@charset "utf-8";

*,
::before,
::after {
  padding: 0;
  margin: 0;
  box-sizing: border-box;
}

ul,
ol,
li {
  list-style-type: none;
}

a {
  color: inherit;
  text-decoration: none;
}

button {
  background-color: transparent;
  border-style: none;
  border-style: none;
}

img,
picture {
  max-width: 100%;
  width: 100%;
  height: auto;
  display: block;
  object-fit: contain;
}

.img-txt {
  height: 25px;
}

.img-ttl2 {
  height: 100px;
}

html {
  font-size: 62.5%;
  scroll-behavior: smooth;
}

body {
  position: relative;
  font-family: var(--jp);
  font-size: var(--f15);
  font-weight: 700;
  line-height: 1.5;
  /* letter-spacing: 0.1em; */
  color: var(--cbk);
  background: var(--cw);
}

body.fixed {
  overflow: hidden;
  height: 100%;
}

main {
  position: relative;
}

@media(max-width:1423px) {}

@media(max-width:1024px) {}

@media(max-width:600px) {}

:root {
  --jp: "IBM Plex Sans JP", sans-serif;
  /* --jp02: "Zen Kaku Gothic New", sans-serif; */
  --en: "Poppins", sans-serif;
  --num: "Arial", "Helvetica Neue", "Hiragino Kaku Gothic ProN", "Hiragino Sans", "Meiryo", sans-serif;
}

.jp {
  font-family: var(--jp);
}

/* .jp02 {
  font-family: var(--jp02);
} */

.en {
  font-family: var(--en);
}

.num {
  font-family: var(--num);
}

.italic {
  font-style: italic;
}


/* -------------------------
 * フォントサイズのroot
 * ------------------------- */
:root {
  --txt16: 1.6rem;
  --txt18: 1.8rem;
  --f10: 1rem;
  --f10all: 1rem;
  --f12: 1.2rem;
  --f12all: 1.2rem;
  --f13: 1.3rem;
  --f13all: 1.3rem;
  --f14: 1.4rem;
  --f14all: 1.4rem;
  --f15: 1.5rem;
  --f15all: 1.5rem;
  --f16: 1.6rem;
  --f17: 1.7rem;
  --f18: 1.8rem;
  --f19: 1.9rem;
  --f20: 2rem;
  --f21: 2.1rem;
  --f22: 2.4rem;
  --f24: 2.4rem;
  --f26: 2.6rem;
  --f28: 2.8rem;
  --f30: 3rem;
  --f32: 3.2rem;
  --f34: 3.4rem;
  --f36: 3.6rem;
  --f38: 3.8rem;
  --f40: 4rem;
  --f42: 4.2rem;
  --f44: 4.4rem;
  --f46: 4.6rem;
  --f48: 4.8rem;
  --f50: 5rem;
  --f52: 5.2rem;
  --f54: 5.4rem;
  --f56: 5.6rem;
  --f58: 5.8rem;
  --f60: 6rem;
  --f62: 6.2rem;
  --f64: 6.4rem;
  --f70: 7rem;
  --f80: 8rem;
  --f90: 9rem;
  --f100: 10rem;
  --f120: 12rem;
}

@media(max-width:1423px) {
  :root {
    --txt16: 1.6rem;
    --txt18: 1.7rem;
    --f10: 1rem;
    --f10all: 1rem;
    --f12: 1.2rem;
    --f12all: 1.2rem;
    --f13: 1.3rem;
    --f13all: 1.3rem;
    --f14: 1.4rem;
    --f14all: 1.4rem;
    --f15: 1.5rem;
    --f15all: 1.5rem;
    --f16: 1.6rem;
    --f17: 1.7rem;
    --f18: 1.8rem;
    --f19: 1.9rem;
    --f20: 1.85rem;
    --f21: 1.9rem;
    --f22: 2rem;
    --f24: 2.1rem;
    --f26: 2.25rem;
    --f28: 2.4rem;
    --f30: 2.6rem;
    --f32: 2.8rem;
    --f34: 2.8rem;
    --f36: 3rem;
    --f38: 3rem;
    --f40: 3.15rem;
    --f42: 3.2rem;
    --f44: 3.3rem;
    --f46: 3.4rem;
    --f48: 3.9rem;
    --f50: 4rem;
    --f52: 4.1rem;
    --f54: 4.2rem;
    --f56: 4.3rem;
    --f58: 4.4rem;
    --f60: 4.5rem;
    --f62: 4.5rem;
    --f64: 4.6rem;
    --f70: 5rem;
    --f80: 5.5rem;
    --f90: 6rem;
    --f100: 6.75rem;
    --f120: 8rem;
  }
}

@media(max-width:834px) {
  :root {
    --txt16: 1.5rem;
    --txt18: 1.6rem;
    --f10: 0.9rem;
    --f10all: 1rem;
    --f12: 1.1rem;
    --f12all: 1.2rem;
    --f13: 1.2rem;
    --f13all: 1.3rem;
    --f14: 1.3rem;
    --f14all: 1.4rem;
    --f15: 1.4rem;
    --f15all: 1.5rem;
    --f16: 1.5rem;
    --f17: 1.6rem;
    --f18: 1.6rem;
    --f19: 1.6rem;
    --f20: 1.675rem;
    --f21: 1.7rem;
    --f22: 1.75rem;
    --f24: 1.8rem;
    --f26: 1.825rem;
    --f28: 1.85rem;
    --f30: 1.875rem;
    --f32: 1.9rem;
    --f34: 2.0rem;
    --f36: 2.0rem;
    --f38: 2.1rem;
    --f40: 2.15rem;
    --f42: 2.4rem;
    --f44: 2.4rem;
    --f46: 2.4rem;
    --f48: 2.4rem;
    --f50: 2.4rem;
    --f52: 2.5rem;
    --f54: 2.6rem;
    --f56: 2.7rem;
    --f58: 2.8rem;
    --f60: 3.0rem;
    --f62: 3.1rem;
    --f64: 3.2rem;
    --f70: 3.6rem;
    --f80: 4.2rem;
    --f90: 4.6rem;
    --f100: 5rem;
    --f120: 6rem;
  }
}

.txt16 {
  font-size: var(--txt16);
  font-weight: 400;
  line-height: 2.3;
}

.txt18 {
  font-size: var(--txt18);
  font-weight: 400;
  line-height: 2;
}

.f120 {
  font-size: var(--f120);
}

.f100 {
  font-size: var(--f100);
}

.f90 {
  font-size: var(--f90);
}

.f80 {
  font-size: var(--f80);
}

.f70 {
  font-size: var(--f70);
}

.f64 {
  font-size: var(--f64);
}

.f62 {
  font-size: var(--f62);
}

.f60 {
  font-size: var(--f60);
}

.f56 {
  font-size: var(--f56);
}

.f54 {
  font-size: var(--f54);
}

.f52 {
  font-size: var(--f52);
}

.f50 {
  font-size: var(--f50);
}

.f48 {
  font-size: var(--f48);
}

.f42 {
  font-size: var(--f42);
}

.f40 {
  font-size: var(--f40);
}

.f36 {
  font-size: var(--f36);
}

.f32 {
  font-size: var(--f32);
}

.f30 {
  font-size: var(--f30);
}

.f28 {
  font-size: var(--f28);
}

.f26 {
  font-size: var(--f26);
}

.f24 {
  font-size: var(--f24);
}

.f22 {
  font-size: var(--f22);
}

.f21 {
  font-size: var(--f21);
}

.f20 {
  font-size: var(--f20);
}

.f18 {
  font-size: var(--f18);
}

.f18all {
  font-size: 1.8rem;
}

.f17 {
  font-size: var(--f17);
}

.f16 {
  font-size: var(--f16);
}

.f15 {
  font-size: var(--f15);
}

.f15all {
  font-size: var(--f15all);
}

.f14 {
  font-size: var(--f14);
}

.f14all {
  font-size: var(--f14all);
}

.f13 {
  font-size: var(--f13);
}

.f13all {
  font-size: var(--f13all);
}

.f12 {
  font-size: var(--f12);
}

.f12all {
  font-size: var(--f12all);
}

.f10 {
  font-size: var(--f10);
}

.f10all {
  font-size: var(--f10all);
}


/* SP area 750px→500px用 */

:root {
  --fsp18: 1.3rem;
  --fsp20: 1.4rem;
  --fsp22: 1.5rem;
  --fsp24: 1.6rem;
  --fsp28: 1.9rem;
  --fsp30: 2rem;
  --fsp32: 2.1rem;
  --fsp36: 2.35rem;
  --fsp40: 2.6rem;
  --fsp42: 2.8rem;
  --fsp60: 3.8rem;
  --fsp70: 4.2rem;
  --fsp90: 5.5rem;
  --fsp100: 6rem;
}

@media(max-width:450px) {
  :root {
    --fsp18: 1.1rem;
    --fsp20: 1.2rem;
    --fsp22: 1.3rem;
    --fsp24: 1.4rem;
    --fsp28: 1.7rem;
    --fsp30: 1.8rem;
    --fsp32: 1.9rem;
    --fsp36: 2rem;
    --fsp40: 2.1rem;
    --fsp42: 2.2rem;
    --fsp60: 2.8rem;
    --fsp70: 3rem;
    --fsp90: 3.6rem;
    --fsp100: 4rem;
  }
}

.fsp100 {
  font-size: var(--fsp100);
}

.fsp90 {
  font-size: var(--fsp90);
}

.fsp70 {
  font-size: var(--fsp70);
}

.fsp60 {
  font-size: var(--fsp60);
}

.fsp42 {
  font-size: var(--fsp42);
}

.fsp40 {
  font-size: var(--fsp40);
}

.fsp36 {
  font-size: var(--fsp36);
}

.fsp32 {
  font-size: var(--fsp32);
}

.fsp30 {
  font-size: var(--fsp30);
}

.fsp28 {
  font-size: var(--fsp28);
}

.fsp24 {
  font-size: var(--fsp24);
}

.fsp24txt {
  font-size: var(--fsp24);
  color: #555;
  line-height: 1.5;
  font-weight: 500;
}

.fsp22 {
  font-size: var(--fsp22);
}

