@charset "utf-8";

:root{
  --color-main: #2D75C8;
  --color-text: #484848;
  --color-white: #FFFFFF;
  --grad-main: linear-gradient(90deg,#2D75C8 0%,#2D75C8 25%,#5B68F2 75%,#5B68F2 100%);
  --inner-width: 1080px;
}

/* ===============================
branding FV
=============================== */
.branding-page {
  background: #fff;
  margin-top: 60px;
overflow-x: hidden;        
}

.branding-page .branding-fv{
  position:relative;
  overflow:hidden;
  background:#fff;
  padding:120px 0 20px;
  min-height:930px;
}

/* 波の少し下からベース色 */
.branding-page .branding-fv::before{
  content:"";
  position:absolute;
  top:140px;
  left:0;
  width:100%;
  height: calc(100% - 138px);
  background: #F3F7FC;
  z-index:0;
}

.branding-page .branding-fv > .container{
  position:relative;
  z-index:10;
  max-width:var(--inner-width);
}

.branding-page .branding-fv .breadcrumb{
  margin-bottom:0px;
}

/* 上段 */
.branding-page .branding-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;
}

.branding-page .branding-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;
}

.branding-page .branding-fv__title::before{
  content:"BRAND";
  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:#F3F7FC;
  z-index:-1;
}

.branding-page .branding-fv__image{
  width:36%;
  position:relative;
  z-index:10;
  margin-top:10px;
}

.branding-page .branding-fv__image img{
  width:100%;
  max-width:257px;
  display:block;
  float: right;
}

/* 下段 */
.branding-page .branding-fv__lead{
  margin-top:130px;
  text-align:center;
  position:relative;
  z-index:10;
}

.branding-page .branding-fv__lead-en{
  font-family:"Karla", sans-serif;
  font-weight:600;
  font-size:20px;
  line-height:1.2;
  letter-spacing:0.15em;
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.branding-page .branding-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);
}

.branding-page .branding-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;
}

.branding-page .branding-fv__lead-text{
  margin-top:0px;
}

.branding-page .branding-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;    
}

.branding-page .branding-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;    
}

.branding-page .branding-fv__lead-text span{
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.branding-page .branding-fv__btn{
  margin-top:44px;
}

.branding-page .branding-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);
}

.branding-page .branding-fv__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0,0,0,0.15);
}
/* wave */
.branding-page .branding-fv__wave.pc{
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 1;
  pointer-events: none;
}

.branding-page .branding-fv__wave.pc img{
  width: 1920px;
  max-width: none;
  display: block;
}

/* circle */
.branding-page .branding-fv__circle{
  position:absolute;
  left:-120px;
  top:-120px;
  width:700px;
  z-index:2;
  pointer-events:none;
}

.branding-page .branding-fv__circle img{
  width:100%;
  display:block;
  opacity:0.7;
}

/* dot */
.branding-page .branding-fv__dot{
  position:absolute;
  z-index:3;
  pointer-events:none;
}

.branding-page .branding-fv__dot img{
  width:100%;
  display:block;
}

.branding-page .branding-fv__dot--left {
  top: 183px;
  left: 48%;
  width: 300px;
}

