:root{
  --default: #333;
  --white: #FFF;
  --blue: #163CE0;
  --pink: #E715D2;

  --bgblue: #1330AF;
  --bg-gray: #E9EDFF;

  interpolate-size: allow-keywords;
}

html,body{
  font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, sans-serif;
  color: var(--default);
  font-feature-settings: 'pwid' 1;
}
h1,h2,h3,h4,h5,h6{
  font-feature-settings: 'palt' on;
}
figure{
  @media screen and (max-width: 767px){
    width: 100%;
    img{width: 100%;}
  }
}

.pcb{
  display: block;
  @media screen and (max-width: 767px){
    display: none;
  }
}
.spb{
  display: none;
  @media screen and (max-width: 767px){
    display: block;
  }
}

.btn-base{
  box-sizing: border-box;
  display: block;
  border-radius: 200px;
  box-shadow: 0 0 10px 0 rgba(0, 60, 255, .4);
  transition: all .3s;
  &:hover{
    box-shadow: 0 0 0 0 rgba(0, 60, 255, .4);
  }
}
.btn-white{
  color: var(--blue);
  border: 1px solid #fff;
  &:hover{
    color: var(--bgblue);
    border: 1px solid rgba(0, 60, 255, .4);
  }
}
.btn-blue{
  color: var(--white);
  background: var(--blue);
  &:hover{
    color: var(--white);
    background: var(--bgblue);
  }
}
.btn-header{
  padding: 8px 16px;
  @media screen and (max-width: 767px){
    padding: 8px 12px;
  }
}
.fv-btn{
  margin-top: 48px;
  display: flex;
  gap: 16px;
  @media screen and (max-width: 767px){
    margin-top: -30px;
    justify-content: center;
  }
}
.btn-fv,
.btn-cta{
  text-decoration: none;
  font-size: 24px;
  font-weight: 700;
  padding: 10px 24px 12px;
  min-width: 200px;
  text-align: center;
  @media screen and (max-width: 767px){
    font-size: 20px;
    padding: 10px 16px 12px;
    min-width: auto;
  }
}
.cta-btn{
  margin-top: 44px;
  display: flex;
  justify-content: center;
  gap: 16px;
  @media screen and (max-width: 767px){
    flex-direction: column;
    margin-top: 24px;
  }
  &.cta-add{
    margin-top: 24px;
  }
}
.btn-cta{
  padding: 10px 52px 12px;
}
.cta-design{
  justify-content: flex-start;
  margin-top: 24px;
  @media screen and (max-width: 767px) {
    text-align: center;
  }
}
.btn-cta-img{
  padding: 8px 16px;
  text-decoration: none;
  font-weight: 700;
  @media screen and (max-width: 767px) {
    width: 90%;
    margin: 0 auto;
  }
  &.btn-white{
    background: var(--white);
    color: #017F92;
    &:hover{
      color: #006271;
    }
  }
  &.btn-green{
    background: #00A59A;
    color: var(--white);
    &:hover{
      background: #006271;
    }
  }
}



.title{
  font-size: 40px;
  font-weight: 700;
  letter-spacing: 2px;
  font-feature-settings: 'palt' on;
  @media screen and (max-width: 767px){
    font-size: 32px;
  }
}
.title-w,
.title-small-w{
  color: var(--white);
}
.title-small{
  font-size: 32px;
  font-weight: 700;
  letter-spacing: 1.6px;
  font-feature-settings: 'palt' on;
  @media screen and (max-width: 767px){
    font-size: 28px;
  }
}
.title-small-b{
  color: var(--blue);
}