.fsp20 {
  font-size: var(--fsp20);
}

.fsp18 {
  font-size: var(--fsp18);
}

.h {
  font-weight: 900;
}

.eb {
  font-weight: 800;
}

.b {
  font-weight: 700;
}

.sb {
  font-weight: 600;
}

.m {
  font-weight: 500;
}

.r {
  font-weight: 400;
}

.l {
  font-weight: 300;
}

.el {
  font-weight: 200;
}

.t {
  font-weight: 100;
}


.lh20 {
  line-height: 2;
}


.lh17 {
  line-height: 1.7
}

.lh16 {
  line-height: 1.6
}

.lh15 {
  line-height: 1.5
}

.lh12 {
  line-height: 1.2
}

.lh10 {
  line-height: 1;
}

.ls0 {
  letter-spacing: 0em;
}

.ls1 {
  letter-spacing: 0.1em;
}

.ls02 {
  letter-spacing: 0.02em;
}

:root {
  --cw: #fff;
  --cgy: #b5b5b5;
  --cbk: #000;
  --cbk5: #555;
  --cbl: #00a8cb;
  --cgn: #29b591;
  --crd: #E54642;
  --cpk: #fe91ac;
  --cy: #ffeb51;
}

.fcw {
  color: var(--cw);
}

.fcgy {
  color: var(--cgy);
}

.fcbk {
  color: var(--cbk);
}

.fcbk5 {
  color: var(--cbk5);
}

.fcbl {
  color: var(--cbl);
}

.fcgn {
  color: var(--cgn);
}

.fcrd {
  color: var(--crd);
}

.fcpk {
  color: var(--cpk);
}

.fcy {
  color: var(--cy);
}

.underline {
  text-decoration: underline 1px currentColor;
}

.tac {
  text-align: center;
}

.tas {
  text-align: start;
}

.tae {
  text-align: end;
}

/* ============== */


.pad {
  padding: 150px 0;
}

.padtop {
  padding-top: 150px;
}

.padbtm {
  padding-bottom: 150px;
}

@media(max-width:1423px) {
  .pad {
    padding: 9vw 0;
  }

  .padtop {
    padding-top: 9vw;
  }

  .padbtm {
    padding-bottom: 9vw;
  }
}

@media(max-width:834px) {
  .pad {
    padding: 60px 0;
  }

  .padtop {
    padding-top: 60px;
  }

  .padbtm {
    padding-bottom: 60px;
  }
}


@media(max-width:500px) {
  .pad {
    padding: 50px 0;
  }

  .padtop {
    padding-top: 50px;
  }

  .padbtm {
    padding-bottom: 50px;
  }
}

.s_pad {
  padding: 100px 0;
}

.s_padtop {
  padding-top: 100px;
}

.s_padbtm {
  padding-bottom: 100px;
}

@media(max-width:1423px) {
  .s_pad {
    padding: 6vw 0;
  }

  .s_padtop {
    padding-top: 6vw;
  }

  .s_padbtm {
    padding-bottom: 6vw;
  }
}

@media(max-width:834px) {
  .s_pad {
    padding: 50px 0;
  }

  .s_padtop {
    padding-top: 50px;
  }

  .s_padbtm {
    padding-bottom: 50px;
  }
}


@media(max-width:500px) {
  .s_pad {
    padding: 50px 0;
  }

  .s_padtop {
    padding-top: 50px;
  }

  .s_padbtm {
    padding-bottom: 50px;
  }
}

.sp_pad {
  padding: 60px 0;
}

.sp_padtop {
  padding-top: 60px;
}

.sp_padbtm {
  padding-bottom: 60px;
}

@media(max-width:450px) {
  .sp_pad {
    padding: 45px 0;
  }

  .sp_padtop {
    padding-top: 45px;
  }

  .sp_padbtm {
    padding-bottom: 45px;
  }
}

.mrg {
  margin: 140px 0;
}

.mrgtop {
  margin-top: 140px;
}

.mrgbtm {
  margin-bottom: 140px;
}

.mrgt100 {
  margin-top: 100px;
}

.mrgt90 {
  margin-top: 90px;
}

.mrgt80 {
  margin-top: 80px;
}

.mrgt70 {
  margin-top: 70px;
}

.mrgt60 {
  margin-top: 60px;
}

.mrgt50 {
  margin-top: 50px;
}

.mrgt40 {
  margin-top: 40px;
}

.mrgt40_10 {
  margin-top: 40px;
}

.mrgt35 {
  margin-top: 35px;
}

.mrgt30 {
  margin-top: 30px;
}

.mrgt25 {
  margin-top: 25px;
}

.mrgt20 {
  margin-top: 20px;
}

.mrgt15 {
  margin-top: 15px;
}

.mrgt10 {
  margin-top: 10px;
}

@media(max-width:1423px) {
  .mrg {
    margin: 8vw 0;
  }

  .mrgtop {
    margin-top: 8vw;
  }

  .mrgbtm {
    margin-bottom: 8vw;
  }
}

@media(max-width:834px) {
  .mrg {
    margin: 60px 0;
  }

  .mrgtop {
    margin-top: 60px;
  }

  .mrgbtm {
    margin-bottom: 60px;
  }

  .mrgt100 {
    margin-top: 50px;
  }
}

@media(max-width:500px) {
  .mrg {
    margin: 45px 0;
  }

  .mrgtop {
    margin-top: 45px;
  }

  .mrgbtm {
    margin-bottom: 45px;
  }

  .mrgt40_10 {
    margin-top: 10px;
  }
}



.sp_mrg {
  margin: 60px 0;
}

.sp_mrgtop {
  margin-top: 60px;
}

.sp_mrgbtm {
  margin-bottom: 60px;
}

@media(max-width:450px) {
  .sp_mrg {
    margin: 45px 0;
  }

  .sp_mrgtop {
    margin-top: 45px;
  }

  .sp_mrgbtm {
    margin-bottom: 45px;
  }
}

.br20 {
  border-radius: 20px;
}

/* ========== */

.inner {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
}

.sp_inner {
  max-width: 436px;
  width: 90%;
  margin: 0 auto;
}

.sp_inner84 {
  width: 84%;
  margin: 0 auto;
}

/* 485px以下 */

.inner1280 {
  max-width: 1280px;
  width: 90%;
  margin: 0 auto;
}

.inner1500 {
  max-width: 1500px;
  width: 90%;
  margin: 0 auto;
}

.inner1080 {
  max-width: 1080px;
  width: 90%;
  margin: 0 auto;
}

@media(max-width:834px) {}

.max1200 {
  display: none;
}

.min1200 {
  display: block;
}

@media(max-width:1200px) {
  .max1200 {
    display: block;
  }

  .min1200 {
    display: none;
  }
}

.max834 {
  display: none;
}

.sp {
  display: none;
}

.min835 {
  display: block;
}

.pc {
  display: block;
}

@media(max-width:834px) {

  .max834 {
    display: block;
  }

  .min835 {
    display: none;
  }

  .sp {
    display: block;
  }

  .pc {
    display: none;
  }
}

.max700 {
  display: none;
}

@media(max-width:700px) {
  .max700 {
    display: block;
  }
}

.max600 {
  display: none;
}

.min601 {
  display: block;
}

@media(max-width:600px) {
  .max600 {
    display: block;
  }

  .min601 {
    display: none;
  }
}

.max550 {
  display: none;
}

@media(max-width:550px) {
  .max550 {
    display: block;
  }
}

.max500 {
  display: none;
}

@media(max-width:500px) {
  .max500 {
    display: block;
  }
}

.max470 {
  display: none;
}

@media(max-width:470px) {
  .max470 {
    display: block;
  }
}

.max450 {
  display: none;
}

@media(max-width:450px) {
  .max450 {
    display: block;
  }
}

.max400 {
  display: none;
}

@media(max-width:400px) {
  .max400 {
    display: block;
  }
}

.max380 {
  display: none;
}

@media(max-width:380px) {
  .max380 {
    display: block;
  }
}

.max370 {
  display: none;
}

@media(max-width:370px) {
  .max370 {
    display: block;
  }
}

.h-sc {
  position: relative;
  display: block;
  overflow: hidden;
  border-radius: 20px;
}

.h-sc__img {
  transition: all .3s ease-in-out;
}

.h-sc:hover .h-sc__img {
  transform: scale(1.05);
}

.h-op {
  transition: all .3s ease-in-out;
}

.h-op:hover {
  cursor: pointer;
  opacity: .7;
  transition: all .3s ease-in-out;
}

/* ======= */