.branding-page .branding-fv__dot--right {
  top: 500px;
  right: 10px;
  width: 120px;
}
.branding-page .branding-fv__circle-tags{
  list-style: none;
  margin: 22px auto 22px;
  padding: 0;
  display: flex;
  grid-template-columns: max-content max-content;
  justify-content: center;
  column-gap: 8px;
  row-gap: 10px;
  width: fit-content;
}
.branding-page .branding-fv__circle-tags li{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 0;
  padding: 12px 24px;
  border: 2px solid transparent;
  border-radius: 999px;
  background:
    linear-gradient(#FFFFFF, #FFFFFF) padding-box,
    linear-gradient(90deg, #2D75C8 0%, #2D75C8 25%, #5B68F2 75%, #5B68F2 100%) border-box;
  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);
}

/* ===============================
SP
=============================== */
@media (max-width:768px){
    
  .branding-page {
    background: #fff;
    margin-top: 20px;
  }    

  .branding-page .branding-fv{
    padding:80px 0 90px;
    min-height:auto;
    overflow:visible;
    background:#fff;
  }
    
  .branding-page .branding-fv::before {
    top: 80px;
    height: calc(100% - 80px);
    background: linear-gradient(180deg, #F3F7FC 0%, #FFFFFF 100%);     
  }    

  .branding-page .branding-fv .breadcrumb{
    margin-bottom:30px;
  }

  .branding-page .branding-fv__top{
    display:flex;
    justify-content:space-between;
    align-items:flex-start;
  }

  .branding-page .branding-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;
  }

  .branding-page .branding-fv__title::before{
    top:50%;
    left:0;
    transform:translateY(-50%);
    font-size:64px;
    line-height:100%;
  }



  .branding-page .branding-fv__lead{
    margin-top:28px;
    text-align:center;
    padding: 0 7%;    
  }

  .branding-page .branding-fv__lead-en{
    font-size:13px;
    line-height:130%;
    letter-spacing:0.15em;
  }

  .branding-page .branding-fv__lead-title{
    margin-top:10px;
    font-size:24px;
    line-height:150%;
    letter-spacing:0;
  }

  .branding-page .branding-fv__lead-title span{
    font-size:24px;
    line-height:140%;
    letter-spacing:0.03em;
  }

  .branding-page .branding-fv__lead-text{
    margin-top:18px;
  }

  .branding-page .branding-fv__lead-text p{
    font-size:16px;
    line-height:200%;
    letter-spacing:0.1em;
    margin-top: 22px;    
  }

.branding-page .branding-fv__circle-tags{
  margin: 24px auto 0;
  padding: 0;
  width: 100%;
  max-width: 260px;
  display: grid;
  gap: 10px 10px;
  justify-items: center;
  align-items: center;
}

.branding-page .branding-fv__circle-tags li{
  width: auto;
  min-width: 0;
  padding: 10px 16px;
  font-size:16px;
  line-height:100%;
  letter-spacing:0.03em;
}

.branding-page .branding-fv__circle-tags li:nth-child(1){
  grid-column: 2 / 4;
}

.branding-page .branding-fv__circle-tags li:nth-child(2){
  grid-column: 2 / 4;
}

.branding-page .branding-fv__circle-tags li:nth-child(3){
  grid-column: 2 / 3;
}

.branding-page .branding-fv__circle-tags li:nth-child(4){
  grid-column: 3 / 4;
}

.branding-page .branding-fv__circle-tags li:nth-child(5){
  grid-column: 2 / 4;
}

  .branding-page .branding-fv__btn{
    margin-top:22px;
  }

  .branding-page .branding-fv__btn a{
    padding:12px 17px;
    font-size:16px;
    line-height:100%;
    letter-spacing:0.09em;
    box-shadow:2px 2px 0 rgba(0, 0, 0, 0.25);
  }

  .branding-page .branding-fv__wave.sp{
    position: absolute;
    top: 80px;
    left: 50%;
    transform: translateX(-50%);
    width: 660px;
    max-width: 1920px;
    z-index: 1;
    pointer-events: none;
  }

  .branding-page .branding-fv__wave.sp img{
    width: 660px;
    display: block;
  }    

  .branding-page .branding-fv__circle{
    left:-92px;
    top:210px;
    width:330px;
  }

  .branding-page .branding-fv__dot--left{
    top:180px;
    right:88px;
    left:auto;
    width:120px;
  }

  .branding-page .branding-fv__dot--right{
    top:300px;
    right:-18px;
    width:88px;
  }  
    

    
  .branding-page .branding-fv__lead-text p:last-child {
    font-size: 14px;
    line-height: 200%;
    letter-spacing: 10%;
    color: var(--color-text);
    margin-top: 10px;
  }     
    
  .branding-page .branding-fv__top{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  .branding-page .branding-fv__title{
    width: 100%;
  }
.branding-page .branding-fv__image{
  width: 100%;
  margin-top: 12px;
}

 .branding-page .branding-fv__image img {
    width: 100%;
    max-width: 141px;
    display: block;
    float: none;
    margin-left: auto;
    margin-right: 20px;
  }

}


/* ===============================
branding Problem
=============================== */
.branding-page .branding-problem{
  position: relative;
  padding: 200px 0 120px;
  background: linear-gradient(180deg, #F3F7FC 0%, #FFFFFF 100%);
  overflow: hidden;
}

.branding-page .branding-problem__bg{
  position: absolute;
  pointer-events: none;
  z-index: 0;
}

.branding-page .branding-problem__bg img{
  width: 100%;
  display: block;
}

.branding-page .branding-problem__bg--left{
  left: 0;
  top: 40px;
  width: 220px;
}

.branding-page .branding-problem__bg--right{
  right: 0;
  top: 0;
  width: 440px;
}

.branding-page .branding-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;
}

.branding-page .branding-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;
}

.branding-page .branding-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);
}

