@charset "utf-8";

:root{
  --color-main: #F48A1D;
  --color-text: #484848;
  --color-white: #FFFFFF;
  --grad-main: linear-gradient(90deg,#FFDB66 0%,#FFDB66 25%,#F48A1D 75%,#F48A1D 100%);
  --inner-width: 1080px;
}

/* ===============================
ads FV
=============================== */
.ads-page {
  background: #fff;
  margin-top: 60px;
overflow-x: hidden;        
}

.ads-page .ads-fv{
  position:relative;
  overflow:hidden;
  background:#fff;
  padding:120px 0 20px;
  min-height:930px;
}

/* 波の少し下からベース色 */
.ads-page .ads-fv::before{
  content:"";
  position:absolute;
  top:140px;
  left:0;
  width:100%;
  height: calc(100% - 138px);
  background: #FFF7F0;
  z-index:0;
}

.ads-page .ads-fv > .container{
  position:relative;
  z-index:10;
  max-width:var(--inner-width);
}

.ads-page .ads-fv .breadcrumb{
  margin-bottom:0px;
}

/* 上段 */
.ads-page .ads-fv__top{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 10;
  min-height: 260px;
}

.ads-page .ads-fv__title{
  width: 100%;
  margin-top: 95px;
  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;
}

.ads-page .ads-fv__title::before{
  content: "ad";
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  font-family: "Karla", sans-serif;
  font-weight: 700;
  font-size: 123px;
  line-height: 100%;
  letter-spacing: 0;
  color: #FFF7F0;
  z-index: -1;
}
@media (min-width: 769px) and (max-width: 920px){
.ads-page .ads-fv__title::before {
  font-size: 13vw;
}

}
.ads-page .ads-fv__image{
  position: absolute;
  top: -88px;
  right: 0;
  width: 472px;
  z-index: 3;
}

.ads-page .ads-fv__image img{
  width: 100%;
  max-width: none;
  display: block;
  float: none;
}

/* 下段 */
.ads-page .ads-fv__lead{
  margin-top:130px;
  text-align:center;
  position:relative;
  z-index:10;
}

.ads-page .ads-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;
}

.ads-page .ads-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);
}

.ads-page .ads-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;
}

.ads-page .ads-fv__lead-text{
  margin-top:0px;
}

.ads-page .ads-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;    
}

.ads-page .ads-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: 50px;    
}

.ads-page .ads-fv__lead-text span{
  background: var(--grad-main);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
  background-clip:text;
  color:transparent;
}

.ads-page .ads-fv__btn{
  margin-top:44px;
}

.ads-page .ads-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);
}

.ads-page .ads-fv__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0,0,0,0.15);
}
/* wave */
.ads-page .ads-fv__wave.pc{
  position: absolute;
  top: -40px;
  left: 50%;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 1;
  pointer-events: none;
}

.ads-page .ads-fv__wave.pc img{
  width: 1920px;
  max-width: none;
  display: block;
}

/* circle */
.ads-page .ads-fv__circle{
position: absolute;
  left: -120px;
  top: -90px;
  width: 700px;
  z-index: 2;
  pointer-events: none;
}

.ads-page .ads-fv__circle img{
  width:100%;
  display:block;
  opacity:0.7;
}

/* dot */
.ads-page .ads-fv__dot{
  position:absolute;
  z-index:3;
  pointer-events:none;
}

.ads-page .ads-fv__dot img{
  width:100%;
  display:block;
}

.ads-page .ads-fv__dot--left {
  top: 183px;
  left: 48%;
  width: 300px;
}

.ads-page .ads-fv__dot--right {
  top: 500px;
  right: 10px;
  width: 120px;
}
.ads-page .ads-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;
}
.ads-page .ads-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){
    
  .ads-page {
    background: #fff;
    margin-top: 20px;
  }    

  .ads-page .ads-fv{
    padding:80px 0 90px;
    min-height:auto;
    overflow:visible;
    background:#fff;
  }
    
  .ads-page .ads-fv::before {
    top: 80px;
    height: calc(100% - 80px);
    background: linear-gradient(180deg, #FFF7F0 0%, #FFFFFF 100%);     
  }    

  .ads-page .ads-fv .breadcrumb{
    margin-bottom:30px;
  }

.ads-page .ads-fv__top{
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  min-height: auto;
}

  .ads-page .ads-fv__title{
    width: 100%;
    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;
  }

  .ads-page .ads-fv__title::before{
    top:50%;
    left:0;
    transform:translateY(-50%);
    font-size:64px;
    line-height:100%;
    width: auto;  
    white-space: nowrap;
}



  .ads-page .ads-fv__lead{
    margin-top:28px;
    text-align:center;
    padding: 0 7%;    
  }

  .ads-page .ads-fv__lead-en{
    font-size:13px;
    line-height:130%;
    letter-spacing:0.15em;
  }

  .ads-page .ads-fv__lead-title{
    margin-top:10px;
    font-size:24px;
    line-height:150%;
    letter-spacing:0;
  }

  .ads-page .ads-fv__lead-title span{
    font-size:24px;
    line-height:140%;
    letter-spacing:0.03em;
  }

  .ads-page .ads-fv__lead-text{
    margin-top:18px;
  }

  .ads-page .ads-fv__lead-text p{
    font-size:16px;
    line-height:200%;
    letter-spacing:0.1em;
    margin-top: 22px;    
  }

.ads-page .ads-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;
}

.ads-page .ads-fv__circle-tags li{
  width: auto;
  min-width: 0;
  padding: 10px 16px;
  font-size:16px;
  line-height:100%;
  letter-spacing:0.03em;
}

.ads-page .ads-fv__circle-tags li:nth-child(1){
  grid-column: 2 / 4;
}

.ads-page .ads-fv__circle-tags li:nth-child(2){
  grid-column: 2 / 4;
}

.ads-page .ads-fv__circle-tags li:nth-child(3){
  grid-column: 2 / 3;
}

.ads-page .ads-fv__circle-tags li:nth-child(4){
  grid-column: 3 / 4;
}

.ads-page .ads-fv__circle-tags li:nth-child(5){
  grid-column: 2 / 4;
}

  .ads-page .ads-fv__btn{
    margin-top:22px;
  }

  .ads-page .ads-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);
  }

  .ads-page .ads-fv__wave.sp{
    position: absolute;
    top: 80px;
    left: 50%;
    transform: translateX(-50%);
    width: 660px;
    max-width: 1920px;
    z-index: 1;
    pointer-events: none;
  }

  .ads-page .ads-fv__wave.sp img{
    width: 660px;
    display: block;
  }    

  .ads-page .ads-fv__circle{
    left:-92px;
    top:210px;
    width:330px;
  }

  .ads-page .ads-fv__dot--left{
    top:180px;
    right:88px;
    left:auto;
    width:120px;
  }

  .ads-page .ads-fv__dot--right{
    top:300px;
    right:-18px;
    width:88px;
  }  
    

    
  .ads-page .ads-fv__lead-text p:last-child {
    font-size: 14px;
    line-height: 200%;
    letter-spacing: 10%;
    color: var(--color-text);
    margin-top: 10px;
  }     
    
  .ads-page .ads-fv__top{
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
  }

  .ads-page .ads-fv__title{
    width: 100%;
  }