.sec-ttl {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.sec-ttl01 {}

.sec-ttl02 {}

.sec-lead__circle {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  line-height: 1.2;
  width: 200px;
  height: 200px;
  background: url(../img/common/circle_gn_l.svg) no-repeat center / contain;
  padding-bottom: 20px;
}

.tag {
  position: relative;
  display: inline-block;
  padding: 2px 12px 0;
}

.tag::before {
  content: '';
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: #0051e0;
  border-radius: 3px;
}


.loadin01 {
  opacity: 0;
  transform: scale(0);
}

.loadin01.show {
  opacity: 1;
  transform: scale(1);
  transition: all .6s .1s ease-in-out;
}

.loadin02 {
  opacity: 0;
  transform: scale(0);
}

.loadin02.show {
  opacity: 1;
  transform: scale(1);
  transition: all .4s 0.9s ease-in-out;
}

.loadin03 {
  opacity: 0;
  transform: translate(0, -150%);
}

.loadin03.show {
  opacity: 1;
  transform: translate(0, 0%);
  transition: all .4s 1.3s ease-in-out;
}

@media(max-width: 834px) {

  .loadin01_sp {
    opacity: 0;
    transform: scale(0);
  }

  .loadin01_sp.show {
    opacity: 1;
    transform: scale(1);
    transition: all .6s .1s ease-in-out;
  }

  .loadin02_sp {
    opacity: 0;
    transform: scale(0);
  }

  .loadin02_sp.show {
    opacity: 1;
    transform: scale(1);
    transition: all .4s 0.9s ease-in-out;
  }

  .loadin03_sp {
    opacity: 0;
    transform: translate(0, -150%);
  }

  .loadin03_sp.show {
    opacity: 1;
    transform: translate(0, 0%);
    transition: all .4s 1.3s ease-in-out;
  }

  .loadin04_sp {
    opacity: 0;
    transform: translate(0, 100%) scale(0);
  }

  .loadin04_sp.show {
    opacity: 1;
    transform: translate(0, 0%) scale(1);
    transition: all .7s 1.8s ease-in-out;
  }
}


.opening01 {
  position: fixed;
  z-index: 1000;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background-color: var(--cy);
  transform: translate(0, 100%);
}

.opening01.show {
  /* height: 0; */
  animation: fvclose 1.8s ease-in-out;
  /* transform: translate(0, -110%); */
}

@keyframes fvclose {
  0% {
    /* height: 0;
        transform-origin: bottom; */
    transform: translate(0, 100%);
  }

  50% {
    /* height: 100vh; */
    /* transform-origin: top; */
  }

  100% {
    /* height: 100vh; */
    /* height: 0; */
    /* transform-origin: top; */
    transform: translate(0, -110%);
  }
}

@media(max-width:1000px) {
  .opening01 {
    display: none;
  }
}



.fadein {
  opacity: 0;
  transform: translate(0, 80px);
}

.fadein.show {
  opacity: 1;
  transform: translate(0, 0);
  transition: all .6s ease-out;
}

.fadein_sc {
  opacity: 0;
  transform: scale(0);
}

.fadein_sc.show {
  opacity: 1;
  transform: scale(1);
  transition: all .6s ease-out;
}

.fadein_sc_b {
  opacity: 0;
  transform: scale(0);
}

.fadein_sc_b.show {
  opacity: 1;
  transform: scale(1);
  animation: bounce .6s ease-in-out initial;
  /* transition: all .6s ease-out; */
}

@keyframes bounce {
  0% {
    opacity: 0;
    transform: scale(0);
  }

  80% {
    opacity: 1;
    transform: scale(1.1);
  }

  100% {
    opacity: 1;
    transform: scale(1);
  }
}

.btn {
  display: block;
  text-align: center;
  height: 90px;
  line-height: 92px;
  border-radius: 15px;
  width: 100%;
  color: #fff;
  background: #0066ff;
  box-shadow: 0 4px 0 #0059c6;
  transition: all .3s ease-in-out;
}

.btn:hover {
  opacity: .8;
  transition: all .3s ease-in-out;
}

.btn:active {
  box-shadow: none;
  transform: translateY(4px);
}

@media(max-width: 450px) {
  .btn {
    height: 74px;
    line-height: 76px;
    border-radius: 15px;
  }
}


.header-top {
  position: fixed;
  z-index: 110;
  top: 30px;
  left: 0;
  width: fit-content;
  padding: 0 40px;
  height: fit-content;
  transition: all .4s ease;
}

.header-top__inner {
  display: flex;
  align-items: center;
  gap: 25px;
}

.header-top__logo-link__img {
  width: 236px;
  fill: #fff;
}


@media(max-width:1000px) {
  .header-top__logo-link__img {
    width: 200px;
  }
}

@media(max-width: 834px) {
  .header-top {
    top: 20px;
    left: 0;
    padding: 0 20px;
  }

  .header-top.active {
    display: block;
  }

  .header-top__inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 25px;
  }

  .header-top__logo-link__img {
    width: 180px;
  }
}

@media(max-width: 500px) {
  .header-top {
    top: 20px;
    padding: 0 20px;
  }
}

.menu {
  position: fixed;
  z-index: 4;
  top: 50%;
  right: calc((50vw - 250px) / 2);
  transform: translate(50%, -50%);
  max-height: 100dvh;
  height: fit-content;
  overflow: scroll;
  display: flex;
  flex-direction: column;
}

.menu-inner {
  padding: 40px 15px;
}

.menu-nav {
  display: flex;
  flex-direction: column;
  gap: 20px;
}

.menu-nav__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  font-size: 1.6rem;
  font-weight: 600;
}

.menu-nav__link {
  position: relative;
  display: block;
}

.menu-nav__link.active {
  color: #0051e0;
}

@media(max-width:1200px) {
  .menu {
    display: none;
    z-index: 500;
    background: #f6f6f6;
    width: 100%;
    height: 100%;

    top: 0;
    right: 0;
    transform: translate(0%, 0%);
  }

  .menu.active {
    display: flex;
    align-items: center;
  }
}

@media(max-width:500px) {
  .menu-nav__list {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 15px;
    font-size: 1.6rem;
  }
}

.bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 2;
  width: 100%;
  height: 100vh;
  background: url(../img/common/bg_pc.webp) no-repeat center / cover;
}

.bg-left {
  width: calc(50vw - 250px);
  height: 100%;
  background: url(../img/common/pc_bg_left.webp) no-repeat center / cover;
}

@media(max-width:1200px) {
  .bg-left {
    display: none;
  }
}



.header-btn {
  position: fixed;
  z-index: 700;
  top: 15px;
  right: 15px;
  width: 100px;
  height: 48px;
  border-radius: 30px;
  background: #000;
  border: none;
  /* display: flex; */
  display: none;
  align-items: center;
  justify-content: center;
  gap: 10px;
}

.header-btn__txt {
  color: #fff;
}

.header-btn .header-btn__txt span:nth-of-type(1) {
  display: block;
}

.header-btn .header-btn__txt span:nth-of-type(2) {
  display: none;
}

.header-btn.active .header-btn__txt span:nth-of-type(1) {
  display: none;
}

.header-btn.active .header-btn__txt span:nth-of-type(2) {
  display: block;
}

@media(max-width:1200px) {
  .header-btn {
    display: flex;
  }
}

@media(max-width:450px) {
  .header-btn {
    top: 8px;
    right: 8px;
    width: 90px;
    height: 40px;
  }

  .header-btn__txt {
    font-size: 1.6rem;
  }
}

.common-main {
  position: relative;
  z-index: 2;
  margin-left: auto;
  margin-right: 50vw;
  transform: translate(50%, 0);
  z-index: 100;
  width: 500px;
  max-width: 100%;
  background: var(--cw);
  box-shadow: 0 0 7px 1px #50505030;
}

@media(max-width:1200px) {
  .common-main {
    position: relative;
    margin-left: auto;
    transform: translate(0, 0);
    margin-right: auto;
  }
}

@media(max-width:500px) {
  .common-main {
    border-radius: 0px;
    box-shadow: none;
    margin-top: 0;
  }
}

.top-main::after {
  content: '';
  position: absolute;
  z-index: -1;
  bottom: 0;
  left: 0;
  height: 60px;
  width: 100%;
  background: var(--cy);
}

.common-contact {
  position: relative;
  z-index: 6;
  border-radius: 50px;
  padding: 80px 0 50px;
  background: url(../img/common/bg_sp.webp) no-repeat center / cover;
}

.common-contact__mess02 {
  margin-top: 20px;
}

.common-contact__txt {
  margin-top: 35px;
}

.common-contact__cont {
  display: flex;
  flex-direction: column;
  align-items: center;
  background: var(--cw);
  text-align: center;
  border: 4px solid #000;
  border-radius: 15px;
  padding: 40px 6% 45px;
  margin-top: 40px;
}

.header-common__contact {
  position: relative;
  z-index: 4;
  width: 380px;
  max-width: 100%;
  padding: 25px 5% 30px;
  margin-top: 80px;
}

.header-common__contact-mess {
  position: absolute;
  top: -243px;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 160px;
  aspect-ratio: 254 / 216;
  background: url(../img/common/mess_fukidashi.webp) no-repeat center / contain;
}

.header-common__contact-mess__icon {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 25px;
}

.header-common__contact-person {
  position: absolute;
  z-index: 2;
  top: 0;
  right: 20px;
  transform: translate(0, -103%);
  width: 160px;
}

.common-contact__line-link {
  position: relative;
  background: #06c755;
  box-shadow: 0 4px 0 #03aa48;
}

.common-contact__line-link__txt {
  position: absolute;
  top: 0;
  left: 0;
  transform: translate(-20%, -20%);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  line-height: 1.3;
  height: 76px;
  width: 76px;
  border-radius: 100vmax;
  background: #000;
}

.header-common__contact .common-contact__line-link__txt {
  height: 66px;
  width: 66px;
  transform: translate(-15%, -20%);
}

.header-common__contact .btn {
  height: 70px;
  line-height: 72px;
  font-size: 2.2rem;
}

.common-contact__web-link {
  margin-top: 22px;
}

.header-common__contact .common-contact__web-link {
  margin-top: 15px;
}

.common-contact__tel-link {
  line-height: 1.3;
  background: #f5f5f5;
  width: 100%;
  border-radius: 15px;
  padding: 20px 0 5px;
  margin-top: 22px;
}

.header-common__contact .common-contact__tel-txt02 {
  font-size: 3rem;
}

.common-contact__sns-area {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-top: 30px;
}

.header-common__contact .common-contact__sns-area {
  gap: 10px;
  margin-top: 20px;
}

.header-common__contact .common-contact__sns-ttl {
  font-size: 1.7rem;
}

.common-contact__sns-list {
  display: flex;
  gap: 5px;
}

.common-contact__sns-item__img {
  width: 48px;
}


.header-common__contact .common-contact__sns-item__img {
  width: 42px;
}

@media(max-width:1450px) {
  .header-common__contact {
    width: 340px;
  }
}

@media(max-width:1200px) {
  .common-contact__end.common-contact {
    padding: 80px 0 100px;
  }
}

@media(max-width:500px) {
  .header-common__contact {
    width: 380px;
    max-width: 100%;
    padding: 30px 6% 35px;
    margin-top: 30px;
  }

  .header-common__contact-mess {
    display: none;
  }

  .header-common__contact-person {
    display: none;
  }
}

@media(max-width:450px) {
  .common-contact__web-link {
    margin-top: 15px;
  }

  .common-contact__tel-link {
    margin-top: 15px;
  }

  .common-contact__sns-ttl {
    font-size: 1.5rem;
  }

  .common-contact__sns-item__img {
    width: 42px;
  }


}

@media(max-width:430px) {
  .common-contact__people {
    width: 150px;
    margin: 20px auto 70px;
  }

  .common-contact__cont-inner {
    margin-top: -50px;
  }
}