header{
  padding: 8px 40px;
  background: rgba(255, 255, 255, .75);
  box-shadow: 0px 0px 10px 0px rgba(22, 60, 224, .40);
  backdrop-filter: blur(5px);
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 5;
  @media screen and (max-width: 767px){
    padding: 8px 16px;
    h1{
      width: 100%;
      max-width: 113px;
      img{width: 100%;}
    }
  }
  img{
    vertical-align: bottom;
  }
}
nav{
  ul{
    display: flex;
    align-items: center;
    gap: 40px;
    a{
      color: var(--default);
      text-decoration: none;
      font-weight: 700;
      font-size: 18px;
      transition: all .3s;
      &:hover{
        color: var(--blue);
      }
    }
  }
  .tabb{
    @media screen and (max-width: 1220px){
      display: none;
    }
  }
  .btns{
    ul{
      gap: 16px;
      @media screen and (max-width: 767px){
        gap: 8px;
      }
    }
    span{
      @media screen and (max-width: 767px){
        display: none;
      }
    }
    i{
      display: none;
      font-style: normal;
      @media screen and (max-width: 767px){
        display: inline-block;
      }      
    }
  }
}

.contents{
  width: 100%;
  max-width: 1100px;
  margin: 0 auto;
}
.contents-short{
  width: 100%;
  max-width: 960px;
  margin: 0 auto;
}

.logo-marquee{
  background: var(--white);
  position: relative;
  z-index: 2;
  .marquee-title{
    font-size: 18px;
    color: var(--blue);
    font-weight: 700;
    text-align: center;
    @media screen and (max-width: 767px){
      font-size: 12px;
    }
  }
  .marquee{
    width: 100%;
    overflow: hidden;
    white-space: nowrap;
    img{
      width: 1897px;
      vertical-align: bottom;
      animation: scrollX 75s linear infinite;
    }
  }
  .marquee-offer{
    text-align: right;
    color: var(--default);
    font-size: 12px;
    margin-right: 16px;
    @media screen and (max-width: 767px){
      text-align: center;
    }
  }
}
@keyframes scrollX {
  from {transform: translateX(0);}
  to {transform: translateX(-100%);}
}

.cta{
  text-align: center;
  position: relative;
  transform: translateY(-50%);
  z-index: 2;
  @media screen and (max-width: 767px){
    padding: 0 16px;
  }
  &.inner-cta{
    transform: none;
  }
  .contents{
    box-shadow: 0px 0px 10px 0px rgba(0, 60, 255, .40);
    border-radius: 99px;
    padding: 40px 24px;
    background: var(--white);
    @media screen and (max-width: 767px){
      border-radius: 64px;
    }
  }
  .cta-title{
    font-size: 40px;
    color: var(--pink);
    font-weight: 700;
    @media screen and (max-width: 767px){
      font-size: 24px;
    }
    img{
      vertical-align: bottom;
      padding-right: 4px;
      @media screen and (max-width: 767px){
        max-width: 266px;
      }
    }
  }
  .cta-title-small{
    font-weight: 700;
    background: linear-gradient(90deg, #163CE0 0%, #163CE0 30%, #EB14D2 70%);
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 24px;
    @media screen and (max-width: 767px) {
      font-size: 18px;
    }
  }
}



.fv{
  position: relative;
  padding: 122px 0 0;
  border-bottom: 16px solid var(--bgblue);
  @media screen and (max-width: 767px){
    padding: 86px 0 16px;
  }
  &::before,
  &::after{
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/lp-llmoa/fv-bg01.png) no-repeat 0 0;
    background-size: 550px;
    @media screen and (max-width: 767px) {
      background-size: contain;
    }
  }
  &::after{
    background: url(/images/lp-llmoa/fv-bg02.png) no-repeat 100% 100%;
    background-size: 820px;
    @media screen and (max-width: 767px) {
      background-size: 200%;
    }
  }
  .contents{
    position: relative;
    z-index: 2;
    display: flex;
    justify-content: space-between;
    align-items: center;
    @media screen and (max-width: 767px){
      display: block;
      padding: 0 16px;
    }
  }
  .logo-marquee{
    margin-top: 16px;
    padding-top: 8px;
  }
  @media screen and (max-width: 767px){
    figure{
      width: 100%;
      margin-top: 16px;
      img{width: 100%;}
    }
  }
}
.fv-subtitle{
  width: 100%;
  max-width: 257px;
  margin-left: -12px;
}
.fv-title{
  font-size: 48px;
  letter-spacing: 2.4px;
  @media screen and (max-width: 767px){
    font-size: 36px;
  }
}
.fv-read{
  font-size: 18px;
  margin-top: 16px;
  letter-spacing: .9px;
  font-weight: 400;
  @media screen and (max-width: 767px){
    font-size: 14px;
  }
}
.fv-right{
  max-width: 536px;
  img{width: 100%;}
}