.branding-page .branding-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;
}

.branding-page .branding-problem__list{
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 2;
}

.branding-page .branding-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);
}

.branding-page .branding-problem__list li::before{
  content: "";
  flex: 0 0 12px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--color-main);
  position: static;
  transform: none;
}

.branding-page .branding-problem__list li:last-child{
  border-bottom: none;
}


.branding-page .branding-problem__image {
  position: absolute;
  right: -23px;
  bottom: -2px;
  z-index: 10;
}

.branding-page .branding-problem__image img{
  width: 100%;
  display: block;
}

.branding-page .branding-problem__image.pc{
  max-width: 148px;
}

.branding-page .branding-problem__message{
  margin-top: 28px;
  text-align: center;
  position: relative;
  z-index: 2;
}

.branding-page .branding-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){

  .branding-page .branding-problem{
    padding: 0 0 80px;
    background: linear-gradient(180deg, #FAF8FF 0%, #FFFFFF 100%);
    overflow: hidden;
  }

  .branding-page .branding-problem__bg--left{
    left: -20px;
    top: 20px;
    width: 120px;
  }

  .branding-page .branding-problem__bg--right{
    right: -30px;
    top: 0;
    width: 140px;
  }

  .branding-page .branding-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;
  }

  .branding-page .branding-problem__label{
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0.15em;
  }

  .branding-page .branding-problem__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-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;
  }

.branding-page .branding-problem__list li{
  gap:12px;
  padding: 14px 8px 14px 0;
  font-size: 16px;
  line-height: 160%;
  letter-spacing: 0.03em;
}

.branding-page .branding-problem__list li::before{
  flex: 0 0 8px;
  width: 8px;
  height: 8px;
}

  .branding-page .branding-problem__image{
    position: absolute;
    left: 50%;
    bottom: 160px;
    transform: translateX(-50%);
    right: auto;
    z-index: 10;
    pointer-events: none;
  }

  .branding-page .branding-problem__image.sp {
    max-width: 281px;
    width: 100%;
  }

  .branding-page .branding-problem__message{
    margin-top: 42px;
    text-align: center;
    position: relative;
    z-index: 2;
  }

  .branding-page .branding-problem__message span{
    padding: 4px;
    font-size: 18px;
    line-height: 130%;
    letter-spacing: 0.1em;
    width: 100%;
    display: block;
    margin:0 auto;
  }
}

/* ===============================
branding Strategy × Creative × Analytics
=============================== */
.branding-page .branding-sca{
  position: relative;
  padding: 120px 0 120px;
  background: var(--color-white);
  overflow: visible;
  z-index: 2;
}