@media(max-width:400px) {
  .common-contact__contact-link {
    width: 440px;
    max-width: 100%;
    height: 70px;
    line-height: 70px;
    margin: 20px auto 35px;
  }

  .common-contact__line-link__txt {
    top: 0;
    left: 0;
    transform: translate(-20%, -20%);
    line-height: 1.3;
    height: 66px;
    width: 66px;
  }

  .header-common__contact {
    width: 340px;
    max-width: 100%;
    padding: 30px 6% 35px;
    margin-top: 30px;
  }

}

.top-pcfv {
  position: fixed;
  z-index: 200;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;
  background: url(../img/common/bg_pc.webp) no-repeat center / cover;
}

.top-pcfv.show {
  /* height: 0;
  transform-origin: top; */
  /* transition: all .6s .6s ease-in-out; */
  animation: pcfvclose 1.8s ease-in-out;
}

@keyframes pcfvclose {
  0% {
    /* height: 100vh;
    transform-origin: top; */
    transform: translate(0, 0);
  }

  /* 98% {
    height: 0;
    transform-origin: top;
  } */
  30% {
    /* height: 100vh;
    transform-origin: top; */
    transform: translate(0, 0);
  }

  100% {
    transform: translate(0, -200%);
  }
}

.top-pcfv.hidden {
  display: none;
}

.top-pcfv__logo {
  position: absolute;
  top: 25px;
  left: 40px;
  width: 200px;
}

.top-pcfv__ttl {
  position: relative;
  z-index: 3;
  width: 60%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 15px;
  margin: 40px auto 0;
}

.top-pcfv__ttl01 {
  width: auto;
  height: 50px;
}

.top-pcfv__ttl02 {
  width: auto;
  height: 100px;
}

.top-pcfv__slider-area {
  width: 100%;
  height: calc(100dvh - 270px);
  display: flex;
  align-items: center;
  margin: 20px auto 0;
}

.top-pcfv__slider {
  padding: 60px 0 70px;
}

.top-pcfv__slider .swiper-slide {
  width: fit-content;
  height: fit-content;
}


.top-pcfv__slide {
  position: relative;
  height: calc(100dvh - 270px);
  /* height: 700px;
  width: 700px; */
  aspect-ratio: 1 / 1;
  border-radius: 100vmax;
  border: 5px solid #000;
  margin-left: 0;

  transform: scale(.8);
  transform-origin: top;

  background: #13c89b;
}

.top-pcfv__slide02 {
  background: #00a8cb;
}

.top-pcfv__slide03 {
  background: #fe91ac;
}

.swiper-slide-active .top-pcfv__slide {
  transform: scale(1);
}

.top-pcfv__slide-img {
  position: absolute;
  z-index: 2;
  width: 98%;
  top: -6%;
  left: 1%;
  /* animation: mv-fadein 8s linear infinite; */
  transform-origin: bottom;
}

.top-pcfv__slide02 .top-pcfv__slide-img {
  width: 91.7%;
  top: -5.6%;
  left: -10.3%;
}

.top-pcfv__slide03 .top-pcfv__slide-img {
  width: 79%;
  top: -3.5%;
  left: 10%;
}


.top-pcfv__mess-wrap {
  position: absolute;
  z-index: 3;
  top: 9%;
  left: 11%;

  writing-mode: vertical-rl;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 5px;

  opacity: 0;
}

.swiper-slide-active .top-pcfv__mess-wrap {
  opacity: 1;
  transition: all 1.4s ease-in-out;
}

.top-pcfv__mess {
  background: #000;
  border-radius: 30px;
  padding: 15px 6px;
}

.top-pcfv__list {
  position: absolute;
  z-index: 3;
  bottom: 0;
  right: 2%;

  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 3px;

  opacity: 0;
}

.swiper-slide-active .top-pcfv__list {
  opacity: 1;
  transition: all 1.4s ease-in-out;
}

.top-pcfv__item {
  background: #fff;
  border-radius: 10px;
  padding: 4px 10px 2px;
}

@media(max-width:1000px) {
  .top-pcfv {
    display: none;
  }
}


.top-spfv {
  position: relative;
  display: none;
  background: var(--cy);
  height: 100dvh;
  width: 100%;
  padding-top: 80px;
}

.top-spfv__ttl {
  position: relative;
  z-index: 3;
  width: 90%;
  margin: 0 auto 0;
}

.top-spfv__ttl02 {
  margin-top: 20px;
}


.mv_img__area {
  position: relative;
  z-index: 4;
  width: 90%;
  aspect-ratio: 1 / 1;
  border-radius: 100vmax;
  border: 5px solid #000;
  /* background: #13c89b; */
  margin: -30px auto 0;
  animation: mv-bg-change 24s ease-in infinite;
}

@keyframes mv-bg-change {
  0% {
    background: #13c89b;
  }

  33.32% {
    background: #13c89b;
  }

  33.33% {
    background: #00a8cb;
  }

  66.65% {
    background: #00a8cb;
  }

  66.66% {
    background: #fe91ac;
  }

  100% {
    background: #fe91ac;
  }
}

.mv_img__wrap {
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
  margin-left: auto;
  opacity: 0;
  animation: mv-change 24s ease-in infinite;
}

.mv_img__wrap01 {
  animation-delay: 0s;
}

.mv_img__wrap02 {
  animation-delay: 8s;
}

.mv_img__wrap03 {
  animation-delay: 16s;
}


@keyframes mv-change {
  0% {
    opacity: 1;
  }

  6% {
    opacity: 1;
  }

  28% {
    opacity: 1;
  }

  33.33% {
    opacity: 0;
  }

  100% {
    opacity: 0;
  }
}

.mv_img__person {
  position: absolute;
  z-index: 2;
  width: 98%;
  top: -6%;
  left: 1%;
  animation: mv-fadein 8s linear infinite;
  transform-origin: bottom;
}

.mv_img__wrap02 .mv_img__person {
  width: 91.7%;
  top: -5.6%;
  left: -10.3%;
}

.mv_img__wrap03 .mv_img__person {
  width: 79%;
  top: -3.5%;
  left: 10%;
}

.top-spfv__mess-wrap {
  position: absolute;
  z-index: 3;
  top: 9%;
  left: 11%;
  animation: mv-fadein01 8s linear infinite;

  writing-mode: vertical-rl;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 5px;
}

.top-spfv__mess {
  background: #000;
  border-radius: 30px;
  padding: 15px 6px;
}

.top-spfv__list {
  position: absolute;
  z-index: 3;
  bottom: 0;
  right: 2%;
  animation: mv-fadein02 8s linear infinite;

  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 3px;
}

.top-spfv__item {
  background: #fff;
  border-radius: 10px;
  padding: 4px 10px 2px;
}


@keyframes mv-fadein {
  0% {
    opacity: 0;
    transform: translate(0, 50px) scale(.2);
  }

  2% {
    opacity: 1;
    transform: translate(0, 0px) scale(1);
  }

  96% {
    opacity: 1;
    transform: translate(0, 0px) scale(1);
  }

  100% {
    opacity: 0;
    transform: translate(0, 50px) scale(0);
  }
}

@keyframes mv-fadein01 {
  0% {
    opacity: 0;
  }

  6% {
    opacity: 0;
    transform: scale(.2);
  }

  8% {
    opacity: 1;
    transform: scale(1);
  }

  9% {
    opacity: 1;
    transform: scale(.9);
  }

  10% {
    opacity: 1;
    transform: scale(1);
  }

  100% {
    opacity: 1;
  }
}

@keyframes mv-fadein02 {
  0% {
    opacity: 0;
  }

  16% {
    opacity: 0;
    transform: scale(.2);
  }

  18% {
    opacity: 1;
    transform: scale(1);
  }

  19% {
    opacity: 1;
    transform: scale(.9);
  }

  20% {
    opacity: 1;
    transform: scale(1);
  }

  100% {
    opacity: 1;
  }
}

.top-fvbtm__slider-area {
  position: absolute;
  bottom: 0;
  background: #000;
  padding: 10px 0;
}

.top-fvbtm__slider .swiper-wrapper {
  transition-timing-function: linear;
}

.top-fvbtm__slider .swiper-slide {
  width: fit-content;
  height: fit-content;
}

.top-fvbtm__slide-item {
  display: flex;
  align-items: center;
  gap: 13px;
}

.top-fvbtm__slide-txt {
  color: #fff;
}

.top-fvbtm__slide-img {
  width: 18px;
}

@media(max-width:1000px) {
  .top-spfv {
    display: block;
  }
}

@media(max-width:450px) {
  .top-spfv {
    padding-top: 65px;
  }
}

.top-worry {
  background: var(--cy);
}

.top-worry__first-area {
  position: relative;
  height: 200vh;
}

.top-worry__first {
  position: sticky;
  top: 0;
  left: 0;
  height: fit-content;
}

.top-worry__head {
  position: relative;
}

.top-worry__ttl-wrap {
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 90%;
}

.top-worry__ttl01 {
  width: 92%;
  margin: 0 auto 20px;
}

.top-worry__head-icon {
  position: absolute;
  /* bottom: 50px;
  right: 13%; */
  bottom: 25px;
  right: 17%;
  width: 50px;
  transform: translate(50%, -50%);
}

.top-worry__list-area {
  position: relative;
  padding: 30px 0 40px;
}

.top-worry__list-area::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  transform: translate(0, 99%);
  aspect-ratio: 750 / 100;
  background: url(../img/top/worry_list_arrow.webp) no-repeat center / contain;
}

.top-worry__list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.top-worry__item {
  position: relative;
  display: flex;
  align-items: center;
  line-height: 1.53;
  background: #f5e148;
  border-radius: 15px;
  height: 110px;
  padding-left: 85px;
}

.top-worry__item::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 30px;
  transform: translate(0, -50%);
  width: 34px;
  height: 36px;
  background: url(../img/common/icon_worry.svg) no-repeat center / contain;
}

.top-worry__bottom {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  width: 100%;
  aspect-ratio: 750 / 580;
  background: url(../img/top/worry_bottom.webp) no-repeat center / cover;
  padding-top: 55px;
}