.ads-page .ads-fv__image{
  position: relative;
  top: auto;
  right: auto;
  width: 100%;
  margin-top: 12px;
}

.ads-page .ads-fv__image img{
  width: 100%;
  max-width: 201px;
  display: block;
  float: none;
  margin-left: auto;
  margin-right: 0px;
}

}


/* ===============================
ads Problem
=============================== */
.ads-page .ads-problem{
  position: relative;
  padding: 200px 0 120px;
  background: linear-gradient(180deg, #FFF7F0 0%, #FFFFFF 100%);
  overflow: hidden;
}

.ads-page .ads-problem__bg{
  position: absolute;
  pointer-events: none;
  z-index: 2;
}

.ads-page .ads-problem__bg img{
  width: 100%;
  display: block;
}

.ads-page .ads-problem__bg--left{
  left: 0;
  top: 40px;
  width: 220px;
}

.ads-page .ads-problem__bg--right{
  right: 0;
  top: 0;
  width: 420px;
}

.ads-page .ads-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: 3;
}

.ads-page .ads-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;
}

.ads-page .ads-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);
}

.ads-page .ads-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;
}

.ads-page .ads-problem__list{
  margin: 0;
  padding: 0;
  list-style: none;
  position: relative;
  z-index: 2;
}

.ads-page .ads-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);
}

.ads-page .ads-problem__list li::before{
  content: "";
  flex: 0 0 12px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--color-main);
  position: static;
  transform: none;
}

.ads-page .ads-problem__list li:last-child{
  border-bottom: none;
}


.ads-page .ads-problem__image {
  position: absolute;
  right: -23px;
  bottom: -2px;
  z-index: 10;
}

.ads-page .ads-problem__image img{
  width: 100%;
  display: block;
}

.ads-page .ads-problem__image.pc{
  max-width: 148px;
}

.ads-page .ads-problem__message{
  margin-top: 28px;
  text-align: center;
  position: relative;
  z-index: 2;
}