.branding-page .branding-partner__bg.pc{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.branding-page .branding-partner__bg.pc img{
  width: 1920px;
  height: auto;
}

.branding-page .branding-partner__bg02.pc{
  position: absolute;
  left: 50%;
  top:  -360px;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.branding-page .branding-partner__bg02.pc img{
  width: 1920px;
  height: auto;
}


.branding-page .branding-sca__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.branding-page .branding-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;
}

.branding-page .branding-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;
}

.branding-page .branding-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;
}

.branding-page .branding-sca__lead{
  margin-top: 40px;
}

.branding-page .branding-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);
}

.branding-page .branding-sca__lead span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-sca__compare{
  margin-top: 56px;
  position: relative;
  z-index: 2;
}

.branding-page .branding-sca__compare-intro{
  max-width: 720px;
}

.branding-page .branding-sca__compare-intro p{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 2;
  letter-spacing: 0.1em;
  color: var(--color-text);
  margin: 0;
}

.branding-page .branding-sca__compare-intro p + p{
  margin-top: 2px;
}

.branding-page .branding-sca__compare-intro span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-sca__compare-table{
  margin-top: 48px;
  width: 100%;
  display: flex;
  justify-content: flex-end;
}

.branding-page .branding-sca__compare-grid{
  width: 100%;
  max-width: 726px;
  display: grid;
  grid-template-columns: 150px 273px 303px;
  grid-template-rows: 62px repeat(4, 134px);
}

.branding-page .branding-sca__compare-head{
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
}

.branding-page .branding-sca__compare-head--blank{
  background: transparent;
}

.branding-page .branding-sca__compare-head--normal{
  background: #8EB0DA;
  color: #fff;
  border-radius: 24px 24px 0 0;
}

.branding-page .branding-sca__compare-head--ours{
  background: var(--grad-main);
  color: #fff;
  border-radius: 24px 24px 0 0;
}

.branding-page .branding-sca__compare-label{
  display: flex;
  align-items: center;
  justify-content: center;
  background: #8EB0DA;
  border-right: 1px solid #C9DCF4;
  border-bottom: 1px solid #C9DCF4;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.3;
  color: #fff;
}

.branding-page .branding-sca__compare-cell{
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-bottom: 1px solid #8FB3E3;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.6;
}

.branding-page .branding-sca__compare-cell--normal{
  background: rgba(255,255,255,0.45);
  color: #9CC0EF;
  border-right: 1px solid #8FB3E3;
}

.branding-page .branding-sca__compare-cell--ours{
  background: rgba(255,255,255,0.45);
  color: #2D75C8;
  border-left: 3px solid #2D75C8;
  border-right: 3px solid #5B68F2;
}

.branding-page .branding-sca__compare-cell--ours span{
  display: inline-block;
  padding: 14px 18px;
  background: #FFFDA3;
  width:85%;
}

.branding-page .branding-sca__compare-grid > :nth-last-child(3){
    border-bottom-left-radius: 16px;
}

.branding-page .branding-sca__compare-grid > :last-child{
  border-bottom-right-radius: 24px;
}

.branding-page .branding-sca__compare-grid > :nth-last-child(2){
}

.branding-page .branding-sca__compare-grid > :nth-last-child(1){
  border-bottom: 3px solid #5B68F2;
}

.branding-page .branding-sca__compare-grid > .branding-sca__compare-label:nth-last-of-type(1){
  border-bottom-left-radius: 24px;
}