.top-worry__bottom-mess01 {
  height: 20px;
}

.top-worry__bottom-mess02 {
  height: 90px;
  margin-top: 22px;
}


@media(max-width:450px) {
  .top-worry__head-icon {
    bottom: 5px;
    right: 17%;
    width: 42px;
    transform: translate(50%, -50%);
  }
}

@media(max-width:400px) {
  .top-worry__bottom-mess01 {
    height: 18px;
  }

  .top-worry__bottom-mess02 {
    height: 85px;
    margin-top: 22px;
  }
}

.top-system {
  position: relative;
  z-index: 2;
  background-color: var(--cy);
  padding-top: 135px;
  padding-bottom: 50px;
}

.top-system__head-lead {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -35%);
  width: 175px;
}

.top-system__ttl {
  width: 85%;
  margin: 0 auto 40px;
}

.top-system__slider {
  padding-top: 90px;
  padding-bottom: 90px;
}

.top-system__slider-item {
  position: relative;
  /* transition: rotate 1s ease-in-out, translate .3s ease-in-out; */
  /* transition: translate .3s ease-in-out; */
}

.swiper-slide-prev .top-system__slider-item {
  /* テスト１ */
  /* transform: translate(-15%, 13%) rotate(-15deg); */

  transform: translate(-14%, 18%) rotate(-20deg);
  transition: all .6s ease-in-out;
}

.swiper-slide-active .top-system__slider-item {
  transition: all .6s ease-in-out;
}

.swiper-slide-next .top-system__slider-item {
  /* テスト１ */
  /* transform: translate(15%, 13%) rotate(15deg); */

  transform: translate(14%, 18%) rotate(20deg);
  transition: all .6s ease-in-out;
}

.top-system__slider-item__ttl-wrap {
  position: absolute;
  z-index: 3;
  top: -20px;
  right: -16px;

  writing-mode: vertical-rl;
  display: flex;
  flex-direction: column;
  align-items: start;
  gap: 5px;
  color: #fff;

  opacity: 0;
  transition: all 1s ease-in-out;
}

.top-system__slider-item__ttl {
  background: #000;
  border-radius: 30px;
  padding: 15px 2px;
}

.swiper-slide-active .top-system__slider-item__ttl-wrap {
  opacity: 1;
}

.top-system__slider-item__ttl01,
.top-system__slider-item__ttl02 {
  position: relative;
  line-height: 1.7;
  /* border-right: 3px dotted #6697ec; */
}

.top-system__slider-item__ttl01::before,
.top-system__slider-item__ttl02::before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 100%;
  height: 100%;
}

/* Safari */
_::-webkit-full-page-media,
_:future,
:root .top-system__slider-item__ttl-wrap {
  position: absolute;
  top: 7%;
  left: 4%;
}

_::-webkit-full-page-media,
_:future,
:root .top-system__slider-item__ttl01::before,
_::-webkit-full-page-media,
_:future,
:root .top-system__slider-item__ttl02::before {
  right: -10px;
}

.top-system__slider-item__mess {
  position: absolute;
  z-index: 2;
  top: -60px;
  left: -25px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 180px;
  aspect-ratio: 254 / 216;
  background: url(../img/top/system_fukidashi.webp) no-repeat center / contain;

  opacity: 0;
  transform: scale(0);
}

.swiper-slide-active .top-system__slider-item__mess {
  opacity: 1;
  transform: scale(1);
  /* transition: all .6s ease-out; */
  animation: bounce .6s ease-in-out;
}

img.top-system__slider-item__mess-icon {
  display: inline-block;
  width: auto;
  /* ← width:100% を打ち消す */
  max-width: none;
  height: 1em;
  /* 文字サイズに合わせる */
  vertical-align: -0.15em;
  /* 微調整 */
  margin-left: 2px;
}

@media(max-width: 450px) {
  .top-system__head-lead {
    width: 160px;
    transform: translate(-50%, -20%);
  }

  .top-system__slider-item__mess {
    top: -75px;
    left: -25px;
    width: 150px;
  }
}

@media(max-width:450px) {}

.top-license {
  position: relative;
  z-index: 3;
  border-radius: 50px 50px 0 0;
  background: #fff;
  margin-top: -50px;
}

.top-license__ttl {
  width: 65%;
  margin: 20px auto 0 7%;
}

.top-license__head {
  position: relative;
  padding-top: 100px;

}

.top-license__head-person {
  position: absolute;
  z-index: 3;
  top: 180px;
  right: 0px;
  width: 104px;
}

.top-license__head-txt {
  position: absolute;
  z-index: 2;
  top: 40px;
  right: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  width: 170px;
  aspect-ratio: 254 / 216;
  padding-left: 8%;
  background: url(../img/top/license_fukidashi.webp) no-repeat center / contain;
}

img.top-license__head-txt__icon {
  display: inline-block;
  width: auto;
  /* ← width:100% を打ち消す */
  max-width: none;
  height: 1em;
  /* 文字サイズに合わせる */
  vertical-align: -0.15em;
  /* 微調整 */
  margin-left: 5px;
}

.top-license__head-graph__area {
  position: relative;
  width: 80%;
  aspect-ratio: 1 / 1;
  margin: 30px auto;
}

.top-license__head-graph {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
}

/* 円弧の長さ（dash）と割合（percent）を変数で管理 */
.top-license__head-graph {
  /* --r: 180; */
  /* --dash: 1130.973; */
  /* firefox対策 px 必要 */
  --dash: 1130.973px;
  /* 2 * PI * 180 = 約1130.973 */
  /* --percent: 0.92; */
  --percent: 0.89;
  /* 92% */
}

.top-license__head-graph .graph-bg,
.top-license__head-graph .graph-fg {
  fill: none;
  stroke-width: 75;
  /* 太さ（元のドーナツ太さに合わせて調整） */
  transform: rotate(-90deg);
  /* 開始位置を上に */
  transform-origin: 270px 270px;
}

.top-license__head-graph .graph-bg {
  stroke: #dfdcdd;
}

.top-license__head-graph .graph-fg {
  stroke: #fe91ac;
  stroke-linecap: round;
  stroke-dasharray: var(--dash);
  stroke-dashoffset: var(--dash);
  /* 初期：見えない */
  transition: stroke-dashoffset 2.6s cubic-bezier(0.33, 1, 0.68, 1);
  transition-delay: 0.4s;
  will-change: stroke-dashoffset;
}

/* .show で“描かれる” */
.top-license__head-graph.show .graph-fg {
  stroke-dashoffset: calc(var(--dash) * (1 - var(--percent)));
}

/* 動き苦手な人向け */
/* @media (prefers-reduced-motion: reduce) {
  .top-license__head-graph .graph-fg {
    transition: none;
  }
} */



.top-license__head-graph__num {
  position: absolute;
  z-index: 3;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 32%;
}

.top-license__head-car {
  position: absolute;
  z-index: 4;
  bottom: 0;
  left: 0;
  transform: translate(-5%, -28%);
  width: 150px;
}

.top-license__txt {
  margin-top: 35px;
}

.top-license__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  margin-top: 35px;
}

.top-license__item {
  border-radius: 15px;
  border: 3px solid #f7f7f7;
  padding: 25px 30px 30px;
}

.top-license__item-head {
  display: flex;
  align-items: center;
  gap: 25px;
}

.top-license__item-head__img {
  width: 100px;
}

.top-license__item-head__ttl {
  display: flex;
  flex-direction: column;

}

.top-license__item-head__txt {
  margin-top: 20px;
}

@media(max-width:450px) {
  .top-license__head-person {
    top: 170px;
    width: 104px;
  }

  .top-license__head-txt {
    width: 150px;
  }

  .top-license__head-car {
    transform: translate(-5%, -28%);
    width: 110px;
  }

  .top-license__item {
    padding: 20px 22px 25px;
  }

  .top-license__item-head {
    display: flex;
    align-items: center;
    gap: 20px;
  }

  .top-license__item-head__img {
    width: 70px;
  }
}


.top-work {
  position: relative;
  z-index: 4;
  background: #fff;
  border-radius: 0 0 50px 50px;
}

.top-work__head {
  position: relative;
}

.top-work__head-map {
  width: 95%;
  margin: 50px auto 0 0;
}

.top-work__head-lead {
  position: absolute;
  bottom: 11px;
  right: 0;
  width: 175px;
}

.top-work__ttl {
  margin-top: 25px;
}

.top-work__txt {
  margin-top: 45px;
}

.top-work__slider-area {
  margin-top: 40px;
}

.top-work__slider .swiper-wrapper {
  transition-timing-function: linear;
}

.top-work__slider .swiper-slide {
  width: fit-content;
  height: fit-content;
}

.top-work__slider-item {
  width: 360px;
  display: flex;
  flex-direction: column;
  gap: 13px;
}

.top-work__slider-item02 {
  width: 120px;
}

.top-work__slider-img {
  border-radius: 15px;
}

@media(max-width:450px) {
  .top-work__head-map {
    width: 95%;
    margin: 35px auto 0 0;
  }

  .top-work__head-lead {
    position: absolute;
    bottom: 11px;
    right: 0;
    width: 137px;
  }
}

.top-oneminutes {
  position: relative;
  z-index: 3;
  background: var(--cy);
  padding-top: 100px;
  padding-bottom: 110px;
  margin-top: -50px;
}

.top-oneminutes__list {
  position: relative;
  width: 100%;
  aspect-ratio: 750 / 1478;
  margin-top: 40px;
}

.top-oneminutes__item {
  position: absolute;
}

.top-oneminutes__item:nth-of-type(1) {
  z-index: 3;
  top: 2%;
  left: 0;
  width: 42%;
}

.top-oneminutes__item:nth-of-type(2) {
  z-index: 3;
  top: 2.2%;
  right: 0;
  width: 55.5%;
}

.top-oneminutes__item:nth-of-type(3) {
  position: relative;
  z-index: 2;
}

.top-oneminutes__item:nth-of-type(4) {
  z-index: 3;
  top: 38.5%;
  right: 0;
  width: 41%;
}

.top-oneminutes__item:nth-of-type(5) {
  z-index: 3;
  bottom: 0;
  left: 0;
  width: 39.5%;
}