.ads-page .ads-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){

  .ads-page .ads-problem{
    padding: 0 0 80px;
    background: linear-gradient(180deg, #FAF8FF 0%, #FFFFFF 100%);
    overflow: hidden;
  }

  .ads-page .ads-problem__bg--left{
    left: -20px;
    top: 20px;
    width: 120px;
  }

  .ads-page .ads-problem__bg--right{
    right: -30px;
    top: 0;
    width: 140px;
  }

  .ads-page .ads-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;
  }

  .ads-page .ads-problem__label{
    font-size: 13px;
    line-height: 100%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-problem__title{
    margin-top: 12px;
    font-size: 23px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-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;
  }

.ads-page .ads-problem__list li{
  gap:12px;
  padding: 14px 8px 14px 0;
  font-size: 16px;
  line-height: 160%;
  letter-spacing: 0.03em;
}

.ads-page .ads-problem__list li::before{
  flex: 0 0 8px;
  width: 8px;
  height: 8px;
}

  .ads-page .ads-problem__image{
    position: absolute;
    left: 50%;
    bottom: 113px;
    transform: translateX(-50%);
    right: auto;
    z-index: 10;
    pointer-events: none;
  }

  .ads-page .ads-problem__image.sp {
    max-width: 281px;
    width: 100%;
  }

  .ads-page .ads-problem__message{
    margin-top: 42px;
    text-align: center;
    position: relative;
    z-index: 2;
  }

  .ads-page .ads-problem__message span{
    padding: 4px;
    font-size: 18px;
    line-height: 130%;
    letter-spacing: 0.1em;
    width: 100%;
    display: block;
    margin:0 auto;
    width: fit-content;  
  }
}

/* ===============================
ads Every Search Leads to You
=============================== */
.ads-page .ads-sca{
  position: relative;
  padding: 120px 0 140px;
  background: #FFFFFF;
  z-index: 2;
}

.ads-page .ads-sca__bg.pc{
  position: absolute;
  left: 50%;
  top: -350px;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.ads-page .ads-sca__bg.pc img{
  width: 1920px;
  height: auto;
  display: block;
}

.ads-page .ads-sca__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.ads-page .ads-sca__head{
  width: 100%;
  max-width: 720px;
  margin-left: auto;
  text-align: right;
}

.ads-page .ads-sca__label{
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  background: linear-gradient(90deg, #49D5C3 0%, #3590C8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.ads-page .ads-sca__title{
  margin-top: 18px;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  background: linear-gradient(90deg, #49D5C3 0%, #3590C8 100%);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.ads-page .ads-sca__content{
  margin-top: 36px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 60px;
}

.ads-page .ads-sca__diagram{
  position: relative;
  flex: 0 0 562px;
  width: 562px;
  height: 562px;
  margin-top: 0px;
}

.ads-page .ads-sca__circle{
  position: absolute;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 170%;
  letter-spacing: 0.03em;
  color: #FFFFFF;
  z-index: 2;
}

.ads-page .ads-sca__circle--top{
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 252px;
  height: 252px;
  background: linear-gradient(90deg, #49D5C3 0%, #42BCC5 100%);
}

.ads-page .ads-sca__circle--left{
  left: 0;
  bottom: 0;
  width: 252px;
  height: 252px;
  background: linear-gradient(90deg, #41BBC5 0%, #3DA9C7 100%);
}

.ads-page .ads-sca__circle--right{
  right: 0;
  bottom: 0;
  width: 252px;
  height: 252px;
  background: linear-gradient(90deg, #3BA7C6 0%, #3590C8 100%);
}

.ads-page .ads-sca__line{
  position: absolute;
  background: #C8C8C8;
  z-index: 1;
  transform-origin: center;
}

.ads-page .ads-sca__line--left{
  top: 150px;
  left: 118px;
  width: 120px;
  height: 1px;
  transform: rotate(58deg);
}

.ads-page .ads-sca__line--right{
  top: 150px;
  right: 118px;
  width: 120px;
  height: 1px;
  transform: rotate(-58deg);
}

.ads-page .ads-sca__line--bottom{
  left: 112px;
  bottom: 90px;
  width: 246px;
  height: 1px;
}

.ads-page .ads-sca__text{
  flex: 1 1 auto;
  max-width: 560px;
  text-align: right;
  padding-top: 0px;
}

.ads-page .ads-sca__lead{
  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);
}

.ads-page .ads-sca__flow{
  margin-top: 26px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.ads-page .ads-sca__flow-item{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 120px;
  min-height: 52px;
  padding: 10px 22px;
  border: 2px solid #16AD9B;
  border-radius: 999px;
  background: #FFFFFF;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0.03em;
  color: #16AD9B;
}

.ads-page .ads-sca__flow-arrow{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 1;
  color: #16AD9B;
}

.ads-page .ads-sca__message{
  margin-top: 24px;
  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);
}


.ads-page .ads-sca__ring{
  position: absolute;
  border: 1px solid #C8C8C8;
  border-radius: 50%;
  z-index: 0;
  pointer-events: none;
}

.ads-page .ads-sca__ring--left {
  width: 368px;
  height: 368px;
  left: 94px;
  top: 86px;
}


/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .ads-page .ads-sca{
    padding: 80px 24px 80px;
    overflow: hidden;
  }

  .ads-page .ads-sca__bg.sp{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .ads-page .ads-sca__bg.sp img{
    width: 100%;
    height: auto;
    display: block;
  }

  .ads-page .ads-sca__inner{
    max-width: none;
    position: relative;
    z-index: 2;
  }

  .ads-page .ads-sca__head{
    max-width: none;
    margin-left: 0;
    text-align: right;
  }

  .ads-page .ads-sca__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-sca__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-sca__content{
    margin-top: 28px;
    display: flex;
    flex-direction: column;
    gap: 34px;
  }

  .ads-page .ads-sca__text{
    order: 1;
    max-width: none;
    text-align: center;
    padding-top: 0;
  }

  .ads-page .ads-sca__lead{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.08em;
  }

  .ads-page .ads-sca__flow{
    margin-top: 24px;
    flex-direction: column;
    justify-content: center;
    gap: 10px;
  }

  .ads-page .ads-sca__flow-item{
    min-width: 144px;
    min-height: 52px;
    padding: 10px 22px;
    font-size: 16px;
  }

  .ads-page .ads-sca__flow-arrow{
    transform: rotate(90deg);
    font-size: 18px;
  }

  .ads-page .ads-sca__message{
    margin-top: 20px;
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.08em;
    text-align: center;
  }

  .ads-page .ads-sca__diagram {
    order: 2;
    flex: none;
    width: 100%;
    height: 344px;
    margin-top: 0px;
  }

  .ads-page .ads-sca__circle{
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-sca__circle--top{
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 174px;
    height: 174px;
  }

.ads-page .ads-sca__circle--left{
  left: 0;
  bottom: 0;
  width: 174px;
  height: 174px;
}

.ads-page .ads-sca__circle--right{
  right: 0;
  bottom: 0;
  width: 174px;
  height: 174px;
}
    
  .ads-page .ads-sca__ring--left {
    width: 168px;
    height: 168px;
    left: 50%;
    top: 95px;
    transform: translateX(-50%);
  }
    
}

/*===============================
ads Partner
===============================*/
.ads-page .ads-partner{
  position: relative;
  margin: 120px auto 0;
  padding: 0 0 140px;
  overflow: visible;
  z-index: 1;
}

.ads-page .ads-partner__bg.pc{
  position: absolute;
  left: 50%;
  top: -320px;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.ads-page .ads-partner__bg.pc img{
  width: 1920px;
  height: auto;
  display: block;
}

.ads-page .ads-partner__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.ads-page .ads-partner__hero{
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 40px;
  align-items: flex-end;    
}

.ads-page .ads-partner__head{
  flex: 0 0 60%;
  max-width: 600px;
  position: relative;
  z-index: 3;
  text-align: left;
  padding-top: 28px;
}

.ads-page .ads-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;
}

.ads-page .ads-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);
}

.ads-page .ads-partner__title span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.ads-page .ads-partner__lead{
  margin-top: 30px;
  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);
}

.ads-page .ads-partner__visual{
  flex: 0 0 420px;
  width: 420px;
  height: 320px;
  position: relative;
  z-index: 2;
  pointer-events: none;
}

.ads-page .ads-partner__circle{
  --point-core: #49D5C3;
  position: absolute;
  z-index: 0;
  isolation: isolate;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #FFFFFF;
  background: transparent;
  overflow: visible;

  font-family: "Karla", sans-serif;
  font-weight: 700;
  font-size: 22px;
  line-height: 1;
  letter-spacing: 0.03em;
}

.ads-page .ads-partner__circle::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;
}

.ads-page .ads-partner__circle span,
.ads-page .ads-partner__circle p{
  position: relative;
  z-index: 2;
}

.ads-page .ads-partner__circle--ads{
  --point-core: #FBBA49;
  top: 10px;
  left: 142px;
  width: 166px;
  height: 166px;
}

.ads-page .ads-partner__circle--llmo{
  --point-core: #F8A636;
  left: 44px;
  bottom: 0;
  width: 166px;
  height: 166px;
}

.ads-page .ads-partner__circle--meo{
  --point-core: #F48B1E;
  right: 28px;
  bottom: 0;
  width: 166px;
  height: 166px;
}

.ads-page .ads-partner__cards{
  margin-top: 34px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  position: relative;
  z-index: 3;
}

.ads-page .ads-partner__card{
  width: 100%;
  border-radius: 32px;
  padding: 32px;
  display: block;
  box-shadow: 4px 4px 4px #00000040;
}

.ads-page .ads-partner__card-titlearea{
  flex: 0 0 104px;
  width: 104px;
}

.ads-page .ads-partner__card-titlearea img{
  display: block;
  width: 104px;
  height: auto;
}

.ads-page .ads-partner__card-title{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 24px;
  line-height: 140%;
  letter-spacing: 0.04em;
  text-align: left;
}

.ads-page .ads-partner__card-text{
  margin-top: 0;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 170%;
  letter-spacing: 0.1em;
  text-align: left;
  color: #F48A1D;
}

.ads-page .ads-partner__card--ads{
  max-width: 762px;
  background: #ffffff;
  color:#F48A1D;
}

.ads-page .ads-partner__card--llmo{
  max-width: 1053px;
  background: #ffffff;
  color:#F48A1D;
}

.ads-page .ads-partner__card--meo{
  max-width: 975px;
  background: #ffffff;
  color:#F48A1D;
}

.ads-page .ads-partner__card-box-title{
  text-align: center;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 18px;
  line-height: 100%;
  letter-spacing: 0.08em;
}

.ads-page .ads-partner__card-box-list{
  list-style: none;
  margin: 18px 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ads-page .ads-partner__card-box-list li{
  position: relative;
  padding-left: 1em;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 1.65;
  letter-spacing: 0.05em;
}

.ads-page .ads-partner__card-box-list li::before{
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
}

.ads-page .ads-partner__card-content{
  margin-top: 0;
  display: flex;
  align-items: center;
  gap: 20px;
}

.ads-page .ads-partner__card-main{
  flex: 1 1 0;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ads-page .ads-partner__card-box{
  flex: 0 0 auto;
  max-width: 100%;
  border-radius: 14px;
  padding: 22px 24px;
  background: rgba(255, 175, 103, 0.1);
}

.ads-page .ads-partner__card--ads .ads-partner__card-box-title,
.ads-page .ads-partner__card--ads .ads-partner__card-box-list li,
.ads-page .ads-partner__card--ads .ads-partner__card-box-list li::before{
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: #F48A1D;
  background-clip: initial;
  color: #F48A1D;
}

.ads-page .ads-partner__card--llmo .ads-partner__card-box-title,
.ads-page .ads-partner__card--llmo .ads-partner__card-box-list li,
.ads-page .ads-partner__card--llmo .ads-partner__card-box-list li::before{
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: #F48A1D;
  background-clip: initial;
  color: #F48A1D;
}

.ads-page .ads-partner__card--meo .ads-partner__card-box-title,
.ads-page .ads-partner__card--meo .ads-partner__card-box-list li,
.ads-page .ads-partner__card--meo .ads-partner__card-box-list li::before{
  background: none;
  -webkit-background-clip: initial;
  -webkit-text-fill-color: #F48A1D;
  background-clip: initial;
  color: #F48A1D;
}


/* ===============================
SP
=============================== */
@media (max-width: 768px){
  .ads-page .ads-partner{
    margin: 0px auto 0;
    padding: 0 0 80px;
  }

  .ads-page .ads-partner__bg.sp{
    position: absolute;
    left: 0;
    top: 620px;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .ads-page .ads-partner__bg.sp img{
    width: 100%;
    height: auto;
    display: block;
  }

  .ads-page .ads-partner__inner{
    padding: 0 24px;
    max-width: none;
  }

  .ads-page .ads-partner__hero{
    display: flex;
    flex-direction: column;
    gap: 22px;
  }

  .ads-page .ads-partner__head{
    flex: none;
    max-width: none;
    width: 100%;
    padding-top: 0;
    order: 1;
    margin-bottom:80px;
  }

  .ads-page .ads-partner__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-partner__title{
    margin-top: 14px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-partner__lead{
    margin-top: 24px;
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.08em;
  }


.ads-page .ads-partner__visual{
  order: 2;
  flex: none;
  width: 100%;
  margin-top: 8px;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: flex-start;
  gap: 18px;
  height: auto;
}

.ads-page .ads-partner__circle{
  position: relative;
  top: auto;
  left: auto;
  right: auto;
  bottom: auto;
  transform: none;
  flex: 0 0 auto;
  margin: 0 auto;    
}

.ads-page .ads-partner__circle--ads{
  width: 156px;
  height: 156px;
  margin-left: calc(50% - 78px);
  margin-right: calc(50% - 78px);
  margin-bottom: -18px;
}

.ads-page .ads-partner__circle--llmo{
  width: 156px;
  height: 156px;
}

.ads-page .ads-partner__circle--meo{
  width: 156px;
  height: 156px;
}
    
    
    
  .ads-page .ads-partner__circle{
    font-size: 18px;
  }

  .ads-page .ads-partner__cards{
    margin-top: 80px;
    gap: 24px;
  }

  .ads-page .ads-partner__card {
    max-width: 90%;
    margin-left: auto;
    padding: 34px 22px 22px;
    border-radius: 32px;
    display: block;
    margin-right: auto;
  }

.ads-page .ads-partner__card-titlearea{
  text-align: center;
}

.ads-page .ads-partner__card-content{
  margin-top: 22px;
  display: flex;
  flex-direction: column;
  gap: 24px;
}

  .ads-page .ads-partner__card-title {
    font-size: 24px;
    line-height: 130%;
    text-align: center;
    letter-spacing: 3%;
  }

.ads-page .ads-partner__card-subtitle{
  margin-top: 10px;
  font-size: 12px;
  line-height: 100%;
  letter-spacing: 0.08em;
}

.ads-page .ads-partner__card-text{
  margin-top: 0;
  font-size: 16px;
  line-height: 190%;
  letter-spacing: 0.05em;
  text-align: center;
}

.ads-page .ads-partner__card-box{
  flex: none;
  width: 100%;
  max-width: none;
  padding: 20px 18px;
  border-radius: 14px;
}    

  .ads-page .ads-partner__card-box-title{
    font-size: 16px;
  }

  .ads-page .ads-partner__card-box-list{
    margin-top: 14px;
    gap: 8px;
  }

  .ads-page .ads-partner__card-box-list li{
    font-size: 14px;
    line-height: 1.7;
    letter-spacing: 0.03em;
  }
}



/* ===============================
ads Proven Results
=============================== */
.ads-page .ads-results{
  position: relative;
  overflow: visible;
  background: transparent;
  z-index: 3;
  margin: 200px auto 120px;  
}


.ads-page .ads-results__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.ads-page .ads-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;
}

.ads-page .ads-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;
}

.ads-page .ads-results__cards{
  margin-top: 52px;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
}

.ads-page .ads-results__card{
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.ads-page .ads-results__image{
  border-radius: 32px;
  overflow: hidden;
}

.ads-page .ads-results__image img{
  width: 100%;
  display: block;
}

.ads-page .ads-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);
}

.ads-page .ads-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);
}

.ads-page .ads-results__text span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.ads-page .ads-results__message{
  margin-top: 72px;
  text-align: center;
}

.ads-page .ads-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);
}