.branding-page .branding-sca__compare-sp{
  display: none;
}

  .branding-page .branding-sca__compare-label:nth-of-type(4){
    border-top-left-radius: 16px;
  }

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .branding-page .branding-sca{
    padding: 0 24px 80px;
    background: var(--color-white);
    overflow: visible;
  }

  .branding-page .branding-partner__bg{
    position: absolute;
    left: 0;
    top: 0%;
    bottom: auto;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .branding-page .branding-partner__bg img{
    width: 100%;
    height: auto;
    display: block;
  }
    
  .branding-page .branding-partner__bg02.sp{
    position: absolute;
    left: 0;
    top: 0%;
    bottom: auto;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .branding-page .branding-partner__bg02.sp img{
    width: 100%;
    height: auto;
    display: block;
  }    

  .branding-page .branding-sca__inner{
    max-width: none;
    position: relative;
    z-index: 2;
  }

  .branding-page .branding-sca__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .branding-page .branding-sca__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-sca__lead{
    margin-top: 24px;
  }

  .branding-page .branding-sca__lead p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .branding-page .branding-sca__compare{
    margin-top: 34px;
  }

  .branding-page .branding-sca__compare-intro{
    max-width: none;
  }

  .branding-page .branding-sca__compare-intro p{
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: 0.08em;
  }

  .branding-page .branding-sca__compare-table{
    display: none;
  }

  .branding-page .branding-sca__compare-sp{
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 30px;
  }

  .branding-page .branding-sca__compare-sp-block{
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #8FB3E3;
    background: rgba(255,255,255,0.45);
  }

  .branding-page .branding-sca__compare-sp-head{
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    background: #8EB0DA;
    color: #fff;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 1;
  }

  .branding-page .branding-sca__compare-sp-head--ours{
    background: var(--grad-main);
  }

  .branding-page .branding-sca__compare-sp-row{
    display: grid;
    grid-template-columns: 132px 1fr;
    min-height: 96px;
  }

  .branding-page .branding-sca__compare-sp-label{
    display: flex;
    align-items: center;
    justify-content: center;
    background: #8EB0DA;
    color: #fff;
    text-align: center;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 1.3;
    border-top: 1px solid #ffffff;
  }

  .branding-page .branding-sca__compare-sp-value{
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    padding: 12px 14px;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-weight: 600;
    font-size: 16px;
    line-height: 1.5;
    color: #9CC0EF;
    background: rgba(255,255,255,0.45);
  }

  .branding-page .branding-sca__compare-sp-value--ours{
    color: #2D75C8;
    box-shadow: inset 0 1px 0 #2D75C8;      
  }

  .branding-page .branding-sca__compare-sp-value--ours span{
    display: inline-block;
    padding: 10px 12px;
    background: #FFFDA3;
    width:100%;  
  }    
    
}

/*===============================
branding Partner
===============================*/
.branding-page .branding-partner{
  position: relative;
  margin: 120px auto 0;
  padding: 0 0 140px;
  overflow: visible;
  z-index: 1;
}


.branding-page .branding-partner__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  padding: 0;
  position: relative;
  z-index: 2;
}

.branding-page .branding-partner__head{
  text-align: right;
  position: relative;
  z-index: 3;
}

.branding-page .branding-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;
}

.branding-page .branding-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);
}

.branding-page .branding-partner__title span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-partner__visual{
  position: relative;
  width: 100%;
  margin: 26px auto 18px;
}

.branding-page .branding-partner__identity {
  position: absolute;
  right: -100px;
  top: 185px;
  width: 885px;
  z-index: 1;
  pointer-events: none;
}

.branding-page .branding-partner__identity img{
  width: 100%;
  display: block;
}

.branding-page .branding-partner__pyramid{
  position: relative;
  width: 593px;
  margin: 0 0 0 26px;
  z-index: 2;
}

.branding-page .branding-partner__pyramid img{
  width: 100%;
  display: block;
}

.branding-page .branding-partner__cards{
  margin-top: 10px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  align-items: flex-start;
  position: relative;
  z-index: 3;
}

.branding-page .branding-partner__card{
  width: 100%;
  background: #FFFFFF;
  border-radius: 32px;
  padding: 80px 125px;
  box-shadow: 4px 4px 4px rgba(0, 0, 0, 0.25);
}

.branding-page .branding-partner__card--01{
  max-width: 885px;
}

.branding-page .branding-partner__card--02{
  max-width: 987px;
}

.branding-page .branding-partner__card--03{
  max-width: 1007px;
}

.branding-page .branding-partner__card-inner{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}