.top-oneminutes__item:nth-of-type(6) {
  z-index: 3;
  bottom: 5.9%;
  right: 0;
  width: 57.7%;
}

.top-oneminutes__item-icon {
  position: absolute;
  width: 80px;
  height: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: url(../img/common/icon_fukidashi_r.webp) no-repeat center / contain;
}

.top-oneminutes__item-icon__img {
  width: 33%;
  transform: translate(-32%, -37%);
}

.top-oneminutes__item:nth-of-type(1) .top-oneminutes__item-icon {
  top: 12%;
  right: 38%;
  transform: translate(50%, -50%);
}

.top-oneminutes__item:nth-of-type(2) .top-oneminutes__item-icon {
  top: 8%;
  right: 15%;
  transform: translate(50%, -50%);
}

.top-oneminutes__item:nth-of-type(3) .top-oneminutes__item-icon {
  top: 49%;
  right: 44%;
  transform: translate(-50%, -50%);
}

.top-oneminutes__item:nth-of-type(3) .top-oneminutes__item-icon__img {
  width: 36%;
  transform: translate(-27%, -53%);
}

.top-oneminutes__item:nth-of-type(4) .top-oneminutes__item-icon {
  top: 8%;
  left: 17%;
  transform: translate(-50%, -50%);
  background: url(../img/common/icon_fukidashi_l.webp) no-repeat center / contain;
}

.top-oneminutes__item:nth-of-type(4) .top-oneminutes__item-icon__img {
  width: 32%;
  transform: translate(-32%, -37%);
}

.top-oneminutes__item:nth-of-type(5) .top-oneminutes__item-icon {
  top: 13%;
  right: 9%;
  transform: translate(50%, -50%);
}

.top-oneminutes__item:nth-of-type(5) .top-oneminutes__item-icon__img {
  width: 26%;
  transform: translate(-32%, -37%);
}


.top-oneminutes__item:nth-of-type(6) .top-oneminutes__item-icon {
  top: 13%;
  right: 15%;
  transform: translate(50%, -50%);
}

.top-oneminutes__item:nth-of-type(6) .top-oneminutes__item-icon__img {
  width: 30%;
  transform: translate(-32%, -37%);
}

@media(max-width:500px) {
  .top-oneminutes__item-icon {
    width: 70px;
    height: 70px;
  }
}

@media(max-width:400px) {
  .top-oneminutes__item:nth-of-type(2) .top-oneminutes__item-icon {
    top: 4%;
    right: 19%;
    transform: translate(50%, -50%);
  }

  .top-oneminutes__item:nth-of-type(6) .top-oneminutes__item-icon {
    top: 12%;
    right: 19%;
    transform: translate(50%, -50%);
  }

}

.top-benefits {
  position: relative;
  z-index: 4;
  border-radius: 50px 50px 0 0;
  margin-top: -50px;
}

.top-benefits__head {
  position: relative;
  border-radius: 50px 50px 0 0;
}

.top-benefits__head-img {
  border-radius: 50px 50px 0 0;
}

.top-benefits__head-ttl {
  position: absolute;
  bottom: 30px;
  left: 30px;
  align-items: start;
}

.top-benefits__head-txt {
  position: absolute;
  bottom: 30%;
  right: 13%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 30%;
  aspect-ratio: 254 / 216;
  padding-top: 20px;
  background: url(../img/top/benefits_fukidashi.webp) no-repeat center / contain;
}

.top-benefits__head-txt__icon {
  position: absolute;
  top: 20px;
  left: 50%;
  transform: translate(-50%, 0);
  width: 32px;
}

.top-benefits__head-person {
  position: absolute;
  bottom: -15px;
  right: 0;
  width: 32%;
}

.top-benefits__txt {
  margin-top: 50px;
}

.top-benefits__list {
  display: flex;
  flex-direction: column;
  gap: 25px;
  margin-top: 60px;
}

.top-benefits__item {
  position: relative;
  aspect-ratio: 650 / 280;
  border-radius: 15px;
}

.top-benefits__item:nth-of-type(1) {
  background: #29b591;
  box-shadow: 0 6px 0 #0d9471;
}

.top-benefits__item:nth-of-type(2) {
  background: #fe91ac;
  box-shadow: 0 6px 0 #e94a71;
}

.top-benefits__item:nth-of-type(3) {
  background: #00a8cb;
  box-shadow: 0 6px 0 #007c96;
}

.top-benefits__item:hover {
  opacity: .8;
  transition: all .3s ease-in-out;
}

.top-benefits__item:nth-of-type(1):active,
.top-benefits__item:nth-of-type(2):active,
.top-benefits__item:nth-of-type(3):active {
  box-shadow: none;
  transform: translateY(4px);
}

.top-benefits__item-ttl {
  position: absolute;
  z-index: 4;
  top: 50%;
  right: 0px;
  transform: translate(0, -50%);
  width: 67%;
  aspect-ratio: 1211 / 585;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  background: url(../img/top/benefits01_fukidashi.webp) no-repeat center / contain;
  padding-top: 15px;
}

.top-benefits__item:nth-of-type(2) .top-benefits__item-ttl {
  position: absolute;
  top: 50%;
  right: unset;
  left: 10px;
  transform: translate(0, -50%);
  background: url(../img/top/benefits02_fukidashi.webp) no-repeat center / contain;
}

.top-benefits__item:nth-of-type(3) .top-benefits__item-ttl {
  background: url(../img/top/benefits03_fukidashi.webp) no-repeat center / contain;

}

.top-benefits__item-ttl01 {
  line-height: 1.3;
}

.top-benefits__item-ttl03 {
  position: absolute;
  bottom: 0;
  left: 50%;
  transform: translate(-50%, -8%);
  color: #fff;
  border-radius: 25px;
  white-space: nowrap;
  padding: 6px 15px 4px;
}

.top-benefits__item:nth-of-type(1) .top-benefits__item-ttl03 {
  background: #008462;
}

.top-benefits__item:nth-of-type(2) .top-benefits__item-ttl03 {
  background: #ee5379;
}

.top-benefits__item:nth-of-type(3) .top-benefits__item-ttl03 {
  background: #0084c2;
}

.top-benefits__item-check {
  position: absolute;
  z-index: 5;
  top: -15px;
  right: -10px;
  width: 80px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.top-benefits__item:nth-of-type(2) .top-benefits__item-check {
  z-index: 5;
  top: -15px;
  right: unset;
  left: -10px;
}

.top-benefits__item-check__img {
  width: 100%;
  animation: rotate 10s linear infinite;
}

@keyframes rotate {
  0% {
    transform: rotate(0deg);
  }

  100% {
    transform: rotate(360deg);
  }
}

.top-benefits__item-check__txt {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 55%;
}

.top-benefits__item-img {
  position: absolute;
  z-index: 3;
  bottom: 0;
  left: 0;
  width: 47%;
}

.top-benefits__item:nth-of-type(2) .top-benefits__item-img {
  position: absolute;
  z-index: 3;
  bottom: 0;
  left: unset;
  right: 2%;
  width: 54.5%;
}

.top-benefits__item:nth-of-type(3) .top-benefits__item-img {
  position: absolute;
  z-index: 3;
  bottom: 0;
  left: -32px;
  width: 54.5%;
}

.top-benefits__item-bg {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: 100%;
}

.top-benefits__slider-area {
  position: absolute;
  z-index: 2;
  top: 0;
  left: 0;
  opacity: .1;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 70px;
  overflow: hidden;
}

.top-benefits__slider {
  overflow: hidden;
  width: 100%;
}

.loop-track {
  display: flex;
  white-space: nowrap;
  will-change: transform;
}

.loop-item {
  color: #fff;
  opacity: .1;
  flex: 0 0 auto;
  white-space: nowrap;
}


@media(max-width:450px) {
  .top-benefits__head-txt__icon {
    width: 25px;
  }

  .top-benefits__item-check {
    top: -15px;
    right: -5px;
    width: 70px;
  }

  .top-benefits__item:nth-of-type(2) .top-benefits__item-check {
    top: -15px;
    right: unset;
    left: -5px;
  }

  .top-benefits__item-ttl03 {
    padding: 4px 15px 2px;
    font-size: 1.3rem;
    transform: translate(-50%, -24%);
  }
}

@media(max-width:400px) {
  .top-benefits__item-ttl {
    width: 78%;
    padding-top: 15px;
  }
}

@media(max-width:370px) {
  .top-benefits__item-ttl {
    padding-top: 10px;
  }
}


.top-benefits__modal {
  position: fixed;
  z-index: 1200;
  top: 0;
  left: 0;
  width: 100%;
  height: 100dvh;
  display: none;
  background-color: #000000cc;
}

.top-benefits__modal.active {
  display: flex;
  align-items: center;
  justify-content: center;
}

.top-benefits__modal-list {
  width: 100%;
  max-width: 500px;

  height: 100vh;
  margin: 0 auto 0;
}

.top-benefits__modal-item {
  display: none;
  overflow: scroll;
  height: 100%;
  padding: 50px 0 70px;
}

.top-benefits__modal-item.active {
  display: block;
}

.top-benefits__modal-item__inner {
  width: 100%;
  height: fit-content;
  background-color: #fff;
  border-radius: 15px;
  padding-bottom: 30px;
  margin: 0 auto;
}

.top-benefits__modal-close {
  position: absolute;
  top: 17px;
  right: 22px;
  opacity: 1;
}

.top-benefits__modal-close:hover {
  cursor: pointer;
}

.top-benefits__modal-close::before,
.top-benefits__modal-close::after {
  position: absolute;
  content: '';
  top: 50%;
  left: -20px;
  background-color: #fff;
  height: 2px;
  width: 15px;
  border-radius: 3px;
}

.top-benefits__modal-close::before {
  transform: rotate(45deg) translate(-5%, -50%);
}

.top-benefits__modal-close::after {
  transform: rotate(-45deg) translate(5%, -50%);
}

/* モーダル中身 */

.top-benefits__modal-item__head {
  position: relative;
  aspect-ratio: 750 / 280;
  border-radius: 15px 15px 0 0;
}

.top-benefits__modal-item:nth-of-type(1) .top-benefits__modal-item__head {
  background: #29b591;
}

.top-benefits__modal-item:nth-of-type(2) .top-benefits__modal-item__head {
  background: #fe91ac;
}

.top-benefits__modal-item:nth-of-type(3) .top-benefits__modal-item__head {
  background: #00a8cb;
}

.top-benefits__modal-item .top-benefits__item-ttl {
  width: 58%;
}

.top-benefits__modal-item:nth-of-type(2) .top-benefits__item-ttl {
  position: absolute;
  top: 50%;
  right: unset;
  left: 10px;
  transform: translate(0, -50%);
  background: url(../img/top/benefits02_fukidashi.webp) no-repeat center / contain;
}

.top-benefits__modal-item:nth-of-type(3) .top-benefits__item-ttl {
  background: url(../img/top/benefits03_fukidashi.webp) no-repeat center / contain;

}

.top-benefits__modal-item:nth-of-type(2) .top-benefits__item-img {
  position: absolute;
  z-index: 3;
  bottom: 0;
  left: unset;
  right: 2%;
  width: 50%;
}

.top-benefits__modal-item__mess {
  margin-top: 30px;
}

/* 個別 */
.top-benefits__modal-item01__head-list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin: 30px auto;
}