.ads-page .ads-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){

  .ads-page .ads-results{
    padding: 0 24px 80px;
    margin: 60px auto 0;      
  }

  .ads-page .ads-results__inner{
    max-width: none;
  }

  .ads-page .ads-results__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-results__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-results__cards{
    margin-top: 32px;
    grid-template-columns: 1fr;
    gap: 32px;
  }

  .ads-page .ads-results__card{
    gap: 12px;
  }

  .ads-page .ads-results__image{
    border-radius: 32px;
  }

  .ads-page .ads-results__category{
    padding: 8px 16px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.05em;
  }

  .ads-page .ads-results__text{
    font-size: 16px;
    line-height: 170%;
    letter-spacing: 0.1em;
  }

  .ads-page .ads-results__message{
    margin-top: 56px;
  }

  .ads-page .ads-results__message p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .ads-page .ads-results__bg{
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .ads-page .ads-results__bg img{
    width: 100%;
    height: auto;
    display: block;
  }

}

/* ===============================
ads FAQ
=============================== */

.ads-page .ads-faq{
  padding: 120px 0;
  position: relative;
  z-index: 3; 
}

/* ヘッダ */
.ads-page .ads-faq__head{
  text-align: center;
}

.ads-page .ads-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;
}

.ads-page .ads-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;
}