.intro{
  text-align: center;
  padding: 56px 0 80px;
  @media screen and (max-width: 767px){
    padding: 56px 16px 60px;
  }
  ul{
    margin-top: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 24px;
    @media screen and (max-width: 767px){
      display: block;
    }
  }
  li{
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 1px;
    background: var(--bg-gray);
    padding: 24px 16px;
    border-radius: 20px;
    font-feature-settings: 'palt' on;
    @media screen and (max-width: 767px){
      font-size: 18px;
      padding: 15px 16px 16px;
      margin-bottom: 12px;
    }
  }
  figure{
    margin: 32px 0 24px;
  }
}
.intro-read{
  font-size: 18px;
  letter-spacing: .9px;
  span{
    font-weight: 700;
  }
  @media screen and (max-width: 767px){
    text-align: left;
  }
}

.problem{
  background: var(--bgblue);
  padding-top: 80px;
  position: relative;
  text-align: center;
  @media screen and (max-width: 767px){
    padding: 64px 16px 0;
  }
  &::before,
  &::after{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/lp-llmoa/problem-bg01.png) no-repeat 50% 0;
  }
  &::after{
    background: url(/images/lp-llmoa/problem-bg02.png) no-repeat 50% 100%;
    @media screen and (max-width: 767px){
background-position: 50% 96%;
    }
  }
  .contents-short{
    position: relative;
    z-index: 2;
  }
  .title-small{
    margin: 40px 0;
  }
}
@media screen and (max-width: 767px){
  .problem-subtitle{
    img{width: 100%;}
  }
}
.problem-read{
  color: var(--white);
  margin: 40px 0 ;
  font-size: 18px;
  letter-spacing: .9px;
  @media screen and (max-width: 767px){
    margin-top: 24px;
    text-align: left;
  }
}
.problem-box{
  h3{
    background: #536098;
    color: var(--white);
    border-radius: 20px 20px 0 0;
    padding: 8px 0;
    font-size: 20px;
    @media screen and (max-width: 767px) {
      font-size: 18px;
    }
    em{
      font-style: normal;
      @media screen and (max-width: 767px){
        display: none;
      }
    }
  }
  ul{
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 24px 0;
    gap: 32px;
    background: var(--white);
    border-radius: 0 0 20px 20px;
    @media screen and (max-width: 767px){
      display: block;
      padding: 16px 24px 0;
    }
    p{
      font-weight: 700;
      font-size: 18px;
    }
  }
  li{
    position: relative;
    @media screen and (max-width: 767px){
      display: flex;
      flex-direction: column-reverse;
      padding-bottom: 24px;
      margin-bottom: 12px;
    }
    &::after{
      content: "";
      display: block;
      background: var(--blue);
      width: 14px;
      height: 20px;
      clip-path: polygon(0 0, 100% 50%, 0 100%);
      position: absolute;
      bottom: 3px;
      right: -26px;
      @media screen and (max-width: 767px){
        width: 20px;
        height: 14px;
        clip-path: polygon(0 0, 100% 0, 50% 100%);
        right: 50%;
        bottom: 0;
        transform: translateX(50%);
      }
    }
    &:last-child{
      &::after{
        display: none;
      }
    }
  }
  &.box-col2{
    &::before{
      content: "";
      display: block;
      background: url(/images/lp-llmoa/arrow-up.png) no-repeat 50% 0;
      width: 100%;
      height: 56px;
      margin: 16px 0;
    }
    h3{
      background: linear-gradient(90deg, #849BFF 0%, #EB14D2 100%);
    }
  }
}
.problem-bottom{
  position: relative;
  z-index: 2;
  padding-bottom: 276px;
  @media screen and (max-width: 767px){
    width: calc(100% + 32px);
    margin-left: -16px;
    padding-bottom: 60%;
  }
}

.info-llmo{
  position: relative;
  background: var(--bg-gray);
  margin-top: -310px;
  padding-top: 230px;
  padding-bottom: 120px;
  text-align: center;
  @media screen and (max-width: 767px){
    margin-top: -94%;
    padding: 60% 16px 80px;
  }
  &::before{
    content: "";
    display: block;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/lp-llmoa/info-llmo-bg.png) no-repeat 50% 100%;
  }
  .contents-short{
    position: relative;
    z-index: 2;
  }
  .title-info{
    font-size: 20px;
    margin-top: 40px;
    @media screen and (max-width: 767px){
      margin-top: 24px;
    }
  }
}
.info-llmo-read{
  font-size: 18px;
  margin-top: 16px;
  letter-spacing: .9px;
}
.llmo-info-box{
  background: var(--white);
  border-radius: 20px;
  margin-top: 40px;
  padding: 40px 24px;
  .box-read{
    font-size: 18px;
    letter-spacing: .9px;
    span{
      display: block;
      font-weight: 700;
      @media screen and (max-width: 767px){
        display: inline;
      }
    }
    @media screen and (max-width: 767px){
      text-align: left;
    }
  }
  .figure{
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 24px;
    margin: 24px 0;
    @media screen and (max-width: 767px){
      flex-direction: column;
    }
  }
  .box-bottom{
    margin-top: 40px;
    padding-top: 32px;
    border-top: 1px solid var(--blue);
  }
}
.llmo-info-lists{
  margin: 40px 0;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  flex-wrap: wrap;
  gap: 30px;
  @media screen and (max-width: 767px){
    gap: 32px 8px;
    margin: 32px 0 24px;
  }
  li{
    background: var(--bg-gray);
    border-radius: 12px;
    width: calc((100% - 84px) / 3);
    padding: 12px 12px 12px 32px;
    text-align: left;
    font-weight: 700;
    letter-spacing: .8px;
    position: relative;
    @media screen and (max-width: 767px){
      width: calc((100% - 8px) / 2);
      padding: 18px 12px 12px;
      font-size: 12px;
    }
    span{
      color: var(--blue);
    }
    &::before{
      content: "";
      display: block;
      width: 32px;
      aspect-ratio: 1 / 1;
      background: url(/images/lp-llmoa/icon-ai.svg) no-repeat 0 0;
      background-size: contain;
      position: absolute;
      top: 50%;
      left: 0;
      transform: translate(-50%, -50%);
      @media screen and (max-width: 767px){
        top: 0;
        left: 50%;
      }
    }
  }
}