.branding-page .branding-partner__card-main{
  flex: 1 1 auto;
  min-width: 0;
}

.branding-page .branding-partner__card-side{
  flex: 0 0 auto;
  width: fit-content;
  white-space: nowrap;
  border-radius: 12px;
  padding: 24px;
  background: rgba(132, 176, 226, 0.10);
}

.branding-page .branding-partner__card-title{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 100%;
  letter-spacing: 0.04em;
  background: linear-gradient(90deg, #2F75C9 0%, #4070D9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-partner__card-text{
  margin-top: 24px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 170%;
  letter-spacing: 0.10em;
  background: linear-gradient(90deg, #2F75C9 0%, #4070D9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
  width:96%;
}


.branding-page .branding-partner__card-side-title{
  text-align: center;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0.10em;
  background: linear-gradient(90deg, #2F75C9 0%, #4070D9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-partner__card-side-list{
  list-style: none;
  margin: 16px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

.branding-page .branding-partner__card-side-list li{
  position: relative;
  padding-left: 1em;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.45;
  letter-spacing: 0.07em;
  background: linear-gradient(90deg, #2F75C9 0%, #4070D9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-partner__card-side-list li::before{
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
  background: linear-gradient(90deg, #2F75C9 0%, #4070D9 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){
  .branding-page .branding-partner{
    margin: 60px auto 0;
    padding: 0 0 80px;
  }


  .branding-page .branding-partner__inner{
    padding: 0 24px;
    max-width: none;
  }

  .branding-page .branding-partner__head{
    text-align: right;
  }

  .branding-page .branding-partner__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .branding-page .branding-partner__title{
    margin-top: 14px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-partner__visual{
    max-width: 100%;
    min-height: auto;
    margin: 28px auto 24px;
  }

  .branding-page .branding-partner__identity{
    top: 105px;
    right: 50%;
    transform: translateX(50%);
    width: 320px;
  }

  .branding-page .branding-partner__pyramid{
    width: 100%;
    max-width: 320px;
    margin: 0 auto;
  }

  .branding-page .branding-partner__cards{
    margin-top: 28px;
    gap: 22px;
  }

 .branding-page .branding-partner__card {
    padding: 40px 24px;
    border-radius: 32px;
    width: 95%;
    margin: 0 auto;
  }

  .branding-page .branding-partner__card--01,
  .branding-page .branding-partner__card--02,
  .branding-page .branding-partner__card--03{
    max-width: none;
  }

  .branding-page .branding-partner__card-inner{
    flex-direction: column;
    gap: 24px;
    align-items: stretch;
    text-align: center;
  }

  .branding-page .branding-partner__card-title{
    font-size: 18px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-partner__card-text{
    margin-top: 20px;
    font-size: 16px;
    line-height: 160%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-partner__card-side{
    flex: none;
    width: 100%;
    padding: 24px;
  }

  .branding-page .branding-partner__card-side-title{
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.10em;
  }

  .branding-page .branding-partner__card-side-list{
    margin-top: 14px;
    gap: 2px;
  }

  .branding-page .branding-partner__card-side-list li{
    font-size: 14px;
    line-height: 150%;
    letter-spacing: 0.05em;
    text-align: left;
  }
}

/* ===============================
branding Proven Results
=============================== */
.branding-page .branding-results{
  position: relative;
  overflow: visible;
  background: transparent;
  z-index: 2;
  margin: 200px auto 120px;  
}


.branding-page .branding-results__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.branding-page .branding-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;
}

.branding-page .branding-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;
}

.branding-page .branding-results__cards{
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.branding-page .branding-results__card{
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.branding-page .branding-results__image{
  border-radius: 32px;
  overflow: hidden;
}

.branding-page .branding-results__image img{
  width: 100%;
  display: block;
}

.branding-page .branding-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);
}

.branding-page .branding-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);
}

.branding-page .branding-results__text span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.branding-page .branding-results__message{
  margin-top: 72px;
  text-align: center;
}

.branding-page .branding-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);
}

.branding-page .branding-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){

  .branding-page .branding-results{
    padding: 0 24px 80px;
    margin: 60px auto 0;      
  }

  .branding-page .branding-results__inner{
    max-width: none;
  }

  .branding-page .branding-results__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .branding-page .branding-results__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-results__cards{
    margin-top: 32px;
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .branding-page .branding-results__card{
    gap: 12px;
  }

  .branding-page .branding-results__image{
    border-radius: 32px;
  }

  .branding-page .branding-results__category{
    padding: 8px 16px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.05em;
  }

  .branding-page .branding-results__text{
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.1em;
  }

  .branding-page .branding-results__message{
    margin-top: 56px;
  }

  .branding-page .branding-results__message p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .branding-page .branding-results__bg{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .branding-page .branding-results__bg img{
    width: 100%;
    height: auto;
    display: block;
  }

}

/* ===============================
branding FAQ
=============================== */

.branding-page .branding-faq{
  padding: 120px 0;
  position: relative;
  z-index: 3; 
}

/* ヘッダ */
.branding-page .branding-faq__head{
  text-align: center;
}

.branding-page .branding-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;
}

.branding-page .branding-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;
}

/* リスト */
.branding-page .branding-faq__list{
  max-width: var(--inner-width);
  margin: 80px auto 0;
}

/* アイテム */
.branding-page .branding-faq__item{
  padding: 40px 0;
  border-bottom: 1px solid var(--color-main);
}

.branding-page .branding-faq__item:last-child{
  border-bottom: none;
}

/* Q部分 */
.branding-page .branding-faq__q{
  display: flex;
  align-items: center;
  gap: 20px;
}

/* Qアイコン */
.branding-page .branding-faq__q img{
  width: 53px;
  flex: 0 0 53px;
}

/* 質問 */
.branding-page .branding-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);
}