.top-benefits__modal-item01__head-item {
  text-align: center;
  line-height: 1.2;
  padding: 30px 5px;
  border-radius: 15px;
  background: url(../img/top/benefits_modal_item01_bg.webp) no-repeat center / 70% #29b591;
}

.top-benefits__modal-item01__head-ttl {}

.top-benefits__modal-item01__head-txt01 {}

.top-benefits__modal-item01__head-item:nth-of-type(2) .top-benefits__modal-item01__head-txt01__02 {
  writing-mode: vertical-rl;
}

.top-benefits__modal-item01__head-txt02 {}


.top-benefits__modal-item01__cont-ttl {
  background: #e2faf4;
  border-radius: 15px;
  padding: 15px 0;
  margin-top: 40px;
}

.top-benefits__modal-item01__cont-dl {}

.top-benefits__modal-item01__cont-dt {
  border-bottom: 1px solid #dddddd;
  padding-bottom: 7px;
  margin-top: 40px;
}

.top-benefits__modal-item01__cont-dt:first-of-type {
  margin-top: 30px;
}

.top-benefits__modal-item01__cont-dt__tag {
  display: inline-block;
  background: var(--cgn);
  width: fit-content;
  border-radius: 20px;
  padding: 4px 15px 2px;
  margin-right: 10px;
}

.top-benefits__modal-item01__cont-dd {
  padding: 15px 0;
  border-bottom: 2px dotted #dddddd;
}

.top-benefits__modal-item01__cont-dd__list {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 5px;
  margin-top: 15px;
}

.top-benefits__modal-item01__cont-dd__item {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  line-height: 1.2;
  padding: 30px 5px;
  border-radius: 15px;
  background: var(--cgn);
  padding: 10px 15px;
}

.top-benefits__modal-item01__cont-dd__item-ttl {
  width: 100%;
  text-align: center;
  border-radius: 20px;
  background: #fff;
  padding: 6px 10px 2px;
  margin-bottom: 15px;
}

.top-benefits__modal-item01__cont-detail {
  margin-top: 30px;
}

.top-benefits__modal-item01__bottom {
  position: relative;
  background: #f7f7f7;
  border-radius: 15px;
  padding: 40px 25px 30px;
  margin-top: 50px;
}

.top-benefits__modal-item01__bottom-tag {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: fit-content;
  background: #000;
  border-radius: 30px;
  padding: 4px 20px 2px;
  margin: 0 auto;
}

.top-benefits__modal-item01__bottom-txt {
  margin-top: 17px;
}

@media(max-width:450px) {}

.top-benefits__modal-item02__top-img {
  border-radius: 15px;
  margin-top: 30px;
  margin-bottom: 20px;
}

.top-benefits__modal-item02__img-area {
  margin-top: 20px;
}

.top-benefits__modal-item02__cont {
  background: #f7f7f7;
  border-radius: 15px;
  padding: 40px 25px 30px;
}

.top-benefits__modal-item02__cont-txt01 {
  margin-top: 15px;
}

.top-benefits__modal-item02__cont-txt02 {
  margin-top: 15px;
}

@media(max-width:450px) {
  .top-benefits__modal-item01__head-txt02 {
    font-size: 1.6rem;
  }
}

.top-benefits__modal-item03__txt {
  margin-top: 40px;
}

.top-benefits__modal-item03__list {
  margin-top: 25px;
}

.top-benefits__modal-item03__item {
  display: flex;
  align-items: center;
  gap: 20px;
  padding: 25px 0;
  border-top: 2px dotted #ddd;
}

.top-benefits__modal-item03__item-icon__area {
  width: 110px;
  height: 110px;
  border-radius: 100vmax;
  background: #d9f8ff;
  display: flex;
  align-items: center;
  justify-content: center;
}

.top-benefits__modal-item03__item-icon {
  width: 30%;
}

.top-benefits__modal-item03__item-cont {
  width: calc(100% - 130px);
}

.top-benefits__modal-item03__item-txt {
  margin-top: 10px;
}

@media(max-width:450px) {}

.top-follow {
  position: relative;
  z-index: 2;
  background: url(../img/top/follow_bg.webp) no-repeat center bottom / contain;
  padding-bottom: 100px;
  margin-top: -50px;
}

.top-follow__head-person {
  position: absolute;
  z-index: 3;
  top: 358px;
  left: 0px;
  width: 104px;
}

.top-follow__head-txt {
  position: absolute;
  z-index: 2;
  top: 326px;
  left: 58px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  width: 170px;
  aspect-ratio: 254 / 216;
  background: url(../img/top/follow_fukidashi.webp) no-repeat center / contain;
}

.top-follow__head-txt__icon {
  position: absolute;
  bottom: 13px;
  right: 14px;
  width: 33px;
}

.top-follow__inner {
  padding-top: 80px;
}

.top-follow__txt {
  margin: 40px auto 80px;
}

.top-follow__list {
  display: flex;
  flex-direction: column;
  gap: 80px;
}

.top-follow__item-img__area {
  position: relative;
}

.top-follow__item-img {
  border-radius: 135px;
}

.top-follow__item-mess {
  position: absolute;
  bottom: 10px;
  left: -4px;
  display: flex;
  flex-direction: column;
}

.top-follow__item:nth-of-type(3) .top-follow__item-mess {
  position: absolute;
  bottom: 0px;
  left: -4px;
}

.top-follow__item-mess01,
.top-follow__item-mess02 {
  width: fit-content;
  transform: rotate(-5deg);
  border-radius: 5px;
  color: #fff;
  background: var(--cbl);
  padding: 7px 15px 5px;
}

.top-follow__item-mess02 {
  margin-top: -3px;
  margin-left: 75px;
}

.top-follow__item:nth-of-type(3) .top-follow__item-mess02 {
  margin-top: -4px;
  margin-left: 140px;
}

.top-follow__item-txt {
  margin-top: 30px;
}

@media(max-width:470px) {
  .top-follow__head-person {
    top: 60vw;
    left: 0px;
    width: 104px;
  }

  .top-follow__head-txt {
    top: 65vw;
    left: 90px;
    width: 150px;
  }
}

@media(max-width:430px) {}


.top-follow__bottom {
  position: relative;
  border-radius: 15px;
  background: url(../img/top/follow_bottom.webp) no-repeat center bottom / cover;
  padding: 45px 30px 160px;
  margin-top: 100px;
}

.top-follow__bottom-lead {
  position: absolute;
  bottom: -30px;
  right: -32px;
  width: 160px;
}

.top-follow__bottom-txt {
  margin-top: 25px;
}

@media(max-width:485px) {
  .top-follow__bottom-lead {
    bottom: -30px;
    right: -5%;
    width: 160px;
  }

}

.top-oneday__head {
  position: relative;
}

.top-oneday__ttl {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 80%;
}

.top-oneday__txt {
  margin-top: 40px;
}

.top-oneday__list-area {
  position: relative;
}

.top-oneday__list-area::after {
  content: '';
  position: absolute;
  z-index: 2;
  top: 0;
  left: 30px;
  width: 1px;
  height: 100%;
  border-left: 6px dotted var(--cy);
}

.top-oneday__list {
  position: relative;
  z-index: 3;
  display: flex;
  flex-direction: column;
  gap: 80px;
  margin-top: 50px;
}

.top-oneday__item-img__area {
  position: relative;
}

.top-oneday__item-img {
  border-radius: 15px;
}

.top-oneday__item-mess {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -50%);
  width: fit-content;
  background: var(--cy);
  border-radius: 30px;
  padding: 10px 25px 8px;
}

.top-oneday__item-txt {
  padding: 30px 0 0 70px;
}

@media(max-width:450px) {}

.top-tiktok {
  width: 100%;
  aspect-ratio: 750 / 1020;
  background: url(../img/top/tiktok_bg.webp) no-repeat center / cover;
  border-radius: 50px;
}

.top-tiktok__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
}

.top-tiktok__ttl-icon {
  width: 20%;
  margin: 35px auto 20px;
}

.top-tiktok__ttl {
  width: 65%;
}

.top-tiktok__txt01 {
  margin-top: 25px;
  margin-bottom: 15px;
}

.top-tiktok__txt02 {
  margin-top: 30px;
  margin-bottom: 15px;
}

.top-tiktok__btn {
  background: #ee1d52;
  box-shadow: 0 4px 0 #c00b39;
}

.top-tiktok__sns-list {
  display: flex;
  gap: 8px;
}

.top-tiktok__sns-item__img {
  width: 50px;
}

.top-tiktok__sns-item__link {}

@media(max-width:400px) {
  .top-tiktok__btn {
    height: 68px;
    line-height: 70px;
  }
}

.top-voice {
  position: relative;
  z-index: 2;
  background: var(--cy);
}

.top-voice::before {
  content: '';
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: var(--cw);
  border-radius: 0 0 50px 50px;
}

.top-voice__txt {
  margin-top: 40px;
}

.top-voice__item {
  margin-top: 60px;
}

