* {
    margin: 0;
    padding: 0;
    font-family: "hiragino Sans" "note sans jp", sans-serif;
}

html, body {
  overflow-x: hidden;
  text-size-adjust:100%;
  -webkit-text-size-adjust:100%;
  -webkit-appearance: none;
  font-family: "note sans jp", sans-serif;
}

input,select{
  -webkit-appearance: none;
  border: none;
}
  
/* ---- hero ----*/
  .hero {
    position: relative;
    padding-bottom: 8vw;
  }

  .header {
    position: relative;
    display: flex;
    max-width: 100%;
    margin: 0 auto;
    align-items: center;
  }

  .header__logo {
      margin: auto auto;
  }

  .header__logo__pc, .header__logp__pc__text {
      display: none;
  }

  .header__logo__mobile {
      display: block;
      width: 28.272vw;
      height: auto;
      position: relative;
      top: 2vw;
  }

  .header_navigation{
    position: relative;
    margin: 0 0 0 auto;
  }

  .header_navigation_list{
    list-style: none;
    display: flex;
    gap: 0.5vw;
  }
  
  .header_navigation_list_link {
    display: flex;
    align-items: center;
    text-decoration: none;
  }

  .header_navigation_list_tel {
    padding: 3.5vw 3.30vw;
    background: linear-gradient(to right,#FF83CB,#178BFF);
    color: #fff;
    text-decoration: none;
  }

  .header_navigation_list_inquiries {
    padding: 3.5vw 3.5vw;
    background: linear-gradient(to right,#FF83CB,#178BFF);
    color: #fff;
    text-decoration: none;
  }

  .nav_tel-icon {
    width:5vw;
    height: auto;
  }

  .hoverRoll_text{
    text-decoration: none;
  }

  .hoverRoll_text span {
    font-size: 2.6vw;
    font-weight: 600;
    padding-right: 1.86vw;
    letter-spacing: 0.15vw;
    color: #fff;
    text-decoration: none;
  }
  
  .nav_arrow {
    width: 1vw;
    height: auto;
  }

  .hero__inner {
    margin: 15vw auto 0 auto;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  
  .hero__text {
    text-align: center;
    margin: 0 auto
  }
  
  .hero__platforms {
    display: flex;
    font-size: 4.26vw;
    font-weight: 600;
    letter-spacing: 0.3vw;
    flex-direction: row;
    flex-wrap: nowrap;
    width: auto;
    gap: 2.5vw;
    justify-content: center;
  }

  .hero__title {
    line-height: 1.5;
    letter-spacing: 0.5vw;
    margin: 2.5vw auto 0 auto;
    font-size: 5.5vw;
    line-height: 14vw;
    background: linear-gradient(190deg,#AF2AAE 0%,#F2355B 50%, #FF9E2B 100%);
    font-weight: bold;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }
  
  
  .highlight {
    background: linear-gradient(190deg,#AF2AAE 0%,#F2355B 50%, #FF9E2B 100%);
    font-weight: bold;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    font-size: 8vw;
    letter-spacing: 0.9vw;
  }
  
  .highlight__underline1, .highlight__underline2 {
      height: 0.75vw;
      background-color: #000;
      margin-top: -2vw;
      margin-left: auto;
      margin-right: auto;
      position: relative;
      left: -3vw;
  }

  .highlight__underline1 {
      width: 44.48vw;
      background:  linear-gradient(90deg,#AF2AAE 0%,#F2355B  50%, #AF2AAE 100%);
  }

  .highlight__underline2 {
      width: 78vw;
      background:  linear-gradient(90deg,#AF2AAE 0%,#F2355B  50%, #AF2AAE 100%);
  }

  .hero__lead {
    font-size: 5.33vw;
    color: #3B3B3B;
    font-weight: 700;
    letter-spacing: 1.1vw;
    margin: 3vw auto 0 auto; 
  }

  .hero__logo {
    position: relative;
    width: 54.04vw;
    margin-top: 10vw;
    margin-bottom: 10vw;
  }
  
  .hero__visual {
    text-align: center;
    position: relative;
  }

  .hero__visual__inner {
    display: flex;
  }
  
  

  .hero__phone-frame {
    width: 90.52vw;
    display: block;
    height: 145vw;
    z-index: 3;
  }

  .hero__phone {
    width: 75vw;
    display: block;
    border-radius: 10vw;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
    margin-top: -1vw;
  }

  .hero__toTop {
    position: fixed;
    display: block;
    bottom:8vw;
    left: 3vw;
    z-index: 10;
    width: clamp(45px,12vw,80px);
  }

  .hero__toTop__icon {
    display: block;
    width: 100%;
  }

  .hero__toTop__icon img {
    width: 12.34vw;
  }

  .hero__badge {
    position: fixed;
    bottom: 10vw;
    right: 1vw;
    width: clamp(80px, 23.45vw, 160px); /* 35.17vw → 23.45vw */
    height: clamp(87px, 24.03vw, 173px); /* 36.048vw → 24.03vw */
    display: block;
    z-index: 10;
    filter: drop-shadow(0.5vw 0.5vw 1vw rgba(0, 0, 0, 0.4));
    will-change: filter;
  }
  
  .hero__badge__inner {
    position: relative;
    width: 100%;
    height: 100%;
  }
  
  .badge__img {
    position: relative;
    width: 100%;
    height: 100%;
  }
  
  .badge-base {
    width: 100%;
    height: auto;
    display: block;
  }
  
  .badge-icon {
    position: absolute;
    top: 12%; /* 12% × 2/3 */
    left: 47%;
    transform: translateX(-53%);
    width: 20%; /* 20% × 2/3 */
    height: 20%;
  }
  
  .badge__text-1 {
    color: #fff;
    background-color: #000;
    border-radius: 9999px;
    font-size: clamp(7px, 1.95vw, 13px); /* 2.93vw × 2/3 */
    font-weight: 600;
    position: absolute;
    top: 35%;  /* 35% × 2/3 */
    left: 31%; /* 31% × 2/3 */
    padding: 0.066vw 1vw;
  }
  
  .badge__text-2 {
    position: absolute;
    top: 31%; /* 31% × 2/3 */
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    text-align: center;
    font-family: "Noto Sans JP", sans-serif;
    color: #fff;
    font-weight: bold;
    font-size: 2.13vw; /* 3.2vw × 2/3 */
    line-height: 1.2;
  }
  
  .badge_cost1 {
    font-size: clamp(21px, 8vw, 53px); /* 12vw × 2/3 */
    font-weight: 600;
    display: inline-block;
    line-height: 1;
    margin-left: -1.33vw; /* -2vw × 2/3 */
    margin-right: 1.33vw; /* 2vw × 2/3 */
    transform: scalex(1.2);
  }
  
  .badge_cost2 {
    font-size: clamp(10px, 3.37vw, 23px); /* 5.06vw × 2/3 */
    margin-left: -2vw; /* -3vw × 2/3 */
  }
  
  .badge_cost3 {
    font-size: clamp(9px, 2.13vw, 16px); /* 3.2vw × 2/3 */
    margin-left: -0.33vw; /* -0.5vw × 2/3 */
  }
  


  .header__bg__mobile {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    width: 100%;
    display: block;
  }

  .header__bg__pc {
    display: none;
  }


/* ---- worry ---- */ 
.worry {
    color: white;
    text-align: center;
    padding: 3.125vw 0 10vw 0;
    position: relative;
  }
  
  .worry__inner {
    width: 80vw;
    margin: 8.33vw auto 5.5vw auto;
  }
  
  .worry__title {
    font-size: 6.66vw;
    margin-bottom: 9vw;
    letter-spacing: 0.5vw;
    font-weight: 700;
    line-height: 10.5vw;
  }
  
  .worry__list {
    list-style: none;
    padding: 0;
    margin: 0;
  }
  
  .worry__item {
    width: 80vw;
    max-width: 100%;
    margin-left: auto;
    margin-right: auto;
  }

  .worry__item__inner1 {
    margin-left: -1vw;
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 12vw;
  }

  .worry__item__inner2 {
    margin-right: -1vw;
    margin-bottom: 11vw;
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .worry__item__inner3 {
    display: flex;
    flex-direction: column;
    align-items: center;
    margin-bottom: 17vw;
  }
  
  .worry_1_img {
    margin: 0 auto 4vw;
    display: block;
    width: 79.74vw;
    height: auto;
    margin-left: -2vw;
  }

  .worry_2_img {
    margin: 0 auto -8vw;
    display: block;
    width: 88.696vw;
    height: auto;
  }

  .worry_3_img {
    margin: 0 auto 9vw;
    display: block;
    width: 80.3vw;
    height: auto;
  }
  
  .worry__item__textbox {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 0.88vw;
    margin-left: -1vw;
  }

  .worry__check {
    width: 6.44vw;
  }

  .worry__text {
    font-size: 6.13vw;
    font-weight: 600;
    text-align: left;
    display: inline-block;
  }
  
  .check {
    margin-right: 1.6vw;
    color: #fff;
    font-weight: bold;
  }
  
  .worry__btn {
    margin-top: 10.5vw;
    background:linear-gradient(180deg,#FDFFCE,#FFEB00);
    color: #333;
    padding: 4vw 8.5vw;
    border-radius: 9999px;
    box-shadow: 2.4vw 2.13vw 1.86vw 0px rgba(0,0,0,0.2);
    transition: background-color 0.3s;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    display: block;
    text-decoration: unset;
  }

  .worry__btn__inner {
    display: flex;
    align-items: center;
    text-decoration: none;
    justify-content: center;
    gap: 1.5vw;
  }
  
  .worry__btn__inner__text {
    text-decoration: none;
    font-weight: bold;
    display: inline-block;
    font-size: 5.33vw;
    letter-spacing: 0.1vw;
  }

  .worry__btn__inner__arrow {
    display: none;
  }
  
  .worry__btn:hover {
    background-color: #ffe600;
  }
  

  .worry__bg {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    width: 100%;
    display: block;
  }

/* ---- heature ---- */
  .feature {
    text-align: center;
    padding: 4.16vw 0 8vw 0;
    position: relative;
  }
  
  .feature__inner {
    width: 66.66vw;
    margin: 3.38vw auto 0 auto;
    display: flex;
    flex-direction: column;
  }
  
  .feature__title {
    font-size: 8.8vw;
    font-weight: bold;
    background-color: transparent;
    border: 0.8vw solid #a500e2;
    padding: 0.0vw 11.5vw;
    border-radius: 9999px;
    justify-content: center;
    display: block;
    margin: 6vw auto 5vw auto;
  }
  
  .feature__title__text {
    background: linear-gradient(180deg,#22A8FC,#E25DDC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }
  
  .feature__slider__custom {
    overflow: hidden;
    padding: 1% 0;
    width: 100vw;
    position: relative;
    margin-left: -16vw;
  }

  input[name="feature"] {
    display: none;
  }

  .feature__slider__custom #feature1:checked ~ .feature__slider {
    transform: translateX(0%);
  }
  .feature__slider__custom #feature2:checked ~ .feature__slider {
    transform: translateX(-100vw);
  }
  .feature__slider__custom #feature3:checked ~ .feature__slider {
    transform: translateX(-200vw);
  }


  .feature__slider {
    display: flex;
    flex-shrink: 0;
    margin-bottom: 7vw;
    margin-top: 5vw;
    justify-content: space-between;
    width: 300vw;
    transition:  transform 0.4s ease;
  }

  .feature__item {
    flex:1;
    padding: 5.33vw;
    border-radius: 3.2vw;
    position: relative;
    width: 80vw;
    box-sizing: border-box;
    box-shadow: 0px 1.33vw 1.6vw 0px #bbbbbb;
    margin-left: 10vw;
    margin-right: 10vw;
    background: #fff;
  }

  .feature__number {
    position: relative;
    display: flex;
    align-items: center;
    left: -6vw;
    top: -11vw;
  }

  .feature__number__image {
    width: 19.43vw;
  }

  .feature__number__text{
    font-size: 7.2vw;
    font-weight: 800;
    letter-spacing: 1.2vw;
    position: absolute;
    margin-top: -2vw;
    margin-left: 4vw;
  }

  @supports (-webkit-touch-callout: none) {    
    .feature__number__text{
      margin-top: 0vw;
      letter-spacing: 0.5vw;
    }
  }
  
  .feature__image{
    display: flex;
    align-items: flex-end;
    justify-content: center;
    height: 37.46vw;
    margin-top: -20vw;
  }

  .feature__image1 {
    width: 19.33vw;
    height: auto;
  }

  .feature__image2 {
    width: 44.552vw;
    height: auto;
  }
  

  .feature__image3 {
    width: 50.28vw;
    height: auto;
  }
    
  .feature__border {
    position: relative;
    height: 1.67vw;
    background: linear-gradient(to right, #22A8FC, #d65ad6);
    margin: 8vw 0 5vw 0;
  }

  .feature__item-title {
    font-size: 6.6vw;
    font-weight: 800;
    width: 62.11vw;
    text-align: left;
    margin: 0 auto 2.5vw auto;
    line-height: 8.75vw;
    min-height: 23.97vw;
    background-clip: text;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
  }

  .feature__item-title--1 {
    background-image: linear-gradient(180deg,#22A8FC 0%,#E25DDC 100%);
  }

  .feature__item-title--2 {
    background-image: linear-gradient(180deg,#22A8FC 0%,#E25DDC 60%);
  }

  .feature__item-title--3 {
    background-image: linear-gradient(180deg,#22A8FC 0%,#E25DDC 60%);
  }
  
  .feature__text {
    font-size: 5.33vw;
    font-weight: 400;
    text-align: left;
    line-height: 1.55;
    width: 70.42vw;
    text-align: left;
    margin: 0  auto;
    letter-spacing: 0.4vw;
  }

  .feature__slide_arrow {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    display: flex;
    justify-content: space-between;
    flex-direction: row;
    width: 95vw;
    left: 2.5vw;
  }


  
  .feature__slide_arrow_left {
    transform: scalex(-1);
    opacity: 1;
    transition: opacity 0.3s ease;
  }

  .feature__slide_arrow_right {
    justify-items: right;
    opacity: 1;
    transition: opacity 0.3s ease;
  }

  .feature__slider__pagination {
    display: flex;
    justify-content: center;
    gap: 4vw;
    width: 100%;
  }
  
  .feature__slider__pagination label {
    width: 2.66vw;
    height: 2.66vw;
    border-radius: 50%;
    border: 0.53vw solid #666;
    background-color: transparent;
    cursor: pointer;
    transition: background-color 0.3s;
  }

  .feature__slider__custom #feature1:checked ~ .feature__slider__pagination label[for="feature1"],
  .feature__slider__custom #feature2:checked ~ .feature__slider__pagination label[for="feature2"],
  .feature__slider__custom #feature3:checked ~ .feature__slider__pagination label[for="feature3"] {
    background-color: #444;
  }

  
  .feature__cta {
    margin-top: 5.33vw;
    display: none;
  }
  
  .feature__button {
    background: linear-gradient(to bottom, #22A8FC, #E25DDC);
    color: white;
    padding: 2vw 4vw;
    border-radius: 1vw;
    text-decoration: none;
    font-size: 2.18vw;
    font-weight: 600;
    display: inline-block;
    box-shadow: 0 1.06vw 2.13vw rgba(0,0,0,0.15);
    transition: opacity 0.3s;
  }
  
  .feature__button:hover {
    opacity: 0.8;
  }

  .feature__bg__mobile {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    width: 100%;
    display: block;
  }

  .feature__bg__pc {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    width: 100%;
    display: none;
  }
  
  /* ---- example ----*/
  .example {
    padding: 12.8vw 0;
    text-align: center;
    color: #333;
    position: relative;
  }
  
  .example__title {
    font-size: 6vw;
    color: #9b4de0;
    border: 0.8vw solid #9b4de0;
    display: inline-block;
    padding: 0.25vw 7vw;
    border-radius: 10.66vw;
    margin-bottom: 10.66vw;
    letter-spacing: 1vw;
  }
  
  .example__title__text {
    background: linear-gradient(180deg,#22A8FC,#E25DDC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }


  
  .example__lead {
    max-width: 80vw;
    width: 78.5vw;
    margin: 0 auto 16vw;
    font-size: 5.33vw;
    line-height: 10.3vw;
    text-align: left;
    letter-spacing: 0.3vw;
  }

  
  .highlight {
    font-weight: bold;
  }
  
  .example__stats {
    display: flex;
    justify-content: center;
    gap: 10vw;
    margin-bottom: 24.8vw;
    flex-wrap: wrap;
  }
  
  .example__stat {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex-wrap: nowrap;
    align-items: center;
  }
  
  .example__label {
    font-size: 4.26vw;
    color: #ffffff;
    font-weight: 700;
    margin-bottom: -7vw;
    z-index: 5;
    letter-spacing: 0.2vw;
    margin-left: 4.5vw;
  }
  
  .example__caption {
    font-size: 3.2vw;
    color: #ffffff;
    margin-top: -6.66vw;
    z-index: 5;
    font-weight: 700;
    min-width: 36vw;
    text-align: left;
    margin-left: -14vw;
  }

  .example__stat__img img {
    width: 71.33vw;
  }
  
  .example__subheading {
    font-size: 6.66vw;
    font-weight: 500;
    margin-bottom: 5.33vw;
    color: #1A1A1A;
    background: #F5BBE5;
    padding: 1vw 0;
  }
  
  .example__categories {
    display: grid;
    grid-template-columns: repeat(2, 48.30vw);
    grid-template-rows: repeat(3,auto);
    gap: 2vw 3vw;
    max-width: 213vw;
    margin: 0 auto;
  }
  
  .example__category img {
    width: 48.30vw;
    border-radius: 1vw;
    margin-bottom: 1vw;
  }
  
  .example__category p {
    font-size: 4.2vw;
    font-weight: 600;
    color: #6B2884;
  }
  
  .example__category__mobile {
    display: block;
  }

  .example__category__pc {
    display: none;
  }

  .example__bg {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    /*width: 100%;*/
    display: block;
  }


  /* ---- cost ---- */
  .cost {
    padding: 15vw 0 17vw 0;
    text-align: center;
    position: relative;
  }
  
  .cost__title {
    font-size: 6vw;
    margin-bottom: 16vw;
    color: #A500E2;
    border: 0.8vw solid #A500E2;
    display: inline-block;
    padding: 0vw 6.66vw;
    border-radius: 10.66vw;
  }

  .cost__title__text {
    background: linear-gradient(180deg,#22A8FC,#E25DDC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }
  
  .cost__plans {
    display: flex;
    flex-wrap: wrap;
    gap: 8vw;
    justify-content: center;
    flex-direction: column;
    align-items: center;
  }
  
  .cost__plan {
    background-color: #fff;
    border-radius: 8vw;
    width: 80vw;
    flex: 1 1 30%;
    box-shadow: 0 1.06vw 2.66vw rgba(0, 0, 0, 0.1);
    position: relative;
  }
  
  .cost__plan.is-highlighted {
    border: 0.8vw solid #e81d63;
  }
  
  .cost__label {
    position: absolute;
    top: -5.33vw;
    left: 50%;
    transform: translateX(-50%);
    background: linear-gradient(180deg,#FF74A3,#FF0031);
    color: white;
    font-size: 4.8vw;
    font-weight: 600;
    padding: 1.6vw 2.6vw;
    border-radius: 5.33vw 5.33vw 0vw 0vw;
    line-height: 1.4;
    width: 95%;
  }
  
  .cost__image__light {
    width: 37.55vw;
    margin-top: 13vw;
    margin-bottom: 1vw;
  }

  .cost__image__standard {
    width: 55.65vw;
    margin-top: 8vw;
    margin-bottom: 6vw;
  }

  .cost__image__premium {
    width: 45.41vw;
    margin-top: 8vw;
    margin-bottom: 4vw;
  }
  
  .cost__name__light, .cost__name__standard,
  .cost__name__premium {
    font-size: 6.93vw;
    font-weight: 700;
    margin-bottom: -2vw;
  }

  .cost__name__light {
    color: #FF0058;
  }

  .cost__name__standard {
    color: #0070E0;
  }

  .cost__name__premium {
    color: #FF6C00;
  }
  
  .cost__price {
    font-size: 5.33vw;
    font-weight: 600;
    color: #1A1A1A;
  }
  
  .cost__price__number {
    font-size: 11.46vw;
    font-weight: 700;
    display: inline-block;
    transform: scaleX(1.2);
    margin-left: 1.5vw;
    margin-right: 1.5vw;
  }

  .cost__post {
    font-size: 3.5vw;
    font-weight: 500;
    color: #1A1A1A;
    margin-bottom: 2vw;
    margin-top: -1.5vw;
  }
  
  .cost__purpose__light,
  .cost__purpose__standard,.cost__purpose__standard2,
  .cost__purpose__premium, .cost__purpose__premium2 {
    font-size: 4.8vw;
    font-weight: bold;
    margin-bottom: 5vw;
    color: #ffffff;
    border-radius: 9999px;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
    letter-spacing: 2vw;
  }

  .cost__purpose__light {
  background: linear-gradient(180deg,#FF74A3,#FF0031);
  }

  .cost__purpose__standard, .cost__purpose__standard2 {
    background: linear-gradient(180deg,#00B1FF,#004EFF);
  }

  .cost__purpose__premium, .cost__purpose__premium2 {
    background: linear-gradient(180deg,#F8DB00,#FF6200);
  }

  .cost__purpose__light,.cost__purpose__standard,
  .cost__purpose__premium {
    padding: 0vw 22vw;
    margin-bottom: 4vw;
  }

  .cost__purpose__standard2,.cost__purpose__premium2 {
    padding: 0vw 15vw;
    margin-bottom: 4vw;
  }

  .cost__features__light, .cost__features__standard,
  .cost__features__premium {
    display: block;
    text-align: center;
  }

  .cost__features__text {
    text-align: left;
    font-size: 4.8vw;
    padding-left: 1em;
    width: 65vw;
    font-weight: 400;
    margin-left: auto;
    margin-right: auto;
    list-style: none;
    display: inline-block;
  }

  .cost__features__text li {
    position: relative;
    margin-bottom: 3vw;
    padding-left: 1em;
    line-height: 6vw;
  }

  .cost__features__text li::before{
    content: '';
    position: absolute;
    left: 0;
    top: 3vw;
    width: 0.9vw;
    height: 0.9vw;
    background-color: #1A1A1A;
    border-radius: 50%;
  }

  .cost__category {
    text-align: center;
    width: 65vw;
    margin-left: auto;
    margin-right: auto;
    font-size: 4.8vw;
    display: block;
  }

  .cost__category__text {
    text-align: left;
    display: inline-block;
  }

  .cost__category__text ul{
    margin-bottom: -1vw;
  }

  .cost__category__text__ad_light, .cost__category__text__ad_standard,
  .cost__category__text__ad_premium {
    font-size: 4.8vw;
    margin-top: 4vw;
  }
  
  .cost__note {
    font-size: 4.26vw;
    font-weight: 400;
    color: #1A1A1A;
    line-height: 1.5;
    letter-spacing: 0.5vw;
    background:#F0F0F0 ;
    padding: 1vw 6vw;
    width: fit-content;
    position: relative;
    margin: 5vw auto;
  }
  
  .cost__disclaimer__pc, .cost__disclaimer__mobile{
    font-size: 4vw;
    font-weight: 400;
    margin-top: -7vw;
    color: #0F0F0F;
    width: 80vw;
    text-align: end;
    letter-spacing: 0.4vw;
  }

  .cost__bg {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    /*width: 100%;*/
    display: block;
    left: 50%;
    transform: translateX(-50%);
  }
  
/* ---- work detail ----*/
.work-detail {
    background-color: #F8F8F8;
    padding: 11.46vw 0 9vw 0;
    text-align: center;
  }
  
  .work-detail__title {
    margin-bottom: 11.73vw;
    border: 0.53vw solid #9b4de0;
    padding: 0.25vw 6.66vw;
    border-radius: 9999px;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
  }
  
  .work-detail__title-main {
    font-size: 8.5vw;
    display: inline-block;
    letter-spacing: 2vw;
    background: linear-gradient(180deg,#22A8FC,#E25DDC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }
  
  .work-detail__title-sub {
    display: block;
    font-size: 4.5vw;
    color: #000;
    margin-top: -1.33vw;
    letter-spacing: 0.3vw;
  }


  .work-detail__slider__custom {
    position: relative;
    width: 100vw;
    overflow: hidden;
    padding: 2vw 0;
  }


  input[name="work-detail"] {
    display: none;
  }

  .work-detail__slider__custom #work-detail1:checked ~ .work-detail__slider {
    transform: translateX(0vw);
  }
  .work-detail__slider__custom #work-detail2:checked ~ .work-detail__slider {
    transform: translateX(-100vw);
  }
  .work-detail__slider__custom #work-detail3:checked ~ .work-detail__slider {
    transform: translateX(-200vw);
  }
  .work-detail__slider__custom #work-detail4:checked ~ .work-detail__slider {
    transform: translateX(-300vw);
  }

  
  .work-detail__slider {
    display: flex;
    flex-shrink: 0;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: space-between;
    width: 400vw;
    transition:  transform 0.4s ease;
    position: relative;
  }
  
  .work-detail__item {
    flex: 1;
    text-align: center;
    position: relative;
    box-sizing: border-box;
    box-shadow: 0vw 0.5vw 1.6vw 0.7vw #bbbbbb;
    border-radius: 10vw;
    min-width: 80vw;
    margin-left: 10vw;
    margin-right: 10vw;
    background: #fff;
  }
  
  .work-detail__icon {
    text-align: center;
    margin-bottom: 2vw;
    margin-top: 5vw;
  }
  
  .work-detail__icon img {
    width: 48.168vw;
  }
  
  .work-detail__icon__ad__text {
    font-size: 4.26vw;
    font-weight: 800;
    color: #fff;
    position: absolute;
    margin-top: -9vw;
    margin-left: 46%;
  }

  @supports (-webkit-touch-callout: none) {
    .work-detail__icon__ad__text {
      margin-left: 45%;
    }
  }

  .work-detail__text {
    display: inline;
  }

  .work-detail__item__title {
    font-size: 9.86vw;
    font-weight: 700;
    color: #9b4de0;
    margin-bottom: 2.66vw;
  }
  
  .work-detail__text__detail {
    list-style: disc;
    font-size: 4.8vw;
    font-weight: 400;
    color: #444;
    line-height: 1.7;
    width: 70.42vw;;
    list-style: none;
    display: inline-block;
    text-align: left;
  }
  
  .work-detail__text__detail li {
    position: relative;
    margin-bottom: 3vw;
    padding-left: 1em;
    line-height: 6vw;
  }

  .work-detail__text__detail li::before{
    content: '';
    position: absolute;
    left: 0;
    top: 3vw;
    width: 0.9vw;
    height: 0.9vw;
    background-color: #1A1A1A;
    border-radius: 50%;
  }

  .work-detail__line {
    display: none;
  }

  .work-detail__slide_arrow {
    position: relative;
    top: -75vw;
    display: inline-flex;
    justify-content: space-between;
    width: 94vw;
  }

  .work-detail__slide_arrow_left {
    transform: scalex(-1);
    opacity: 1;
    transition: opacity 0.3s ease;
  }

  .work-detail__slide_arrow_right {
    justify-items: right;
    opacity: 1;
    transition: opacity 0.3s ease;
  }

  .work-detail__slider__pagination {
    display: flex;
    justify-content: center;
    gap: 4vw;
    width: 100%;
  }
  
  .work-detail__slider__pagination label {
    width: 2.66vw;
    height: 2.66vw;
    border-radius: 50%;
    border: 0.53vw solid #666;
    background-color: transparent;
    cursor: pointer;
    transition: background-color 0.3s;
  }

  .work-detail__slider__custom #work-detail1:checked ~ .work-detail__slider__pagination label[for="work-detail1"],
  .work-detail__slider__custom #work-detail2:checked ~ .work-detail__slider__pagination label[for="work-detail2"],
  .work-detail__slider__custom #work-detail3:checked ~ .work-detail__slider__pagination label[for="work-detail3"],
  .work-detail__slider__custom #work-detail4:checked ~ .work-detail__slider__pagination label[for="work-detail4"] {
    background-color: #444;
  }


  .work-detail__note {
    margin-top: 16vw;
    color: #E23ADB;
    background-color: #fff;
    border-radius: 8vw;
    border: 0.8vw solid;
    width: 80vw;
    margin-left: auto;
    margin-right: auto;
    display: block;
    text-align: center;
  }
  
  .work-detail__note-label {
    background-color: #E23ADB;
    color: white;
    font-size: 5.33vw;
    font-weight: 600;
    border-radius: 7vw 7vw 0 0 ;
    display: inline-block;
    width: 100%;
    padding-bottom: 2vw;
    margin-bottom: 4.5vw;
  }
  
  .work-detail__note-text {
    color: #000;
    font-size: 4.53vw;
    font-weight: 400;
    list-style: none;
    width: 70vw;
    display: inline-block;
    text-align: left;
  }

  .work-detail__note-text li {
    position: relative;
    margin-bottom: 5vw;
    padding-left: 2vw;
    line-height: 6vw;
  }

  .work-detail__note-text li::before{
    content: '';
    position: absolute;
    left: 0;
    top: 3vw;
    width: 0.9vw;
    height: 0.9vw;
    background-color: #1A1A1A;
    border-radius: 50%;
  }

  
/* ---- about ---- */
.about {
    padding: 18vw 0;
    position: relative;
  }
  
  .about__inner {
    max-width: 100%;
    margin: 0 auto;
  }    

  .about__title {
    margin-bottom: 11.73vw;
    border: 0.53 solid #9b4de0;
    padding: 0.25vw 6.66vw;
    border-radius: 9999px;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
  }

  .about__title__text {
    font-size: 10vw;
    line-height: 11vw;
    display: inline-block;
    background: linear-gradient(180deg,#22A8FC,#E25DDC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
  }
  
  .about__content {
    display: flex;
    flex-direction: column-reverse;
    flex-wrap: wrap;
    gap: 10.66vw;
    align-items: flex-start;
    margin-bottom: 10.66vw;
  }
  
  .about__text {
    flex: 1 1 50%;
    font-size: 0.95rem;
    color: #333;
    text-align: center;
    display: block;
  }
  
  .about__subtitle {
    font-size: 4.8vw;
    font-weight: 500;
    color: #441EC3;
    margin-bottom: 5vw;
  }
  
  .about__company {
    width: 70.4vw;
    margin-bottom: 8vw;
  }
  
  .about__catch {
    font-size: 4.8vw;
    font-weight: 700;
    color: #2B2B2B;
    margin-bottom: 9vw;
    letter-spacing: 0.8vw;
    line-height: 7.8vw;
  }

  .about__description {
    text-align: left;
    padding-left: 10vw;
    padding-right: 10vw;
    font-size: 4.8vw;
    font-weight: 400;
    letter-spacing: 0.3vw;
    line-height: 7.8vw;
    margin-bottom: -2vw;
  }
  
  .about__image {
    flex: 1 1 45%;
  }
  
  .about__image img {
    width: 100%;
  }
  
  .about__services {
    background-color: #fff;
    margin-bottom: 10.66vw;
    width: 90vw;
    margin-left: auto;
    margin-right: auto;
  }

  .about__services__text {
    font-size: 4vw;
    font-weight: 300;
    color: #444;
    text-align: left;
    padding: 5vw;
    line-height: 7.8vw;
    letter-spacing: 0.45vw;
  }
  
  .about__button-area {
    text-align: center;
  }
  
  .about__button {
    background: linear-gradient(180deg,#C471D8 , #3052DE);
    color: white;
    padding: 2vw 12vw;
    border-radius: 9999px;
    text-decoration: none;
    font-size: 3.73vw;
    font-weight: 600;
    transition: opacity 0.3s;
    display: inline-block;
    letter-spacing: 0.4vw;
  }
  
  .about__button:hover {
    opacity: 0.8;
  }
  
  .about__bg {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    /*width: 100%;*/
    display: block;
    left: 50%;
    transform: translateX(-50%);
  }

  /* ---- question ---- */
  .question {
    background-color: #fefefe;
    padding: 21.33vw 9.5vw;
  }
  
  .question__inner {
    max-width: 213.33vw;
    margin: 0 auto;
  }
  
  .question__title {
    background-color: transparent;
    border: 0.53vw solid #a500e2;
    padding: 0.0vw 5vw;
    border-radius: 9999px;
    width:fit-content;
    display: block;
    margin: 6vw auto 5vw auto;
  }
  
  .question__title__text {
    background: linear-gradient(180deg,#22A8FC,#E25DDC);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    color: transparent;
    font-size: 9vw;
  }
  
  .question__list {
    display: flex;
    flex-direction: column;
    gap: 6.4vw;
  }
  
  .question__item {
    background-color: #ffffff;
    border: 0.53vw solid #F0D4F7;
  }
  
  .question__label {
    display: flex;
    flex-direction: row;
    text-align: left;
    align-items: flex-start;
    background-color: #F0D4F7;
    padding: 2vw 0;
  }

  .question__label__icon {
    width: 6.66vw;
    margin: 0 2.5vw;
  }
  
  .question__label__title {
    font-weight: bold;
    display: flex;
    align-items: center;
    width: 66.66vw;
    letter-spacing: 0.2vw;
    font-size: 4.26vw
  }

  .question__state {
    width:7vw;
    height: auto;
    margin-top: 5%;
    /*border-style:solid;
    border-width: 2.2vw 33.5vw 2.2vw 0;
    border-color: transparent #FFFFFF transparent transparent;*/
    margin-right: 1vw;
    transform: rotateZ(0deg); 
    transition: transform 0.4s ease;
    filter: drop-shadow(0.25vw 0.25vw 0.25vw rgba(0, 0, 0, 0.4));
    will-change: filter;
    display: flex;
    align-items: center;
  }

  .question__item.open .question__state {
    transform: rotateZ(-90deg);
  }

  /* 最初は非表示 */
  .question__answer {
    font-size: 4.26vw;
    font-weight: 500;
    line-height: 1.6;
    color: #444;
    margin: 0 3vw; /* margin-top は open時に付与 */
    overflow: hidden;
    transition: max-height 0.4s ease, opacity 0.4s ease, transform 0.4s ease, margin 0.4s ease;
    max-height: 0;
    transform: translateY(-5%);
  }

  /* 開いたときの表示状態 */
  .question__item.open .question__answer {
    max-height: 100vw; /* 想定される最大値。大きめに */
    opacity: 1;
    margin-top: 3.5vw;
    margin-bottom: 3.5vw;
    transform: translateY(0);
  }

  /* ---- closing ---- */
  .closing {
    padding: 5vw 0;
    position: relative;
  }
  
  .closing__inner {
    margin: 0 auto;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    justify-content: space-between;
    gap: 10.66vw;
    flex-direction: column-reverse;
  }
  
  .closing__text {
    flex: 1 1 50%;
    color: #333;
    text-align: center;
    display: block;
  }
  
  .closing__heading_1 {
    font-size: 5.33vw;
    font-weight: 600;
    color: #6500BA;
    margin-bottom: -0.8vw;
    letter-spacing: 0.5vw;
  }

  .closing__heading_2 {
    font-size: 6.66vw;
    font-weight: 700;
    color: #6500BA;
    margin-bottom: 5.33vw;
    letter-spacing: 0.5vw;
  }

  .closing__heading_2_mobile {
    display: none;
  }
  
  .closing__lead {
    font-size: 4.53vw;
    font-weight: 400;
    line-height: 7.8vw;
    margin-bottom: 13vw;
    display: inline-block;
    width: 80vw;
    text-align: left;
    letter-spacing: 0.7vw;
  }
  
  .closing__button {
    background: linear-gradient(180deg, #0DBEFF,#C72EFF);
    color: #fff;
    padding: 4vw 10vw;
    border-radius: 9999px;
    text-decoration: none;
    font-weight: 700;
    display: inline-block;
    transition: opacity 0.3s;
    font-size: 5.86vw;
    letter-spacing: 0.5vw;
  }
  
  .closing__button:hover {
    opacity: 0.85;
  }
  
  .closing__image {
    flex: 1 1 40%;
    text-align: center;
  }
  
  .closing__image img {
    width: 93.70vw;
    margin-bottom: -7vw;
  }

  .closing__bg {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    /*width: 100%;*/
    display: block;
    left: 50%;
    transform: translateX(-50%);
  }
  
  /* ---- contact ---- */
  .contact {
    background-color: #EBEEFF;
    padding: 14vw 5.33vw 9vw 5.33vw;
    text-align: center;
  }
  
  .contact__inner {
    width: 80vw;
    margin: 0 auto;
  }
  
  .contact__title {
    font-size: 7.2vw;
    font-weight: 600;
    color: #0068B9;
    margin-bottom: 2.66vw;
    letter-spacing: 0.5vw;
  }

  .contact__line {
    position: relative;
    height: 0.4vw;
    background: #0068B9;
    margin: 6vw auto 4.5vw auto;
    width: 25vw;
  }
  
  .contact__lead {
    font-size: 0.95rem;
    color: #555;
    margin-bottom: 9.5vw;
    letter-spacing: 0.25vw;
  }
  
  .contact__form {
    text-align: left;
  }
  
  .contact__field {
    margin-bottom: 3.5vw;
  }
  
  .contact__field label {
    display: block;
    font-weight: bold;
    margin-bottom: 1vw;
    font-size: 0.95rem;
  }
  
  .contact__field input,
  .contact__field textarea {
    width: 100%;
    padding: 0.5vw;
    border: 0.5vw solid #707070;
    font-size: 1rem;
    max-width: 100%;
    background: #fff;
  }
  
  .contact__tel-group {
    display: flex;
    align-items: center;
    gap: 2.66vw;
  }
  
  .contact__tel-group input {
    width: 100%;
    max-width: 22vw;
  }
  
  .hyphen {
    font-size: 1.2rem;
  }
  
  .required {
    background-color: #e53935;
    color: #fff;
    padding: 0vw 2vw;
    font-size: 3vw;
    font-weight: 300;
    margin-left: 0.5vw;
  }
  
  .contact__submit {
    text-align: center;
    margin-top: 8vw;
  }
  
  .contact__submit button {
    background: #8C5FE2;
    color: white;
    padding: 2.8vw 9vw;
    font-size: 1rem;
    border: none;
    border-radius: 3vw;
    cursor: pointer;
    transition: opacity 0.3s;
  }
  
  .contact__submit button:hover {
    opacity: 0.85;
  }
  
  /* ---- footer ---- */
  .footer {
    padding: 22vw 5.33vw 3vw 5.33vw;
    text-align: center;
    position: relative;
  }
  
  .footer__inner {
    margin: 0 auto;
    display: block;
    text-align: center;
  }
  
  .footer__company {
    width: 46.14vw;
    margin-bottom: 9vw;
  }
  
  .footer__address {
    font-size: 3.46vw;
    font-weight: 600;
    margin-bottom: 3vw;
    color: #ffffff;
    letter-spacing: 0.5vw;
  }

  .footer__tell-pc {
    display: none;
  }

  .footer__tell-mobile {
    color: #ffffff;
    font-size: 3.46vw;
    font-weight: 600;
    letter-spacing: 0.6vw;
  }

  .footer__mail-mobile {
    color: #ffffff;
    font-size: 3.46vw;
    font-weight: 600;
    letter-spacing: 0.5vw;
    margin-bottom: 10vw;

  }

  .footer__mail-mobile a {
    text-decoration: none;
    color: #ffffff;
    cursor: default;
  }

  .no-spam {
    display: none;
  }
  
  .footer__link-banner img {
    width: 80vw;
    margin-bottom: 10vw;
  }
  
  .footer__copyright {
    font-family: "Hiragino Mincho ProN", 'Noto Serif JP',sans-serif;
    font-size: 0.8rem;
    color: #fff;
  }

  .footer__bg {
    position: absolute;
    top:0;
    z-index: -1;
    height: 100%;
    /*width: 100%;*/
    display: block;
    left: 50%;
    transform: translateX(-50%);
  }
    