/* 回答 */
.branding-page .branding-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){

  .branding-page .branding-faq{
    padding: 60px 20px;
  }

.branding-page .branding-faq__label{
  font-size: 13px;
  line-height: 130%;
  letter-spacing: 0.15em;
}

.branding-page .branding-faq__title{
  font-size: 24px;
  line-height: 140%;
  letter-spacing: 0.03em;
}

  .branding-page .branding-faq__item{
    padding: 32px 0;
    text-align: center;
  }

  /* Q中央 */
  .branding-page .branding-faq__q{
    flex-direction: column;
    align-items: center;
    gap: 28px;
  }

  .branding-page .branding-faq__q img{
    width: 52px;
    flex: 0 0 52px;
  }

  .branding-page .branding-faq__q h3 {
    font-size: 16px;
    line-height: 140%;
    letter-spacing: 2%;
  }

  /* 回答 */
  .branding-page .branding-faq__a {
    padding-left: 0;
    margin-top: 12px;
    line-height: 180%;
    letter-spacing: 15%;
    text-align: center;
    font-size: 14px;
  }
.branding-page .branding-faq__list {
  max-width: var(--inner-width);
  margin: 0px auto 0;
}    
    
}


/* ===============================
branding CAT
=============================== */
.branding-page .branding-cat{
  padding: 80px 24px;
  background: var(--grad-main);
}

.branding-page .branding-cat__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}

.branding-page .branding-cat__content{
  width: 70%;
}

.branding-page .branding-cat__image{
  width: 30%;
  text-align: center;
}

.branding-page .branding-cat__image img{
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.branding-page .branding-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);
}

.branding-page .branding-cat__lead{
  margin-top: 28px;
}

.branding-page .branding-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);
}

.branding-page .branding-cat__btn{
  margin-top: 36px;
}

.branding-page .branding-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);
}

.branding-page .branding-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;
}