/* リスト */
.ads-page .ads-faq__list{
  max-width: var(--inner-width);
  margin: 80px auto 0;
}

/* アイテム */
.ads-page .ads-faq__item{
  padding: 40px 0;
  border-bottom: 1px solid var(--color-main);
}

.ads-page .ads-faq__item:last-child{
  border-bottom: none;
}

/* Q部分 */
.ads-page .ads-faq__q{
  display: flex;
  align-items: center;
  gap: 20px;
}

/* Qアイコン */
.ads-page .ads-faq__q img{
  width: 53px;
  flex: 0 0 53px;
}

/* 質問 */
.ads-page .ads-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);
}

/* 回答 */
.ads-page .ads-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){

  .ads-page .ads-faq{
    padding: 60px 20px;
  }

.ads-page .ads-faq__label{
  font-size: 13px;
  line-height: 130%;
  letter-spacing: 0.15em;
}

.ads-page .ads-faq__title{
  font-size: 24px;
  line-height: 140%;
  letter-spacing: 0.03em;
}

  .ads-page .ads-faq__item{
    padding: 32px 0;
    text-align: center;
  }

  /* Q中央 */
  .ads-page .ads-faq__q{
    flex-direction: column;
    align-items: center;
    gap: 28px;
  }

  .ads-page .ads-faq__q img{
    width: 52px;
    flex: 0 0 52px;
  }

  .ads-page .ads-faq__q h3 {
    font-size: 16px;
    line-height: 140%;
    letter-spacing: 2%;
  }

  /* 回答 */
  .ads-page .ads-faq__a {
    padding-left: 0;
    margin-top: 12px;
    line-height: 180%;
    letter-spacing: 15%;
    text-align: center;
    font-size: 14px;
  }
.ads-page .ads-faq__list {
  max-width: var(--inner-width);
  margin: 0px auto 0;
}    
    
}


/* ===============================
ads CAT
=============================== */
.ads-page .ads-cat{
  padding: 80px 24px;
  background: var(--grad-main);
}

.ads-page .ads-cat__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 40px;
}