.top-voice__item:first-of-type {
  margin-top: 40px;
}

.top-voice__item-head {
  display: flex;
  align-items: center;
  gap: 20px;
}

.top-voice__item:nth-of-type(even) .top-voice__item-head {
  flex-direction: row-reverse;
}

.top-voice__item:nth-of-type(even) .top-voice__item-head__main {
  text-align: end;
}

.top-voice__item-img {
  width: 100px;
}

.top-voice__item-head__main {
  width: calc(100% - 120px);
}

.top-voice__item-head__data {
  color: #b0b0b0;
}

.top-voice__item-cont {
  margin: 25px 0 0 auto;
  width: 92%;
  aspect-ratio: 61 / 45;
  background: url(../img/top/voice_fukidashi_right.webp) no-repeat center / contain;
  padding: 40px 40px 30px 70px;
}

.top-voice__item:nth-of-type(even) .top-voice__item-cont {
  margin: 25px auto 0 0;
  background: url(../img/top/voice_fukidashi_left.webp) no-repeat center / contain;
  padding: 40px 70px 30px 40px;
}

.top-voice__item-cont__txt {
  line-height: 1.66;
}

.top-voice__item-cont__icon-area {
  display: flex;
  gap: 8px;
  margin-top: 15px;
}

.top-voice__item-cont__icon-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 48px;
  height: 48px;
  border-radius: 100vmax;
  background: #fff;
}

.top-voice__item-cont__icon {
  width: 45%;
}

@media(max-width:450px) {
  .top-voice__item-head {
    gap: 15px;
  }

  .top-voice__item-img {
    width: 90px;
  }

  .top-voice__item-head__main {
    width: calc(100% - 105px);
  }

  .top-voice__item-cont {
    width: 95%;
    /* aspect-ratio: 380 / 281; */
    padding: 30px 25px 23px 50px;
  }

  .top-voice__item:nth-of-type(even) .top-voice__item-cont {
    width: 95%;
    padding: 30px 50px 23px 25px;
  }

  .top-voice__item-cont__txt {
    font-size: 1.7rem;
  }
}

@media(max-width:400px) {
  .top-voice__item {
    margin-top: 45px;
  }

  .top-voice__item-head__data {
    font-size: 1.2rem;
  }

  .top-voice__item-cont {
    margin: 10px 0 0 auto;
  }

  .top-voice__item:nth-of-type(even) .top-voice__item-cont {
    margin: 10px auto 0 0;
  }

  .top-voice__item-cont__txt {
    font-size: 1.6rem;
  }

  .top-voice__item-cont__icon-area {
    margin-top: 10px;
  }
}

@media(max-width:370px) {
  .top-voice__item-head__data {
    font-size: 1.15rem;
  }
}

.top-flow {
  position: relative;
  z-index: 4;
  padding-bottom: 90px;
  background: var(--cy);
}

.top-flow__inner {
  position: relative;
  padding-top: 60px;
}

.top-flow__circle {
  position: absolute;
  z-index: 10;
  top: 0;
  right: 0;
  transform: translate(0, -30%);
  background: url(../img/common/circle_gn_r.webp) no-repeat center / contain;
}

.top-flow__list-area {
  overflow: scroll;
  margin-top: 25px;
}

.top-flow__list {
  width: 1370px;
  display: flex;
  gap: 30px;
  padding: 15px 35px;
}

.top-flow__item {
  width: 320px;
  background: #fff;
  border-radius: 15px;
}

.top-flow__item-img__area {
  position: relative;
  border-radius: 15px 15px 0 0;
}

.top-flow__item-img {
  border-radius: 15px 15px 0 0;
}

.top-flow__item-icon {
  position: absolute;
  top: -10px;
  left: -10px;
  width: 90px;
  height: 90px;
  padding-right: 6%;
  padding-bottom: 7%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: url(../img/common/icon_fukidashi_l.webp) no-repeat center / contain;
}

.top-flow__item-icon__img {
  width: 40%;
}

.top-flow__item:nth-of-type(1) .top-flow__item-icon__img {
  width: 30%;
}

.top-flow__item-ttl {
  position: absolute;
  bottom: 20px;
  left: 50%;
  transform: translate(-50%, 0);
  white-space: nowrap;
  background: #000;
  color: var(--cw);
  height: 42px;
  line-height: 44px;
  border-radius: 32px;
  padding: 0 20px;
}

.top-flow__item-main {
  padding: 20px 35px 35px;
}

.top-flow__item-txt {
  color: var(--cbk5);
}

.top-flow__item-btn {
  height: 50px;
  line-height: 52px;
  border-radius: 15px;
  margin-top: 20px;
}

@media(max-width: 500px) {}

@media(max-width: 450px) {
  .top-flow__circle {
    width: 160px;
  }
}

@media(max-width: 400px) {
  .top-flow__circle {
    width: 150px;
  }
}


.top-faq {
  position: relative;
  z-index: 5;
  background: #fff;
  border-radius: 50px 50px 0 0;
  margin-top: -50px;
}

.top-faq__dl {
  margin-top: 50px;
}

.top-faq__btn {
  position: absolute;
  top: 50%;
  right: 20px;
  transform: translate(0, -50%);
  width: 30px;
  height: 30px;
  border-radius: 50%;
}

.top-faq__btn-cont {
  position: relative;
  width: 100%;
  height: 100%;
}

.top-faq__btn-cont::after {
  font-size: 2.4rem;
  color: var(--cgn);
  content: '\e316';
  font-family: "Material Symbols Outlined";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(180deg);
  transition: all .3s linear;
}

.top-faq__cont.qa_open .top-faq__btn-cont::after {
  transform: translate(-50%, -50%) rotate(0);
}

.top-faq__cont {
  border-radius: 10px;
  background: #f7f7f7;
}

.top-faq__cont:not(:first-of-type) {
  margin-top: 20px;
}

.top-faq__dt,
.top-faq__dd {
  position: relative;
}

.top-faq__dt {
  display: flex;
  align-items: center;
  justify-content: space-between;
  line-height: 1.4;
  padding: 30px 50px 30px 90px;
}

.top-faq__dd {
  display: none;
  color: var(--cbk5);
  padding: 40px 30px 40px;
  border-top: 4px dotted #dddddd;
}

.top-faq__cont.qa_open .top-faq__dd {
  display: block;
}

.top-faq__dt::before {
  content: 'Q';
  z-index: 3;
  position: absolute;
  top: 50%;
  left: 22px;
  width: 50px;
  height: 50px;
  border-radius: 100vmax;
  transform: translate(0, -55%);
  font-family: var(--en);
  font-size: 2.6rem;
  font-weight: 700;
  color: var(--cw);
  background: var(--cgn);
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-bottom: 3px;
}

.top-faq__dd-txt01 {
  color: var(--cgn);
}

.top-faq__dd-txt02 {
  margin-top: 20px;
  font-weight: 500;
}

@media(max-width: 450px) {}


.top-requirements {}

.top-requirements__dl {
  display: flex;
  flex-wrap: wrap;
  background-color: #f7f7f7;
  border-radius: 10px;
  padding: 15px 0;
  margin-top: 35px;
}

.top-requirements__dt {
  width: 100%;
  color: var(--cgn);
  padding: 20px 30px 0px;
}

.top-requirements__dd {
  width: 100%;
  color: var(--cbk5);
  line-height: 1.5;
  font-weight: 500;
  border-bottom: 4px dotted #dddddd;
  padding: 4px 30px 20px;
}

.top-requirements__dd:last-of-type {
  border-bottom: none;
  padding-bottom: 0;
  margin-bottom: 0;
}

@media(max-width: 500px) {}


.footer-sp {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 60px;
  z-index: 400;
  display: none;
}

.footer-sp__list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  height: 100%;
}

.footer-sp__item-link {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}

.footer-sp__tel .footer-sp__item-link {
  background: #000;
}

.footer-sp__web .footer-sp__item-link {
  background: #0066ff;
}

.footer-sp__line .footer-sp__item-link {
  background: #06c755;
  gap: 5px;
}

.footer-sp__line-txt01 {
  background: #000;
  line-height: 1.2;
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
}

.footer-sp__line-txt02 {
  line-height: 1.2;
  text-align: center;
}

@media(max-width: 1200px) {
  .footer-sp {
    display: block;
    transform: translate(0, 105%);
    opacity: 0;
    transition: all .3s ease-in-out;
  }

  .footer-sp.active {
    opacity: 1;
    bottom: 0;
    transform: translate(0, 0);
  }
}

.under-main {
  background: url(../img/common/bg_yellow.webp) no-repeat center / cover;
}

.under-fv {
  width: 100%;
  aspect-ratio: 750 / 470;
}

.under-fv__inner {
  height: 100%;
}

.under-fv__ttl-wrap {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  padding-top: 30px;
  height: 100%;
}

.under-footer {
  padding: 70px 0 80px;
}

.under-footer__txt {
  text-align: center;
}

@media(max-width:1200px) {
.under-footer {
  padding: 70px 0 120px;
}
}

/* コンタクト */
.contact__content {
  position: relative;
  padding: 5rem 0 5.5rem;
}

.contact-thanks__content {
  position: relative;
  padding: 5rem 0 7rem;
}

.contact-error__content {
  position: relative;
  padding: 5rem 0;
}

.contact__content::before ,
.contact-thanks__content::before ,
.contact-error__content::before {
  content: '';
  position: absolute;
  z-index: -1;
  top: 0;
  left: 3%;
  width: 94%;
  height: 100%;
  background: #fff;
  border-radius: 40px;
}

.contact__thanks-icon {
  text-align: center;
}

.contact__thanks-icon .material-symbols-outlined {
  font-size: 10rem;
  font-weight: 300;
  line-height: 1;
  color: #0066ff;
  text-align: center;
}

.contact__thanks-mess {
  color: #0066ff;
  text-align: center;
}

.contact-thanks .contact__title {
  margin: 5rem auto 2.5rem;
}

.contact__button {
  color: #0066ff;
  display: block;
  width: fit-content;
  margin: 5.5rem auto 0;
}


/* Safari */
_::-webkit-full-page-media,
_:future,
:root .top-support__item-item__item::before {
  left: 0.9em;
}