.branding-page .branding-cat__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.25);
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .branding-page .branding-cat{
    padding: 40px 24px 48px;
  }

  .branding-page .branding-cat__inner{
    flex-direction: column-reverse;
    gap: 20px;
    text-align: center;
  }

  .branding-page .branding-cat__content,
  .branding-page .branding-cat__image{
    width: 100%;
  }

  .branding-page .branding-cat__image img{
    max-width: 129px;
  }

  .branding-page .branding-cat__title{
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-cat__lead{
    margin-top: 20px;
  }

  .branding-page .branding-cat__lead p{
    font-weight: 300;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-cat__btn{
    margin-top: 28px;
  }

  .branding-page .branding-cat__btn a{
    padding: 16px 24px;
    font-size: 18px;
    letter-spacing: 0.03em;
  }
}

/* ===============================
branding Copy
=============================== */
.branding-page .branding-copy{
  background: #EFEFEF;
  padding: 30px 100px;
}

.branding-page .branding-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){
  .branding-page .branding-copy{
    padding: 20px 24px;
  }

  .branding-page .branding-copy__text{
    font-size: 11px;
  }
}



/* ===============================
Designed for Execution
=============================== */
.branding-page .branding-execution{
  position: relative;
  padding: 120px 0 110px;
  background: #FFFFFF;
  overflow: hidden;
  z-index: 0;    
}

.branding-page .branding-execution__bg{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1080px;
  pointer-events: none;
  z-index: 0;
}

.branding-page .branding-execution__bg img{
  width: 100%;
  display: block;
}

.branding-page .branding-execution__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
  text-align: center;
}

.branding-page .branding-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;
}

.branding-page .branding-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);
}

.branding-page .branding-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);
}

.branding-page .branding-execution__tags{
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.branding-page .branding-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;
}

.branding-page .branding-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);
}

.branding-page .branding-execution__points{
  margin-top: 56px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 66px;
}

.branding-page .branding-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;
}

.branding-page .branding-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;
}

.branding-page .branding-execution__point span,
.branding-page .branding-execution__point p{
  position: relative;
  z-index: 2;
}

.branding-page .branding-execution__point--01{
  --point-core: #C2881D;
}

.branding-page .branding-execution__point--02{
  --point-core: #C8670A;
}

.branding-page .branding-execution__point--03{
  --point-core: #CB5701;
}


.branding-page .branding-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);
}

.branding-page .branding-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){

  .branding-page .branding-execution{
    padding: 80px 24px 80px;
  }

  .branding-page .branding-execution__bg{
    top: 0;
    max-width: 402px;
  }

  .branding-page .branding-execution__inner{
    max-width: none;
  }

  .branding-page .branding-execution__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .branding-page .branding-execution__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-execution__lead{
    margin-top: 28px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-execution__tags{
    margin-top: 24px;
    gap: 12px;
  }

  .branding-page .branding-execution__tag{
    padding: 8px 16px;
    border-width: 1px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-execution__sublead{
    margin-top: 20px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-execution__points{
    margin-top: 46px;
    flex-direction: column;
    align-items: center;
    gap: 54px;
  }

  .branding-page .branding-execution__point{
    width: 194px;
    min-width: 194px;
    height: 194px;
    padding: 20px;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-execution__point::before{
    inset: -8px;
    filter: blur(18px);
    transform: scale(1.1);
  }

  .branding-page .branding-execution__message{
    margin-top: 54px;
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.03em;
  }

  .branding-page .branding-sca__compare-sp-block--ours{
    border: 2px solid #5B68F2;      
  }



.branding-page .branding-sca__compare-sp-block--normal .branding-sca__compare-sp-label{
  border-top: 1px solid #fff;
}

.branding-page .branding-sca__compare-sp-block--normal .branding-sca__compare-sp-value{
  border-top: 1px solid #8FB3E3;
}

  .branding-page .branding-sca__compare-sp-block--ours .branding-sca__compare-sp-label{
    border-top: 0;
    box-shadow: inset 0 1px 0 #2D75C8;
  }

  .branding-page .branding-sca__compare-sp-row{
    min-height: 0;
  }    
    

    
    
}