.feature-title-box{
  text-align: center;
  background: linear-gradient(90deg, #163CE0 0%, #EB14D2 100%);
  padding: 80px 0 40px;
  @media screen and (max-width: 767px){
    padding: 40px 0;
  }
  h2{
    color: var(--white);
    font-size: 48px;
    @media screen and (max-width: 767px){
      font-size: 32px;
      img{
        max-width: 236px;
      }
    }
    img{
      vertical-align: bottom;
    }
  }
  .feature-read{
    color: var(--white);
    font-size: 18px;
    letter-spacing: .9px;
    margin-top: 40px;
    @media screen and (max-width: 767px){
      padding: 0 16px;
      margin-top: 24px;
      text-align: left;
    }
  }
}
.feature-content-main{
  padding: 80px 0;
  @media screen and (max-width: 767px){
    padding: 40px 0;
  }
}
.feature-content-box{
  box-shadow: 0px 0px 40px 0px rgba(0, 60, 255, .20);
}
.feature-content-box-left,
.feature-content-box-right{
  .feature-content{
    width: 100%;
    max-width: 960px;
    position: relative;
    left: calc((6.25vw / 2) + 50%);
    @media screen and (max-width: 767px) {
      left: calc((1.92vw / 2) + 50%);
      width: 90%;
    }
  }
}
.feature-content-box-left{
  border-radius: 0 999px 999px 0;
  margin-right: 6.25vw;
  @media screen and (max-width: 767px){
    border-radius: 0 80px 80px 0;
    margin-right: 1.92vw;
  }
  .feature-content{
    transform: translateX(-50%);
  }
}
.feature-content-box-right{
  margin-top: 80px;
  border-radius: 999px 0 0 999px;
  margin-left: 6.25vw;
  @media screen and (max-width: 767px) {
    margin-left: 1.92vw;
    border-radius: 80px 0 0 80px;
    .feature-lists ul{
      margin-top: 8px;
    }
  }
  .feature-content{
    transform: translateX(calc(-50% - 6.25vw));
    @media screen and (max-width: 767px) {
      transform: translateX(calc(-50% - 1.92vw));
    }
  }
}
.feature-content{
  text-align: center;
  padding: 80px 0;
  @media screen and (max-width: 767px){
    padding: 56px 0;
  }
  .feature-lists{
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 24px;
    margin-top: 40px;
    @media screen and (max-width: 767px){
      flex-direction: column;
      margin-top: 24px;
      gap: 32px;
    }
    > li{
      width: calc((100% - 48px) / 3);
      figure{
        max-height: 160px;
        img{max-height: 160px;}
      }
      @media screen and (max-width: 767px){
        width: 100%;
        figure{
          width: calc(100% - 48px);
          margin: 0 auto;
          max-height: none;
          img{max-height: none;}
        }
      }
      h4{
        background: linear-gradient(90deg, #163CE0 0%, #EB14D2 90%);
        background-clip: text;
        -webkit-text-fill-color: transparent;
        margin: 8px 0 16px;
        font-size: 20px;
        @media screen and (max-width: 767px){
          margin: 8px 0;
        }
      }
      ul{
        padding-left: 1.5em;
      }
      li{
        text-align: left;
        font-weight: 700;
        list-style: disc;
        color: var(--blue);
        span{
          color: var(--default);
        }
      }
    }
  }
}
.feature-content-bottom{
  background: var(--bgblue);
  text-align: center;
  padding: 80px 0 180px;
  h2{
    color: var(--white);
    font-size: 48px;
    @media screen and (max-width: 767px) {
      font-size: 32px;
      display: inline;
    }
    img{
      vertical-align: bottom;
      @media screen and (max-width: 767px) {
        max-width: 266px;
      }
    }
  }
  h3{
    color: var(--white);
    font-size: 40px;
    margin-top: 12px;
    letter-spacing: 2px;
    @media screen and (max-width: 767px) {
      display: inline;
      font-size: 32px;
    }
  }
  ul{
    margin-top: 32px;
    background: var(--white);
    border-radius: 20px;
    display: flex;
    justify-content: space-between;
    @media screen and (max-width: 767px) {
      flex-direction: column;
      padding: 0 16px;
      background: none;
    }
  }
  li{
    position: relative;
    filter: drop-shadow(0 0px 5px rgba(0, 60, 255, .40));
    margin-left: -32px;
    @media screen and (max-width: 767px) {
      margin-left: 0;
      margin-top: -32px;
    }
    .flow-inner{
      clip-path: polygon(0 0, 90% 0, 100% 50%, 90% 100%, 0 100%);
      padding: 32px 36px 32px 56px;
      background: var(--white);
      text-align: left;
      min-height: 270px;
      @media screen and (max-width: 767px) {
        padding: 52px 20px 40px;
        clip-path: polygon(0 0, 100% 0, 100% 90%, 50% 100%, 0 90%);
        min-height: auto;
      }
    }
    &:first-child{
      margin-left: 0;
      z-index: 4;
      @media screen and (max-width: 767px) {
        margin-top: 0;
        .flow-inner{
          padding-top: 32px;
        }
      }
      .flow-inner{
        padding-left: 32px;
        border-radius: 20px 0 0 20px;
        @media screen and (max-width: 767px) {
          border-radius: 20px 20px 0 0;
          padding-left: 20px;
          padding-top: 28px;
        }
      }
    }
    &:nth-child(2){
      z-index: 3;
    }
    &:nth-child(3){
      z-index: 2;
    }
    &:last-child{
      .flow-inner{
        clip-path: none;
        padding-right: 32px;
        border-radius: 0 20px 20px 0;
        .flow-title{
          background: linear-gradient(90deg, #163CE0 0%, #EB14D2 90%);
          background-clip: text;
          -webkit-text-fill-color: transparent;
          span{visibility: hidden;}
        }
        @media screen and (max-width: 767px) {
          border-radius: 0 0 20px 20px;
        }
      }
    }
  }
  .flow-title{
    font-size: 24px;
    color: var(--blue);
    font-weight: 700;
    margin-bottom: 12px;
    span{
      display: inline-block;
      font-size: 16px;
      color: var(--white);
      background: var(--blue);
      border-radius: 4px;
      padding: 3px 8px 4px;
      margin-bottom: 4px;
      line-height: 1;
      &.spi{
        display: none;
      }
    }
    @media screen and (max-width: 767px) {
      text-align: center;
      .pcb{
        display: none;
      }
      span.spi{
        display: inline-block;
        margin-left: 10px;
      }
    }
  }
}
.leave{
  text-align: center;
  margin-top: -20px;
  margin-bottom: 40px;
  @media screen and (max-width: 767px){
    margin-top: -80px;
  }
}

.casestudy{
  @media screen and (max-width:767px) {
    padding: 0 16px;
  }
  .contents-short{
    margin-top: 40px;
  }
  .title-small{
    text-align: center;
  }
}
.case{
  background: var(--white);
  border-radius: 20px;
  box-shadow: 0px 0px 40px 0px rgba(0, 60, 255, .20);
  margin-top: 40px;
  padding: 40px 24px;
  h3{
    background: linear-gradient(90deg, #163CE0 0%, #EB14D2 90%);
    background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 24px;
    text-align: center;
    @media screen and (max-width: 767px) {
      font-size: 20px;
    }
  }
  .corp{
    display: flex;
    align-items: center;
    gap: 48px;
    margin: 32px 0;
    @media screen and (max-width: 767px) {
      flex-direction: column;
      gap: 24px;
    }
    figure{
      width: 40.416%;
      @media screen and (max-width: 767px) {
        width: 100%;
      }
    }
  }
  .corp-text{
    width: calc(100% - 40.416% - 48px);
    @media screen and (max-width: 767px) {
      width: 100%;
    }
  }
  .corp-tag{
    background: var(--blue);
    color: var(--white);
    display: inline-block;
    padding: 3px 8px 4px;
    border-radius: 4px;
  }
  .corp-name{
    text-align: left;
    margin: 8px 0;
  }
  .corp-read{
    font-size: 18px;
    letter-spacing: .9px;
  }
  .corp-result{
    display: flex;
    justify-content: center;
    gap: 24px;
    @media screen and (max-width: 767px) {
      flex-direction: column;
      gap: 16px;
      &:last-child{
        margin-top: 24px;
      }
    }
  }
}

.design-cta{
  margin: 80px 0;
  @media screen and (max-width: 767px) {
    margin: 40px 0;
    padding: 0 16px;
    h3{
      width: 100%;
      img{width: 100%;}
    }
  }
  .contents-short{
    background:  linear-gradient(97deg, #002FD8 -8.06%, #0094CE 48.37%, #00A59A 103.72%);
    border-radius: 20px;
    padding: 24px 24px 24px 40px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 32px;
    @media screen and (max-width: 767px) {
      padding: 24px;
      display: block;
    }  
  }
  .cta-read{
    margin-top: 8px;
    color: var(--white);
  }
  .title-small{
    font-size: 30px;
  }
}

.faq{
  text-align: center;
  @media screen and (max-width: 767px) {
    padding: 0 16px;
  }
}
.faq-content{
  margin-top: 40px;
  @media screen and (max-width: 767px) {
    margin-top: 24px;
  }
}
.faq-box{
  text-align: left;
  margin-top: 24px;
  padding: 24px;
  border-radius: 20px;
  background: var(--white);
  box-shadow: 0px 0px 10px 0px rgba(0, 60, 255, .20);
  &:first-child{
    margin-top: 0;
  }
  dt{
    font-size: 24px;
    color: var(--blue);
    font-weight: bold;
    display: flex;
    position: relative;
    @media screen and (max-width: 767px) {
      font-size: 20px;
    }
    &::before{
      content: "";
      display: block;
      width: 40px;
      aspect-ratio: 1 / 1;
      background: url(/images/lp-llmoa/icon-q.png) no-repeat 0 0;
      margin-right: 10px;
      @media screen and (max-width: 767px) {
        width: 32px;
        background-size: contain;
      }
    }
    &::after{
      content: "";
      display: block;
      width: 40px;
      aspect-ratio: 1 / 1;
      background: url(/images/lp-llmoa/icon-arrow.png) no-repeat 0 0;
      margin-left: 8px;
      filter: drop-shadow(0 0px 5px rgba(0, 60, 255, .40));
      @media screen and (max-width: 767px) {
        width: 32px;
        background-size: contain;
      }
    }
    span{
      width: calc(100% - 100px);
      @media screen and (max-width: 767px) {
        width: calc(100% - 42px);
      }
    }
    &.faq-active::after{
      background: url(/images/lp-llmoa/icon-arrow-u.png) no-repeat 0 0;
      @media screen and (max-width: 767px) {
        background-size: contain;
      }
    }
  }
  dd{
    font-size: 18px;
    display: flex;
    height: 0;
    transition: all .5s;
    overflow: hidden;
    &::before{
      content: "";
      display: block;
      width: 40px;
      background: url(/images/lp-llmoa/icon-a.png) no-repeat 0 0;
      margin-right: 10px;
      @media screen and (max-width: 767px) {
        width: 32px;
        background-size: contain;
      }
    }
    span{
      width: calc(100% - 50px);
    }
    &.faq-active{
      height: auto;
      height: calc-size(auto, size);
      border-top: 1px solid var(--bg-gray);
      padding-top: 16px;
      margin-top: 20px;
    }
  }
}

.action{
  background: linear-gradient(90deg, #163CE0 0%, #EB14D2 100%);
  text-align: center;
  padding: 80px 0;
  margin-top: 80px;
  position: relative;
  &::before,
  &::after{
    content: '';
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background: url(/images/lp-llmoa/action-bg01.png) no-repeat 0 0;
    @media screen and (max-width: 767px) {
      background-size: contain;
    }
  }
  &::after{
    background: url(/images/lp-llmoa/action-bg02.png) no-repeat 100% 100%;
    @media screen and (max-width: 767px) {
      background-size: 200%;
    }
  }
  .action-read{
    margin: 40px 0;
    letter-spacing: .9px;
    color: var(--white);
    @media screen and (max-width: 767px) {
      margin: 24px 0 32px;
      padding: 0 16px;
      text-align: left;
    }
  }
}
