@charset "utf-8";
.pg__fv {
    background-image: url(https://kisatosandworld.com/system_panel/uploads/images/pg-fv-service.png);
}

.service-top__inner {
  position: relative;
}
.service-top__deco1 {
      position: absolute;
    left: 0;
    top: 0;
    width: 28%;
    z-index: 10;
    aspect-ratio: 536/250;
    object-fit: cover;
    height: auto;
}
.service-top__deco2 {
      position: absolute;
    right: clamp(1.25rem, -1.917rem + 6.6vw, 6rem);
    bottom: 5%;
    width: 15%;
    z-index: 10;
    aspect-ratio: 282/130;
    object-fit: cover;
    height: auto;
}
.service-top__container {
      position: relative;
    z-index: 20;
    padding-top: clamp(5rem, 3.333rem + 3.47vw, 7.5rem);
      padding-left: 20px;
    padding-right: 20px;
    text-align: center;
    display: flex;
    flex-direction: column;
    row-gap: clamp(2rem, 1.667rem + 0.69vw, 2.5rem);
}
.service-top__title {
      font-size: clamp(1.5rem, 0.5rem + 2.08vw, 3rem);
    font-weight: 900;
}
.service-top__text {
      font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 500;
}

.service__line {
  object-fit: cover;
}
.service__container {
      margin-top: clamp(2.188rem, -1.604rem + 7.9vw, 7.875rem);
    display: flex;
    flex-direction: column;
    row-gap: clamp(6.25rem, 0.167rem + 12.67vw, 15.375rem);
}
.service__item {
      display: flex;
    column-gap: clamp(1.25rem, -2.083rem + 6.94vw, 6.25rem);
    padding: 0 clamp(1.25rem, -9.917rem + 23.26vw, 18rem);
    position: relative;
}
.service-deco1 {
      position: absolute;
    z-index: 10;
    width: clamp(22.813rem, 5.271rem + 36.55vw, 49.125rem);
  height: auto;
    left: 0;
    bottom: 0;
  mix-blend-mode: multiply;
}
.service-deco2 {
      position: absolute;
    z-index: 10;
    width: clamp(22.813rem, 5.271rem + 36.55vw, 49.125rem);
  height: auto;
    right: 0;
    bottom: 0;
  mix-blend-mode: multiply;
}
.service__item:nth-child(2n) {
  flex-direction: row-reverse;
}
.service-item__left {
  width: 48%;
      position: relative;
    z-index: 20;
}
.service-item__img {
      aspect-ratio: 598/494;
    object-fit: cover;
    height: auto;
}
.service-item__right {
      width: 52%;
    display: flex;
    flex-direction: column;
    align-items: center;
      position: relative;
    z-index: 20;
}
.service-item__title {
      font-size: clamp(1.5rem, 0.833rem + 1.39vw, 2.5rem);
    font-weight: 900;
}
.service-item__text {
      margin-top: clamp(1.25rem, 0.417rem + 1.74vw, 2.5rem);
    font-size: clamp(0.875rem, 0.708rem + 0.35vw, 1.125rem);
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-weight: 500;
}
.service-item__sub {
      margin-top: clamp(1.25rem, -0.25rem + 3.13vw, 3.5rem);
    display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: clamp(0.25rem, 0.042rem + 0.43vw, 0.563rem);
}
.service-item-sub__text {
      font-size: clamp(1.125rem, 1.042rem + 0.17vw, 1.25rem);
    font-weight: 900;
}
.service-item-sub__line {
      width: clamp(4.75rem, 3.083rem + 3.47vw, 7.25rem);
    object-fit: contain;
}
.service-item__wrap {
      margin-top: clamp(1.25rem, 1.083rem + 0.35vw, 1.5rem);
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: 14px;
}
.service-item__content {
      display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
  font-family: "Zen Kaku Gothic New", sans-serif;
    font-size: clamp(0.75rem, 0.5rem + 0.52vw, 1.125rem);
  font-weight: 500;
    text-align: center;
    width: clamp(6.875rem, 2.875rem + 8.33vw, 12.875rem);
    height: clamp(3.625rem, 1.417rem + 4.6vw, 6.938rem);
    background-color: #fff;
    border-radius: 50%;
}

.scene {
  padding-top: clamp(5rem, 1.667rem + 6.94vw, 10rem);
}
.scene__inner {
  padding: 0 clamp(1.25rem, -9.917rem + 23.26vw, 18rem);
}
.scene__container {
      background-image: url(https://kisatosandworld.com/system_panel/uploads/images/scene-bg.png);
    background-size: contain;
    padding: 40px clamp(1.875rem, -6.875rem + 10.94vw, 6.25rem) 56px;
}
.scene__title {
      font-size: clamp(1.125rem, 0.875rem + 0.52vw, 1.5rem);
    font-weight: 900;
    text-align: center;
}
.scene__items {
      margin-top: 40px;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    column-gap: clamp(1.25rem, -3.5rem + 5.94vw, 3.625rem);
    row-gap: 40px;
}
.scene-item__title {
      font-weight: 500;
    font-family: "Zen Kaku Gothic New", sans-serif;
    font-size: clamp(0.875rem, 0.625rem + 0.31vw, 1rem);
}
.scene-item__img {
      margin-top: 8px;
    aspect-ratio: 342/208;
    object-fit: cover;
    height: auto;
}

.gallery__title {
      display: flex;
    flex-direction: column;
    align-items: center;
    row-gap: 5px;
}
.gallery-title__main {
      font-size: clamp(1.5rem, 1.167rem + 0.69vw, 2rem);
    font-weight: 900;
}
.gallery-title__deco {
      width: clamp(10.688rem, 4.479rem + 12.93vw, 20rem);
    object-fit: contain;
}

.flow {
  padding-top: clamp(5rem, 1.667rem + 6.94vw, 10rem);
}
.flow__inner {
  padding: 0 clamp(1.25rem, -32.25rem + 41.88vw, 18rem);
}
.flow__items {
  margin-top: clamp(3.625rem, 3.375rem + 0.52vw, 4rem);
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    column-gap: clamp(1.25rem, 0.417rem + 1.74vw, 2.5rem);
    position: relative;
}
.flow__item {
      background-color: #FFf;
    background-image: url(https://kisatosandworld.com/system_panel/uploads/images/bg_1.png);
    border: 1px solid #C1C1C1;
    border-radius: 50%;
    aspect-ratio: 1;
    display: flex;
    align-items: center;
    flex-direction: column;
    position: relative;
  padding: 0 clamp(1.25rem, 0.833rem + 0.87vw, 1.875rem);
  padding-top: 5%;
}
.flow__item::after {
  content: "";
  position: absolute;
  top: 50%;
  right: -20%;
  width: 50%;
  height: 1px;
  background: #C1C1C1;
  z-index: -1;
}

/* 3番目と5番目は線なし */
.flow__item:nth-child(5)::after {
  display: none;
}

.flow__number {
      font-size: clamp(1.5rem, 1.208rem + 0.61vw, 1.938rem);
    font-weight: 900;
}
.flow__title {
      margin-top: clamp(0rem, -0.167rem + 0.35vw, 0.25rem);
    font-size: clamp(1rem, 0.833rem + 0.35vw, 1.25rem);
}
.flow__text {
      margin-top: clamp(0.375rem, 0.292rem + 0.17vw, 0.5rem);
    font-size: clamp(0.625rem, 0.458rem + 0.35vw, 0.875rem);
}

.faq {
  padding-top: clamp(5rem, 3.333rem + 3.47vw, 7.5rem);
}
.faq_inner {
  padding: 0 clamp(1.25rem, -9.917rem + 23.26vw, 18rem);
}
.faq__title {
      font-size: 24px;
    font-weight: 900;
    padding-bottom: 15px;
    border-bottom: double;
}
.faq__items {
      margin-top: clamp(1.563rem, 0.521rem + 2.17vw, 3.125rem);
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    column-gap: clamp(1.25rem, -2rem + 6.77vw, 6.125rem);
    row-gap: 40px;
}
.faq__item {
      padding-bottom: 30px;
    border-bottom: 1px solid #707070;
}
.faq-item__header,
.faq-item__content {
      display: flex;
    align-items: baseline;
    column-gap: 10px;
}
.faq-item__q,
.faq-item__a {
      width: clamp(1.875rem, 1.375rem + 1.04vw, 2.625rem);
    min-width: clamp(1.875rem, 1.375rem + 1.04vw, 2.625rem);
    height: clamp(1.875rem, 1.375rem + 1.04vw, 2.625rem);
    border: 1px solid #000;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: clamp(1rem, 0.833rem + 0.35vw, 1.25rem);
    font-weight: 900;
}
.faq-item__title,
.faq-item-text__1 {
      font-size: clamp(0.875rem, 0.708rem + 0.35vw, 1.125rem);
    font-weight: 500;
    font-family: "Zen Kaku Gothic New", sans-serif;
}
.faq-item__content {
  margin-top: clamp(0.438rem, 0.229rem + 0.43vw, 0.75rem);
}
.faq-item-text__2 {
      margin-top: clamp(0.125rem, -0.125rem + 0.52vw, 0.5rem);
    font-size: clamp(0.75rem, 0.667rem + 0.17vw, 0.875rem);
    font-weight: 400;
    font-family: "Zen Kaku Gothic New", sans-serif;
}

.workshop {
  margin-top: clamp(5rem, 1.667rem + 6.94vw, 10rem);
}
.workshop__inner {
      padding: clamp(2.5rem, 0.833rem + 3.47vw, 5rem) clamp(1.25rem, -9.917rem + 23.26vw, 18rem);
    background-color: #fff;
}
.workshop__container {
      display: flex;
    column-gap: clamp(1.25rem, -1.75rem + 6.25vw, 5.75rem);
}
.workshop__left {
  width: 50%;
}
.workshop__img {
      aspect-ratio: 672/448;
    object-fit: cover;
    height: auto;
}
.workshop__right {
      width: 50%;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.workshop__logo {
      width: clamp(15.938rem, 13.271rem + 5.56vw, 19.938rem);
    object-fit: contain;
}
.workshop__title {
      margin-top: clamp(1.25rem, 0.417rem + 1.74vw, 2.5rem);
    font-size: clamp(1.25rem, 1.083rem + 0.35vw, 1.5rem);
    font-weight: 900;
}
.workshop__text {
      margin-top: 20px;
    text-align: center;
    font-family: "Zen Kaku Gothic New", sans-serif;
}



.view-btn {
        position: relative;
    margin-top: 32px;
    overflow: hidden;
    display: flex;
    column-gap: clamp(0.813rem, -0.104rem + 1.91vw, 2.188rem);
    justify-content: center;
    align-items: center;
    text-decoration: none;
    background-color: #FCFAF3;
    padding: 16px clamp(2.125rem, 1.125rem + 2.08vw, 3.625rem);
  box-shadow: 0 3px 6px rgba(0,0,0,0.16);
}
/* テキスト */
.view-btn__text {
        position: relative;
    z-index: 2;
    color: #000;
    font-size: clamp(1.125rem, 1.042rem + 0.17vw, 1.25rem);
    line-height: 1.5;
    font-weight: 900;
    text-align: center;
}
/* 線 */
.view-btn__line {
        position: relative;
    width: clamp(4.375rem, 3.625rem + 1.56vw, 5.5rem);
    height: 1px;
    background: #000;
    z-index: 2;
}
/* 点 */
.view-btn__glow {
      position: absolute;
    top: 50%;
    left: -10px;
    transform: translateY(-50%);
    width: clamp(0.938rem, 0.771rem + 0.35vw, 1.188rem);
    height: clamp(0.938rem, 0.771rem + 0.35vw, 1.188rem);
    border-radius: 50%;
    background: #000;
    filter: blur(1px);
    transition: left 0.9s cubic-bezier(.65,.05,.36,1),
    width 0.9s ease,
    height 0.9s ease,
    background 0.9s ease;
}
/* ホバー */
.view-btn:hover .view-btn__glow {
  left: calc(100% - 14px);
  background: radial-gradient(
    circle,
    rgba(0,0,0,1) 0%,
    rgba(0,0,0,0.9) 25%,
    rgba(0,0,0,0.45) 55%,
    rgba(0,0,0,0.12) 80%,
    rgba(0,0,0,0) 100%
  );
  filter: blur(2px);
}


@media (max-width: 1279px) {
  .scene__items {
    grid-template-columns: repeat(2, 1fr);
  }
  .flow__items {
  grid-template-columns: repeat(6, 1fr);
  gap: 20px;
        max-width: 700px;
    margin-left: auto;
    margin-right: auto;
  }
  .flow__item {
        padding-left: 30px;
    padding-right: 30px;
    padding-top: 15%;
  }
/* 上3つ */
  .flow__item:nth-child(1),
  .flow__item:nth-child(2),
  .flow__item:nth-child(3) {
    grid-column: span 2;
  }
  /* 下2つ */
  .flow__item:nth-child(4) {
    grid-column: 2 / span 2;
  }
  .flow__item:nth-child(5) {
    grid-column: 4 / span 2;
  }
  .flow__item:nth-child(3)::after {
    display: none;
  }
}

@media (max-width: 767px) {
  .service-top__deco1 {
        aspect-ratio: 279/234;
    width: 72%;
  }
  .service-top__deco2 {
        aspect-ratio: 192/103;
    width: 50%;
  }
  
  .service__item {
        flex-direction: column-reverse;
    row-gap: 40px;
    padding: 0 10px;
  }
  .service__item:nth-child(2n) {
        flex-direction: column-reverse;
    row-gap: 40px;
    padding: 0 10px;
  }
  .service-item__left {
    width: 100%;
  }
  .service-item__right {
    width: 100%;
  }
  .service__item > .service-item__left {
    padding-left: 108px;
  }
  .service__item > .service-item__text {
    padding-left: 20px;
  }
  .service__item:nth-child(2n) > .service-item__left {
    padding-left: 0;
    padding-right: 108px;
  }
  .service__item:nth-child(2n) > .service-item__text {
    padding-left: 0;
    padding-right: 20px;
  }
  
  .scene__container {
        padding-left: 20px;
    padding-right: 20px;
  }
  .scene__items {
        grid-template-columns: repeat(1, 1fr);
    max-width: 500px;
    margin-left: auto;
    margin-right: auto;
  }
  .flow__items {
    grid-template-columns: 1fr;
    gap: 40px;
    max-width: clamp(12.5rem, 9.914rem + 10.61vw, 15rem);
  }
  .flow__item {
    grid-column: span 1 !important;
  }
  .flow__item::after {
    top: unset;
    right: 50%;
    transform: translateX(50%);
    bottom: -20%;
    width: 1px;
    height: 50px;
  }
  .flow__item:nth-child(3)::after {
    display: block;
  }
  
  .faq__container {
        max-width: 600px;
    margin-left: auto;
    margin-right: auto;
  }
  .faq__items {
    grid-template-columns: repeat(1, 1fr);
  }
  
  .workshop__container {
        flex-direction: column;
    row-gap: 40px;
    max-width: 600px;
    margin-left: auto;
    margin-right: auto;
  }
  .workshop__left,
  .workshop__right {
    width: 100%;
  }
}

@media (max-width: 389px) {
  .service-top__title {
    font-size: 22px;
  }
  .service-item__wrap {
        grid-template-columns: repeat(1, 1fr);
    row-gap: 10px;
  }
  .service-item__content {
        font-size: 16px;
    width: 180px;
    height: 80px;
  }
  .service-deco1,
  .service-deco2 {
    width: 300px;
  }
  .scene__inner {
    padding: 0 10px;
  }
  .scene__container {
        padding-left: 10px;
    padding-right: 10px;
  }
  .scene-item__title {
    font-size: clamp(0.75rem, 0.17rem + 2.9vw, 0.875rem);
  }
  .view-btn__text {
    font-size: 16px;
  }
}