.ads-page .ads-cat__content{
  width: 70%;
}

.ads-page .ads-cat__image{
  width: 30%;
  text-align: center;
}

.ads-page .ads-cat__image img{
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}

.ads-page .ads-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);
}

.ads-page .ads-cat__lead{
  margin-top: 28px;
}

.ads-page .ads-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);
}

.ads-page .ads-cat__btn{
  margin-top: 36px;
}

.ads-page .ads-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);
}

.ads-page .ads-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;
}

.ads-page .ads-cat__btn a:hover{
  transform: translate(4px, 4px);
  box-shadow: 0 0 0 rgba(0, 0, 0, 0.25);
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .ads-page .ads-cat{
    padding: 40px 24px 48px;
  }

  .ads-page .ads-cat__inner{
    flex-direction: column-reverse;
    gap: 20px;
    text-align: center;
  }

  .ads-page .ads-cat__content,
  .ads-page .ads-cat__image{
    width: 100%;
  }

  .ads-page .ads-cat__image img{
    max-width: 129px;
  }

  .ads-page .ads-cat__title{
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-cat__lead{
    margin-top: 20px;
  }

  .ads-page .ads-cat__lead p{
    font-weight: 300;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-cat__btn{
    margin-top: 28px;
  }

  .ads-page .ads-cat__btn a{
    padding: 16px 24px;
    font-size: 18px;
    letter-spacing: 0.03em;
  }
}

/* ===============================
ads Copy
=============================== */
.ads-page .ads-copy{
  background: #EFEFEF;
  padding: 30px 100px;
}

.ads-page .ads-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){
  .ads-page .ads-copy{
    padding: 20px 24px;
  }

  .ads-page .ads-copy__text{
    font-size: 11px;
  }
}



/* ===============================
Designed for Execution
=============================== */
.ads-page .ads-execution{
  position: relative;
  padding: 120px 0 110px;
  background: #FFFFFF;
  overflow: hidden;
  z-index: 0;    
}

.ads-page .ads-execution__bg{
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  max-width: 1080px;
  pointer-events: none;
  z-index: 0;
}

.ads-page .ads-execution__bg img{
  width: 100%;
  display: block;
}

.ads-page .ads-execution__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
  text-align: center;
}

.ads-page .ads-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;
}

.ads-page .ads-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);
}

.ads-page .ads-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);
}

.ads-page .ads-execution__tags{
  margin-top: 20px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}

.ads-page .ads-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;
}

.ads-page .ads-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);
}

.ads-page .ads-execution__points{
  margin-top: 56px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  gap: 66px;
}

.ads-page .ads-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;
}

.ads-page .ads-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;
}

.ads-page .ads-execution__point span,
.ads-page .ads-execution__point p{
  position: relative;
  z-index: 2;
}

.ads-page .ads-execution__point--01{
  --point-core: #C2881D;
}

.ads-page .ads-execution__point--02{
  --point-core: #C8670A;
}

.ads-page .ads-execution__point--03{
  --point-core: #CB5701;
}


.ads-page .ads-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);
}

.ads-page .ads-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){

  .ads-page .ads-execution{
    padding: 80px 24px 80px;
  }

  .ads-page .ads-execution__bg{
    top: 0;
    max-width: 402px;
  }

  .ads-page .ads-execution__inner{
    max-width: none;
  }

  .ads-page .ads-execution__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-execution__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-execution__lead{
    margin-top: 28px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-execution__tags{
    margin-top: 24px;
    gap: 12px;
  }

  .ads-page .ads-execution__tag{
    padding: 8px 16px;
    border-width: 1px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-execution__sublead{
    margin-top: 20px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-execution__points{
    margin-top: 46px;
    flex-direction: column;
    align-items: center;
    gap: 54px;
  }

  .ads-page .ads-execution__point{
    width: 194px;
    min-width: 194px;
    height: 194px;
    padding: 20px;
    font-size: 16px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-execution__point::before{
    inset: -8px;
    filter: blur(18px);
    transform: scale(1.1);
  }

  .ads-page .ads-execution__message{
    margin-top: 54px;
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-sca__compare-sp-block--ours{
    border: 2px solid #5B68F2;      
  }

}

/* ===============================
ads Strategy
=============================== */
.ads-page .ads-strategy{
  padding: 120px 0;
  position: relative;
  z-index: 3;
}

.ads-page .ads-strategy__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
}

.ads-page .ads-strategy__label{
  text-align: center;
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  color: #F4A62A;
}

.ads-page .ads-strategy__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.03em;
  color: var(--color-text);
}

.ads-page .ads-strategy__cards{
  margin-top: 48px;
  display: flex;
  flex-direction: column;
  gap: 34px;
}

.ads-page .ads-strategy__row{
  display: flex;
  justify-content: center;
  align-items: stretch;
  gap: 36px;
}

.ads-page .ads-strategy__card{
  min-height: 338px;
  border-radius: 32px;
  padding: 46px 26px 28px;
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #FFFFFF;
}

.ads-page .ads-strategy__card-icon{

}

.ads-page .ads-strategy__card-icon img{
  width: 104px;
  height: 104px;
  object-fit: contain;
  display: block;
}

.ads-page .ads-strategy__card-title{
  margin-top: 22px;
  text-align: center;
  font-family: "Karla", "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 700;
  font-size: 24px;
  line-height: 1.2;
  letter-spacing: 0.02em;
  color: #FFFFFF;
}

.ads-page .ads-strategy__card-list{
  list-style: none;
  margin: 14px 0 0;
  padding: 0;
  width: fit-content;
}

.ads-page .ads-strategy__card-list li{
  position: relative;
  padding-left: 1em;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 300;
  font-size: 16px;
  line-height: 190%;
  letter-spacing: 0.08em;
  color: #FFFFFF;
}

.ads-page .ads-strategy__card-list li::before{
  content: "・";
  position: absolute;
  left: 0;
  top: 0;
  color: #FFFFFF;
}

.ads-page .ads-strategy__card--google{
  width: 286px;
  background: linear-gradient(135deg, #FFDA65 0%, #FBBA49 100%);
}

.ads-page .ads-strategy__card--meta{
  width: 352px;
  background: linear-gradient(135deg, #FCC04D 0%, #F8A636 100%);
}

.ads-page .ads-strategy__card--tiktok{
  width: 221px;
  background: linear-gradient(135deg, #F7A233 0%, #F48B1E 100%);
}

.ads-page .ads-strategy__card--line{
  width: 301px;
  background: linear-gradient(135deg, #F7A233 0%, #F48B1E 100%);
}

.ads-page .ads-strategy__card--youtube{
  width: 399px;
  background: linear-gradient(135deg, #FCC04D 0%, #F8A636 100%);
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .ads-page .ads-strategy{
    padding: 80px 16px;
  }

  .ads-page .ads-strategy__inner{
    max-width: none;
  }

  .ads-page .ads-strategy__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-strategy__title{
    margin-top: 12px;
    font-size: 24px;
    line-height: 150%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-strategy__cards{
    margin-top: 34px;
    gap: 18px;
  }

  .ads-page .ads-strategy__row{
    flex-direction: column;
    gap: 18px;
  }

  .ads-page .ads-strategy__card{
    min-height: auto;
    border-radius: 32px;
    padding: 40px 28px 30px;
  }

  .ads-page .ads-strategy__card-icon{
  }

  .ads-page .ads-strategy__card-icon img{
    width: 88px;
    height: auto;
  }

  .ads-page .ads-strategy__card-title{
    margin-top: 20px;
    font-size: 20px;
    line-height: 140%;
  }

  .ads-page .ads-strategy__card-list{
    margin-top: 12px;
    width: fit-content;  
  }

  .ads-page .ads-strategy__card-list li{
    font-size: 14px;
    line-height: 190%;
    letter-spacing: 0.06em;
  }

  .ads-page .ads-strategy__card--google{
    max-width: 260px;
    margin: 0 auto;
  }
    
  .ads-page .ads-strategy__card--meta{
    max-width: 291px;
    margin: 0 auto;
  }    
    
  .ads-page .ads-strategy__card--tiktok{
    max-width: 194px;
    margin: 0 auto;
  }
    
  .ads-page .ads-strategy__card--line{
    max-width: 291px;
    margin: 0 auto;
  }
    
  .ads-page .ads-strategy__card--youtube{
    max-width: 370px;
    margin: 0 auto;
  }        

}


/* ===============================
ads partnar
=============================== */
.ads-page .ads-partnar{
  position: relative;
  padding: 120px 0 120px;
  background: var(--color-white);
  overflow: visible;
  z-index: 2;
}

.ads-page .ads-partner__bg.pc{
  position: absolute;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.ads-page .ads-partner__bg.pc img{
  width: 1920px;
  height: auto;
}

.ads-page .ads-partner__bg02.pc{
  position: absolute;
  left: 50%;
  top:  -360px;
  transform: translateX(-50%);
  width: 1920px;
  z-index: 0;
  pointer-events: none;
}

.ads-page .ads-partner__bg02.pc img{
  width: 1920px;
  height: auto;
}


.ads-page .ads-partnar__inner{
  max-width: var(--inner-width);
  margin: 0 auto;
  position: relative;
  z-index: 2;
}

.ads-page .ads-partnar__label{
  font-family: "Karla", sans-serif;
  font-weight: 600;
  font-size: 20px;
  line-height: 100%;
  letter-spacing: 0.15em;
  color: #F48A1D;
  padding-bottom: 18px;
}

.ads-page .ads-partnar__title{
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 36px;
  line-height: 150%;
  letter-spacing: 0;
  background: linear-gradient(90deg,#FFDB66 0%,#F48A1D 100%);;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.ads-page .ads-partnar__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: 600;
}

.ads-page .ads-partnar__lead{
  margin-top: 40px;
}

.ads-page .ads-partnar__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);
}

.ads-page .ads-partnar__lead span{
  color: #F48A1D;
}

.ads-page .ads-partnar__compare{
  margin-top: 56px;
  position: relative;
  z-index: 2;
}

.ads-page .ads-partnar__compare-intro{
  max-width: 720px;
}

.ads-page .ads-partnar__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;
}

.ads-page .ads-partnar__compare-intro p + p{
  margin-top: 2px;
}

.ads-page .ads-partnar__compare-intro span{
  background: var(--grad-main);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  color: transparent;
}

.ads-page .ads-partnar__compare-table{
  margin-top: 48px;
  width: 100%;
  display: flex;
  justify-content: flex-end;
}

.ads-page .ads-partnar__compare-grid{
  width: 100%;
  max-width: 726px;
  display: grid;
  grid-template-columns: 150px 273px 303px;
  grid-template-rows: 62px repeat(4, 134px);
}

.ads-page .ads-partnar__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;
}

.ads-page .ads-partnar__compare-head--blank{
  background: transparent;
}

.ads-page .ads-partnar__compare-head--normal{
  background: #F48A1D;
  color: #fff;
  border-radius: 24px 24px 0 0;
}

.ads-page .ads-partnar__compare-head--ours{
  background: var(--grad-main);
  color: #fff;
  border-radius: 24px 24px 0 0;
}

.ads-page .ads-partnar__compare-label{
  display: flex;
  align-items: center;
  justify-content: center;
  background: #F48A1D;
  border-right: 1px solid #F48A1D;
  border-bottom: 1px solid #FFFFFF;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.3;
  color: #fff;
}

.ads-page .ads-partnar__compare-cell{
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  border-bottom: 1px solid #F48A1D;
  font-family: "Hiragino Kaku Gothic ProN", sans-serif;
  font-weight: 600;
  font-size: 16px;
  line-height: 1.6;
}

.ads-page .ads-partnar__compare-cell--normal{
  background: #FFFFFF;
  color: #F48A1D;
  border-right: 1px solid #FFDB66;
}

.ads-page .ads-partnar__compare-cell--ours{
  background: #FFFFFF;
  color: #F48A1D;
  border-left: 3px solid #FFDB66;
  border-right: 3px solid #F48A1D;
}

.ads-page .ads-partnar__compare-cell--ours span{
  display: inline-block;
  padding: 14px 18px;
  background: #FFFDA3;
  width:85%;
}

.ads-page .ads-partnar__compare-grid > :nth-last-child(3){
    border-bottom-left-radius: 16px;
    border-bottom: 1px solid #F48A1D;    
}

.ads-page .ads-partnar__compare-grid > :last-child{
  border-bottom-right-radius: 24px;
}

.ads-page .ads-partnar__compare-grid > :nth-last-child(2){
}

.ads-page .ads-partnar__compare-grid > :nth-last-child(1){
  border-bottom: 3px solid #F48A1D;
}

.ads-page .ads-partnar__compare-grid > .ads-partnar__compare-label:nth-last-of-type(1){
  border-bottom-left-radius: 24px;
}

.ads-page .ads-partnar__compare-sp{
  display: none;
}

  .ads-page .ads-partnar__compare-label:nth-of-type(4){
    border-top-left-radius: 16px;
  }

.title_bg{
  position: relative;
}

.title_bg__backword{
  position: absolute;
  top: 50%;
  left: 320px;
  transform: translateY(-50%);
  z-index: -1;
}

/* ===============================
SP
=============================== */
@media (max-width: 768px){

  .ads-page .ads-partnar{
    padding: 0 24px 80px;
    background: var(--color-white);
    overflow: visible;
  }

  .ads-page .ads-partner__bg{
    position: absolute;
    left: 0;
    top: 0%;
    bottom: auto;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .ads-page .ads-partner__bg img{
    width: 100%;
    height: auto;
    display: block;
  }
    
  .ads-page .ads-partner__bg02.sp{
    position: absolute;
    left: 0;
    top: -15%;
    bottom: auto;
    width: 100%;
    z-index: 0;
    pointer-events: none;
  }

  .ads-page .ads-partner__bg02.sp img{
    width: 100%;
    height: auto;
    display: block;
  }    

  .ads-page .ads-partnar__inner{
    max-width: none;
    position: relative;
    z-index: 2;
  }

  .ads-page .ads-partnar__label{
    font-size: 13px;
    line-height: 130%;
    letter-spacing: 0.15em;
  }

  .ads-page .ads-partnar__title{
    margin-top: 16px;
    font-size: 24px;
    line-height: 140%;
    letter-spacing: 0.03em;
  }

  .ads-page .ads-partnar__lead{
    margin-top: 24px;
  }

  .ads-page .ads-partnar__lead p{
    font-size: 16px;
    line-height: 200%;
    letter-spacing: 0.1em;
  }

  .ads-page .ads-partnar__compare{
    margin-top: 34px;
  }

  .ads-page .ads-partnar__compare-intro{
    max-width: none;
  }

  .ads-page .ads-partnar__compare-intro p{
    font-size: 16px;
    line-height: 1.9;
    letter-spacing: 0.08em;
  }

  .ads-page .ads-partnar__compare-table{
    display: none;
  }

  .ads-page .ads-partnar__compare-sp{
    display: flex;
    flex-direction: column;
    gap: 16px;
    margin-top: 30px;
  }

  .ads-page .ads-partnar__compare-sp-block{
    border-radius: 16px;
    overflow: hidden;
    border: 1px solid #F48A1D;
    background: rgba(255,255,255,0.45);
  }

  .ads-page .ads-partnar__compare-sp-head{
    display: flex;
    align-items: center;
    justify-content: center;
    min-height: 58px;
    background: #F48A1D;
    color: #fff;
    font-family: "Hiragino Kaku Gothic ProN", sans-serif;
    font-weight: 600;
    font-size: 18px;
    line-height: 1;
  }

  .ads-page .ads-partnar__compare-sp-head--ours{
    background: var(--grad-main);
  }

  .ads-page .ads-partnar__compare-sp-row{
    display: grid;
    grid-template-columns: 132px 1fr;
  }

  .ads-page .ads-partnar__compare-sp-label{
    display: flex;
    align-items: center;
    justify-content: center;
    background: #F48A1D;
    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;
  }
    

  .ads-page .ads-partnar__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: #F48A1D;
    background: rgba(255,255,255,0.45);
    box-shadow: inset 0 1px 0 #F48A1D;        
  }

  .ads-page .ads-partnar__compare-sp-value--ours{
    color: #F48A1D;
    box-shadow: inset 0 1px 0 #F48A1D;      
  }

  .ads-page .ads-partnar__compare-sp-value--ours span{
    display: inline-block;
    padding: 10px 12px;
    background: #FFFDA3;
    width:100%;  
  }    
    
  .ads-page .ads-partnar .title_bg::before{
    font-size: 56px;
    left: 50%;
    transform: translate(-50%, -50%);
  }
    
.title_bg__backword {
  position: absolute;
  top: 48%;
  left: 100px;
  transform: translateY(-50%);
  z-index: -1;
}    
   
.ads-page .ads-partnar__label {
  padding-bottom: 0px;
}    
   
.ads-page .ads-partnar__compare-sp-block--ours .ads-partnar__compare-sp-head--ours + .ads-partnar__compare-sp-row .ads-partnar__compare-sp-label{
  border-top: none;
}

.ads-page .ads-partnar__compare-sp-block--ours .ads-partnar__compare-sp-head--ours + .ads-partnar__compare-sp-row .ads-partnar__compare-sp-value--ours{
  box-shadow: none;
}
    
}



