@charset "utf-8";
.wrapper { width: 100% ; margin: 0; overflow-x: hidden; padding-top: 4.8rem;  }

@media screen and (max-width: 900px) {
  .wrapper { padding-top: 4rem; }
}

.contents_wrap { width: 90%; max-width: 1200px; margin: 0 auto; }
.contents_wrap_s { width: 90%; max-width: 780px; margin: 0 auto; }

.box-section { padding: 80px 0 100px; margin-top: -20px;  }
.box-section-t { padding-top: 80px; }


@media screen and (max-width: 900px) {
  
  .box-section { padding: 5em 0 4rem; margin-top: -1rem;  }
  .box-section-t { padding-top: 4rem; }
  .box-section-s { padding: 3rem 0; }
  .box-section-s-t { padding-top: 3rem; }
}

.header { border-bottom: 5px solid #0078C9; background: #FFF; padding: .5em 0; position: fixed; top: 0; left: 0; right: 0; widows: 100%; z-index: 9999; box-shadow: 0 3px 6px rgba(46, 16,16, .11); }
.header .inner { display: flex; justify-content: space-between; align-items: center; }
.gNav > li { display: inline-block; font-weight: bold; font-size: .8135rem; }
.gNav > li + li { margin-left: 1.5em; }

.btn-humberger { display: none; }

@media screen and (max-width: 900px) {
  .header .inner { height: 3rem; }
  .header .logo { width: 120px; height: auto; }
  .gNav { display: none; z-index: 998; }
  
  .btn-humberger { display: block; width: 4rem; height: 4rem; display: block; position: fixed; top: 0; right: 0; margin: auto; text-indent: 100%; padding: 0; border: none; background: none; white-space: nowrap; overflow: hidden; z-index: 999; }
  .btn-humberger::before,
  .btn-humberger::after { content: '';  width: 2rem; height: 2px; display: block; background: #222; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; transition: transform .3s; }
  .btn-humberger::before { transform: translateY(-.5em); box-shadow: 0 .5em 0 #222;}
  .btn-humberger::after { transform: translateY(.5em); }
  .btn-humberger.open::before { transform: rotate(-45deg); box-shadow: none;}
  .btn-humberger.open::after { transform: rotate(45deg); }
  
  .gNav.open { display: block; position: fixed; top: 0; left: 0; right: 0; bottom: 0; margin: auto; background: #FFF; padding: 5rem 5%; color: #222; }
  .gNav > li { display: block; text-align: center; }
  .gNav > li + li { margin-left: 0; margin-top: 1em; }
}

.fixed-cv { position: fixed; top: 6rem; right: 0;  margin: auto; color: #FFF; }
.fixed-cv > a,
.fixed-cv > p { -ms-writing-mode: tb-rl; -webkit-writing-mode: vertical-rl; writing-mode: vertical-rl; display: block; padding: 1em 0; font-weight: 900; font-size: 1.8rem; line-height: 300%;  width: 3em; border-radius: 3px; border: 1px solid #FFF; letter-spacing: .03em; }
.fixed-cv > a img { display: inline-block; vertical-align: baseline; margin: .5em auto 0;  width: 1.5em; height: 1.5em; object-fit: contain; }
.fixed-cv .mail { background: #F45799; }
.fixed-cv .line { background: #06C755; }

.fixed-cv .support { background: #FFF; color: #000; font-size: .8rem; width: 100%; line-height: 1.5; padding: 2em .5em; display: flex; align-items: center; justify-content: center; }

@media screen and (max-width: 1500px ){
  .fixed-cv > a  { font-size: 1.5rem; }
}

@media screen and (max-width: 1200px ){
  .fixed-cv > a  { font-size: 1.2rem; }
}
@media screen and (max-width: 900px ){
  .fixed-cv  { left: 0; top: auto; bottom: 0; display: flex; }
  .fixed-cv > a,
  .fixed-cv > p { width: 50%; padding-bottom: env(safe-area-inset-bottom);-ms-writing-mode: lr-tb; -webkit-writing-mode: horizontal-tb; writing-mode: horizontal-tb; text-align: center; padding: 0 1em; }
  
  .fixed-cv > a img { margin: -.2em 0 0 .5em; vertical-align: middle; }
  .fixed-cv .support { width: 50%; line-height: 1.2; display: flex; align-items: center ;justify-content: center; padding: 0 1em;  }
}

@media screen and (max-width: 600px ){
  .fixed-cv > a  { font-size: 1rem; }
  .fixed-cv > a img { width: auto; height: 1.2em; }
  .fixed-cv .support { font-size: .625rem; }
}


.footer { background: #0078C9; color: #FFF; font-size: .875rem; padding: 2rem 0;  }
.footer .inner { display: flex; flex-wrap: wrap; justify-content: space-between; }
.footer .info br { display: none; }
.copyright { font-size: .6rem; }

@media screen and (max-width: 900px ){
  .footer { padding-bottom: 7rem; }
  .footer .info br { display: inline; }
  .copyright { width: 100%; marign-top: 3em; }
}



/*contnets*/
img { max-width: 100%; height: auto; }
.title-section { font-size: 3.4375rem; font-weight: 900; text-align: center; line-height: 120%; color: #0A53A9; margin-bottom: 1em;  }
.title-section span { display: block; font-size: 1rem; font-family: 'Roboto', sans-serif; font-weight: 900; line-height: 150%; color: #0078C9; margin-top: 1em;  }

.bg-blue .title-section { color: #FCE800; }
.bg-blue .title-section span { color: #FFF; }

.bg-blue { background: #0078C9; }


@media screen and (max-width: 900px ){
  .title-section { font-size: 2.5rem; }
}
@media screen and (max-width: 600px ){
  .title-section { font-size: 1.5rem; }
}

/*main*/
.mainvisual { background-image: linear-gradient(120deg, transparent 75%, #FCE800 75%), url("../img/main-bg.jpg"); background-size: 100% 100%, cover; background-position: left top , center center; padding: 5rem 0 4rem; }
.conts-main { display: flex; justify-content: space-between; align-items: flex-end; }
.conts-main .text { width: 60%; position: relative; }
.conts-main .maincopy { position: relative; z-index: 2; }
.conts-main .maincopy img { width: 90%; margin: 0 auto; display: block;}
.conts-main .text .doc { width: 270px; height: 270px; position: absolute; top: -4rem; left: 76%; background: #FCE800; border-radius: 50%; text-align: center ;  font-size: 2.2rem; font-weight: 900; padding-top: .2em;  }
.conts-main .text .doc img { display: block; margin: 0 auto -1rem;  }
.conts-main .text .doc span { display: block; font-size: 1rem; }

.conts-main .img { width: 40%; position: relative; }
.conts-main .img img { width: 100%; }
.conts-main .img .name { position: absolute; right: .5em; bottom: .5em; color: #FFF; font-size: 2rem; font-weight: bold; text-align: center; line-height: 130%; }
.conts-main .img .name span { display: block; font-size: .3em; line-height: 180%;  }

.conts-main .img .free { position: absolute; right: 0; bottom: 90%; margin: auto; transform-origin: left bottom; transform: rotate(30deg); font-weight: bold; font-size: 1.25rem; font-weight: 900; line-height: 200%; }
.conts-main .img .free span { border-bottom: 3px solid #0078C9; }
.conts-main .img .free span:first-of-type { color: #F45799; border-bottom-color: #F45799; }

.main-contact { display: flex; justify-content: space-between; margin-top: 1rem;  }
.main-contact > a { width: 49%; text-align: center; font-weight: 900; font-size: 1.6rem; color: #FFF; padding: 1em 0; border-radius: 2em;  }
.main-contact > a img { display: inline-block; margin-left: .5em; vertical-align: middle; }
.main-contact .mail { background: #F45799; }
.main-contact .line { background: #06C755; }
.main-contact .support { font-size: 1.7rem; font-weight: bold;  color: #F45799; }
@media screen and (max-width: 1300px) {
  .conts-main .text .doc { width: 20vw; height: 20vw; font-size: 2.2vw;  }
  .conts-main .text .doc img { width: 65%; height: auto; }
  
  .main-contact .support { font-size: 1.5rem;}
}
@media screen and (max-width: 1200px) {
  .main-contact > a { font-size: 1rem; }
  .conts-main .img .free { font-size: 1.125rem; }
  .main-contact .support { font-size: 1.3rem; }
}
@media screen and (max-width: 900px) {
  
  .conts-main  { flex-wrap: wrap; }
  .conts-main .text { width: 100%;} 
  .conts-main .text .doc { width: 25vw; height: 25vw; font-size: 3vw; left: auto; right: -2vw; }
  .conts-main .text .doc img{ width: 75%; }
  .conts-main .text .doc span { display: none; }
  .conts-main .img  { width: 80%; max-width: 400px; margin: 2rem auto 0; }
  .conts-main .img .free { top: 0; bottom: auto; right: -60px; }
  .conts-main .img .name { font-size: 3vw; }

}
@media screen and (max-width: 600px) {
  .conts-main .img .free { right: -20%; left: auto; }
  .conts-main .img { width: 80%; margin: 2rem auto 0 0 ; }
  .conts-main .text .doc { font-size: 1rem; }
  .main-contact { flex-wrap: wrap ; }
  .main-contact > a { width: 80%; margin: 0.5em auto 0; padding: .5em; }
  .main-contact img { width: auto; height: 1.2em; }
  .main-contact .support { font-size: 1rem;padding: 0 20px;box-sizing:border-box;line-height:1.2;}
}

/*trouble*/
.conts-trouble { position: relative; }
.conts-trouble::before { content: 'Trouble'; font-size: 25rem; color: #FFF; opacity: .13; position: absolute; left: 0; right: 0; bottom: 15%; margin: auto; text-align: center; line-height: 100%; font-family: 'Roboto', sans-serif; font-weight: 900; }

.list-trouble { display: flex; flex-wrap: wrap; justify-content: center; background: url("../img/trouble.svg") no-repeat center 30% / 20% auto;  }
.list-trouble > li { width: 240px; height: 240px; display: flex; flex-direction: column; align-items: center; justify-content: center; position: relative; color: #FFF; text-align: center; line-height: 150%; font-size: 1.25rem;  }
.list-trouble > li::before { content: ''; width: 100%; height: 100%; display: block; background: url("../img/speech.svg") no-repeat center center/ contain; position: absolute; left: 0; right: 0; bottom: 0; top: 0; margin: auto; }

.list-trouble > li:nth-child(1),
.list-trouble > li:nth-child(4) { margin-top: 150px; }
.list-trouble > li:nth-child(3) { margin-left: 10%; } 
.list-trouble > li:nth-child(6) { margin: 150px 5% 0; } 


.list-trouble > li:nth-child(1)::before { transform: rotate(-10deg); }
.list-trouble > li:nth-child(2)::before {  }
.list-trouble > li:nth-child(3)::before { transform: scaleX(-1); }
.list-trouble > li:nth-child(4)::before { transform: scaleX(-1) rotate(-10deg); }
.list-trouble > li:nth-child(5)::before { transform: rotate(250deg); }
.list-trouble > li:nth-child(6)::before { transform: scaleX(-1) rotate(200deg); }
.list-trouble > li:nth-child(7)::before { transform: scaleX(-1) rotate(270deg); }

@media screen and (max-width: 1200px) {
  .conts-trouble::before  { font-size: 25vw; }
  .list-trouble > li { width: 20vw; height: 20vw; font-size: 1.5vw; }
  .list-trouble > li:nth-child(1),
  .list-trouble > li:nth-child(4) { margin-top: 10vw; }
  .list-trouble > li:nth-child(6) { margin: 10vw 5% 0; } 
}
@media screen and (max-width: 600px) {
  .list-trouble { background-position: center 40%; background-size: 35% auto;  }
  .list-trouble > li { width: 30vw; height: 30vw; font-size: 2vw; }
  .list-trouble > li:nth-child(1) { margin-top: 30vw;  }
  .list-trouble > li:nth-child(2) { margin-left: -16vw; }
  .list-trouble > li:nth-child(3) { margin-left: 2vw; }
  .list-trouble > li:nth-child(4) { margin-left: -16vw; margin-top: 30vw; }
  .list-trouble > li:nth-child(5) { margin:  1rem 0 0 0; } 
  .list-trouble > li:nth-child(6) { margin: 20vw 0 0;} 
  .list-trouble > li:nth-child(7) { margin: 1rem 0 0;} 
}


/*feature*/
.conts-features { background: rgba(0, 120,201, .09); }
.list-features { display: flex; flex-wrap: wrap; justify-content: space-between; counter-reset: listnum;  }
.list-features > li { width: 48%; background: #FFF; margin-top: 3rem; position: relative; counter-increment: listnum;  padding: 3rem; }
.list-features > li:nth-child(n + 3) { margin-top: 6rem; }
.list-features .num { width: 6rem;height: 6rem; display: block; position: absolute; left: 1rem; top: -3rem; border-radius: 50%; background: linear-gradient(#1C7AE6, #00509D); color: #FFF; text-align: center; padding: .6em 0; }
.list-features .num::after { content: counter(listnum, decimal-leading-zero); font-size: 3rem; font-family: 'Roboto', sans-serif; font-weight: 900;  display: block; line-height: 90%; }

.list-features .title { font-size: 4rem; color: #0A53A9; text-align: center; display: flex; align-items: center; justify-content: center; width: 250px; height: 250px; border-radius: 50%; background: #E7F2FA; font-weight: 900; line-height: 120%; }
.list-features .title.small { font-size: 3rem; }

.list-features img { width: auto; height: 260px;  position: absolute; right: 3rem; top: 3rem; margin: auto; }

.list-features .desc { text-align: center; font-weight: bold; font-size: 1.6rem; margin-top: 1em;  }
.marker { background:  linear-gradient(transparent 70%, #FCE800 70%); }

@media screen and (max-width: 1300px) {
  .list-features .title { font-size: 4vw;  width: 20vw; height: 20vw; }
  .list-features .title.small { font-size: 3vw; }
  .list-features img { height: 20vw; }
  .list-features .desc { font-size: 1.3rem; }
  
}
@media screen and (max-width: 900px) {
  .list-features > li { padding: 3rem 1.5rem; }
  .list-features .desc { font-size: 1.125rem; }
  .list-features .num { width: 5rem; height: 5rem; top: -2.5rem; }
  .list-features .num::after { font-size: 2rem; }
}
@media screen and (max-width: 600px) {
  .list-features > li { width: 100%; }
  .list-features > li:nth-child(n + 2) { margin-top: 4rem; }
  .list-features .title { font-size: 8vw;  width: 40vw; height: 40vw; }
  .list-features .title.small { font-size: 6vw; }
  .list-features img { height: 40vw; }
}
/*case*/
.conts-case { background: linear-gradient(-240deg, transparent 20%, rgba(252,232,0,.05) 20%);}
.list-case { counter-reset: listnum; }
.list-case > li { display: flex; justify-content: space-between; counter-increment: listnum; align-items: flex-start; }
.list-case > li + li { margin-top: 50px; }
.list-case > li:nth-child(2n) { padding-left: 80px; }
.list-case .img { width: 256px; height: 256px; border: 5px solid #0078C9; border-radius: 50%; }
.list-case .text { width: calc(100% - 330px);  padding-top: 1em; position: relative; }
.list-case .num { color: #AFA100; opacity: .13; font-size: 2.3rem; font-weight: 900; font-family: 'Roboto', sans-serif;  text-align: center; display: table; position: absolute; right: 100%; top: -1em; margin-right: -.7em; z-index: -1
; }
.list-case .num::after { content: counter(listnum, decimal-leading-zero); font-size: 3.5em; line-height: 100%;  display: block; }

.list-case .title { font-weight: 900; font-size: 1.125rem; color: #0A53A9; margin-bottom: 2em;}
.list-case .title .sub { display: block; }
.list-case .title .main { font-size: 2rem; line-height: 150%; background: linear-gradient(transparent 70%, #FCE800 70%);}

@media screen and (max-width: 1000px) {
  .list-case .img { width: 25vw; height: 25vw; }
  .list-case .text { width: calc(100% - 28vw); }
  
  .list-case .num { font-size: 1.5rem; top: -2em; }
}
@media screen and (max-width: 900px) {
  .list-case .title .main { font-size: 1.5rem;  }
  .list-case > li:nth-child(2n) { padding-left: 5%; }
}
@media screen and (max-width: 600px) {
  .list-case .num { font-size: 1rem; top: -3em; line-height: 150%; }
}


/*voice*/
.conts-voice {position: relative; }
.conts-voice::before { content: 'Voice'; font-size: 19rem; font-weight: 900; font-family: 'Roboto', sans-serif; line-height: 100%; position: absolute; top: 1rem; left: 0; right: 0; margin: auto; opacity: .13; color: #FFF;  text-align: center; }
.list-voice { display: flex; justify-content: space-between; flex-wrap: wrap; position: relative; z-index: 2; }
.list-voice > li { width: 48%; border: 5px solid #F25A99; background: #FFF;  padding: 1.5rem; }
.list-voice .title { color: #0A53A9; text-align: center; font-weight: bold; }
.list-voice .info { font-size: .75rem; text-align: center; }
.list-voice img { display: block; margin: .5em 0 1em; }
.list-voice > li:nth-child(n + 3) { margin-top: 2.5rem; }


@media screen and (max-width: 900px ){
  .conts-voice::before { font-size: 20vw; }
}
@media screen and (max-width: 600px ){
  .list-voice > li { width: 100%; } 
  .list-voice > li:nth-child(n + 2) { margin-top: 1.5rem; }
}

/*strength*/
.conts-strength { background: linear-gradient(-120deg, transparent 60%, rgba(252,232,0,.05) 60%); }
.list-strength { display: flex; flex-wrap: wrap; justify-content: space-between; max-width: 830px; margin: 0 auto; counter-reset: listnum; position: relative; }

.list-strength::before { content: ''; width: 100%; height: calc(100% + 120px); display: block; background: url("../img/strength1.svg") no-repeat top right/ auto 90%; position: absolute; top: -80px; right: 100%; margin: auto; }
.list-strength::after {content: ''; width: 100%; height: calc(100% + 120px); display: block; background: url("../img/strength2.svg") no-repeat top left/ auto 100%; position: absolute; top: -100px; left: 100%; margin: auto; }

.list-strength > li { width: 45%; text-align: center; counter-increment: listnum; font-size: 3rem; font-weight: 900; color: #0078C9; line-height: 120%; }
.list-strength > li:nth-child(n + 3) { margin-top: 1.5em; }
.list-strength > li::before { content: counter(listnum, decimal-leading-zero); font-size: 3em; color: #F45799; opacity: .13; display:block; font-family: 'Roboto', sans-serif; margin-bottom: -.1em; }
.list-strength .sub { display: block; font-size: 1.125rem;color: #222; font-weight: bold; line-height: 130%; }
.list-strength .marker { background-image: linear-gradient(transparent 80%, #FCE800 80%); }

@media screen and (max-width: 1500px ){
  .list-strength { width: 70%; }
  .list-strength > li { width: 48%;  font-size: 3vw; }
  .list-strength .sub { font-size: 1rem; }
}
@media screen and (max-width: 1300px ){
  .list-strength::before { height: 100%;  }
  .list-strength::after { height: 100%; top: auto; bottom: 0; }
}
@media screen and (max-width: 600px ){
  .list-strength { width: 100%; }
  .list-strength > li { width: 70%; font-size: 5vw; position: relative; z-index: 2; }
  .list-strength > li + li { margin-top: 3rem; }
  .list-strength > li:nth-child(-n + 2) { margin-left: auto; }
  .list-strength::before { width: 40%; top: -1rem;  left: 0; right: auto; height: 50%;  }
  .list-strength::after  { width: 40%; left: auto; right: 0; height: 50%; }
}

/*flow*/
.list-flow { display: flex; flex-wrap: wrap; justify-content: space-between; counter-reset: listnum;  }
.list-flow > li { width: 12%; position: relative; text-align: center; color: #FFF; font-size: 1.125rem; font-weight: bold; position: relative; counter-increment: listnum; }
.list-flow > li::before { content: counter(listnum, decimal-leading-zero); background: #F25A99; width: 2rem; height: 2rem; border-radius: 50%; left: 0; top: 0; position: absolute; z-index: 2; }
.list-flow .img { width: 100%; height: 0; padding-bottom: 96%; border-radius: 50%; background: #FFF; border: 3px solid #F25A99; position: relative; margin-bottom: 1em; position: relative; }
.list-flow .img img { width: auto; height: auto; max-width: 50%; max-height: 50%; position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto; }
.list-flow > li:first-child .img::before { content: ''; width: 100vw; height: 10px; background: #FFF; opacity: .15; position: absolute; left: 0; top: 0; bottom: 0; margin: auto; margin-left: min(-10%, calc(-50vw + 600px)); }
.list-flow > li + li .img::before { content: ''; width: 2.5rem; height: 2.5rem; display: block; position: absolute; background: url("../img/flow-arrow.svg") no-repeat center center / contain; left: calc(-50% - 1rem); top: 0; bottom: 0; margin: auto; }
.list-flow p { line-height: 130%;  }

.flow-text { text-align: center; color: #FCE800; font-size: 2.2rem; font-weight: 900; margin-top: 1em;  }
.flow-text span { border-bottom: 5px solid; padding-bottom: .1em; }

@media screen and (max-width: 900px) {
  .list-flow > li { width: 25%; margin-right: 12%; }
  .list-flow > li:nth-child(3){ margin-right: 0; }
  .list-flow > li:nth-child(4) { margin-left:  20%; margin-top: 2rem; }
  .list-flow > li:nth-child(5) { marign-right: 20%; margin-top: 2rem; }
  .list-flow p { font-size: 1rem; }
  
  .list-flow > li:first-child .img::before { width: 110vw;  margin-left: -30%; }
  .list-flow > li:nth-child(4) .img::before { content: ''; width: 120vw; height: 10px; background: #FFF; opacity: .15; position: absolute; left: 0; top: 0; bottom: 0; margin: auto; margin-left: -120%; }

  .list-flow > li + li .img::before { white-space: 1.5rem;height: 1.5rem; left: calc(-30% - 1.5rem); }
  
  .flow-text { font-size:  1.5rem; line-height: 150%;  }
  .flow-text span { display: table; margin: 0 auto; }
}

/*faq*/
.list-qa dt { border: 3px solid #0078C9; font-size: 1.25rem; font-weight: bold; position: relative; margin-top: 2em; }
.list-qa dt a { width: 100%; height: 100%; display: block; padding: 1em 100px;
}
.list-qa dt::before { content: 'Q'; font-family: 'Roboto', sans-serif; font-weight: bold; color: #F45799; font-size: 2rem; position: absolute; left: 40px; top: 1.25rem; }
.list-qa dd { padding: 2em 100px 0; font-size: 1.125rem; position: relative; }
.list-qa dd::before { content: 'A'; font-family: 'Roboto', sans-serif; font-weight: bold; color: #0A53A9; font-size: 2rem; position: absolute; left: 40px; top: 2.5rem; }

@media screen and (max-width: 900px ){
  .list-qa dt { padding: 1em 1em 1em 4em; }
  .list-qa dd { padding: 2em 1em 2em 4em; }
  .list-qa dt::before,
  .list-qa dd::before { left: .7em; }
}
.collapse:not(.show){
  display: none;
}
#accordion_faq a[data-toggle="collapse"]::after{
	content: "×";
	position: absolute;
	right: 20px;
	top: 50%;
	margin-top: -0.8em;
	color: #0078C9;
}
#accordion_faq a[aria-expanded=false]::after{
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    transition-duration: 0.3s;
}
#accordion_faq a[aria-expanded=true]::after{
    -webkit-transform: rotate(90deg);
    -ms-transform: rotate(90deg);
    transform: rotate(90deg);
    transition-duration: 0.3s;
}


/*price*/
.conts-price .first { color: #FFF; font-size: 2.2rem; font-weight: 900; padding-bottom: .3em;  border-bottom: 3px solid; line-height: 120%; display: table; margin: 0 auto 1em; }
.list-price { display: flex; flex-wrap: wrap; justify-content: space-between; }
.list-price > div { width: 48%; background: #FFF; border: 3px solid #F25A99; padding: 1rem 3rem; height: 10rem;  display: flex; align-items: center; justify-content: space-between; }
.list-price > div:nth-child(n + 3) { margin-top: 2.5rem; }
.list-price dt { font-weight: bold; font-size: 1.3rem; width: calc(100% - 12rem); line-height: 150%;  }
.list-price dd { font-size: 2.5rem; font-weight: 900; color: #0078C9; }
.list-price dd span { font-size: 1.6em;  }

@media screen and (max-width: 1200px) {
  .list-price > div { padding: 1rem; }
}

@media screen and (max-width: 900px) {
  .list-price > div { height: 8rem; }
  .list-price > div:nth-child(n + 3) { margin-top: 1.5rem; }
  .list-price dt { font-size: 1rem; width: calc(100% - 10rem); }
  .list-price dd { font-size: 2rem; font-weight: 900; color: #0078C9; }
  .list-price dd span { font-size: 1.3em; }
}
@media screen and (max-width: 600px) {
  
  .conts-price .first { font-size: 1.5rem; }
  .list-price > div { width: 100%; height: 6rem; }
  .list-price > div:nth-child(n + 2) { margin-top: 1rem; }
}

/*ad*/
.conts-ad { background: linear-gradient(120deg, transparent 75%, #FCE800 75%); }
.target { display: flex; flex-wrap: wrap; justify-content: space-between; margin-bottom: 1.5rem; }
.target > li { font-size: 1.25rem; font-weight: bold; width: 18%; background: #F45799;  color: #FFF; border-radius: 10px; padding: 2em; display: flex; align-items: center; justify-content: center; position: relative; }
.target > li::after { content: ''; width: 0; height: 0; border-style: solid; border-color: #F45799 transparent transparent transparent; border-width: 1rem .7rem 0; position: absolute; top: 100%; left: 0; right: 0; margin: auto; }

.ad { display: flex; justify-content: space-between; align-items: flex-end; }
.comment { font-size: 4.2rem; font-weight: 900; line-height: 150%;  color: #0078C9; }
.comment .sub { display: block; text-align: center; font-size: .7em; color: #0A53A9; }
.comment .sub::before,
.comment .sub::after { content: ''; width: 0; height: 0; border-style: solid; border-color: #0A53A9 transparent transparent transparent; display: inline-block; vertical-align: text-bottom; }
.comment .sub::before { border-width: 1.5em 0 0 15px; margin-right: 10px; transform-origin: right bottom;  transform: skewX(30deg); }
.comment .sub::after { border-width: 1.5em 15px 0 0; margin-left: 10px; transform-origin: left bottom; transform: skewX(-30deg); }
.comment .em { border-bottom: 7px solid; }
.comment .free { background: #F45799; color: #FFF; font-size: .6em; display: inline-block; padding: .2em .5em; border-radius: 5px; vertical-align: middle; margin: -.3em 0 0 .2em; line-height: 150%; }
.ad img { max-width: 30%; }

@media screen and (max-width: 1500px) {
  .target > li { font-size: 1.125rem; }
  .comment { font-size: 4.5vw; }
}
@media screen and (max-width: 1200px) {
  .target > li { font-size: 1rem; }
}
@media screen and (max-width: 900px) {
  .target  { justify-content: center; }
  .target > li { width: 32%; margin-right: 2%;  }
  .target > li:nth-child(3),
  .target > li:nth-child(5) { margin-right: 0; }
  .target > li:nth-child(n + 4) { margin-top: 2rem; }
  .comment .em { border-bottom-width: 4px; }
}
@media screen and (max-width: 900px) {
  .target > li { padding: 1em; font-size: .8rem; line-height: 150%; }
  .comment { width: 100%; font-size: 7vw;  }
  .ad { flex-wrap: wrap; }
  .ad img { width: 60%; max-width: 300px; display: block; margin: 1rem auto 0; }
}


/*contact*/
.conts-contact { background: #FFFEF3; }
a.btn-line { max-width: 582px; text-align: center; color: #FFF; background: #06C755; padding: 1em; border-radius: 2em; font-size: 1.3rem; font-weight: 900; display: block; margin: 0 auto 2em; }
a.btn-line img { display: inline-block; vertical-align: middle; margin-left: 1em; }


@media screen and (max-width: 900px) {
  a.btn-line { font-size: 1rem; }
}
.contactform dl dt { color: #0078C9; font-weight: bold; margin-bottom: .5em;  }
.contactform dl .must { color: #F45799; font-size: .75rem; line-height: 2em; padding: 0 1em; border: 1px solid; border-radius: 5px; margin-right: 1em; }
.contactform dl dd  { margin-bottom: 2em; }


.contactform input[type=text],
.contactform input[type=number],
.contactform input[type=date],
.contactform input[type=email],
.contactform input[type=tel],
.contactform select {
  
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: .inherit;
  line-height: 150%; 
  width: 100%; 
	padding: .5em;
	display: block;
  background: #FFF;
	border: 2px solid #127AC6;
}

.contactform textarea { 
  
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: inherit;
  line-height: 150%; 
  height: 15em; 
  width: 100%; 
	padding: .5em;
	display: block;
  background: #FFF;
  border: 2px solid #127AC6;
}

.contactform input[type="submit"] { -webkit-appearance: none; color: #FFF;width: 100%;  max-width:313px;margin: 0 auto 0; display: table;  margin: 3em auto 0;  text-align: center; padding: .8rem; font-size: 1.25rem; border: none; line-height: 150%; background: #0078C9; border-radius: 2rem; cursor: pointer; box-shadow: 0 0 0 5px rgba(0, 120, 201, .13); }

@media (max-width: 600px){
  .conts-main .img {
    width: 45%;
    margin: 1rem auto -0.5rem 4rem;
}
.conts-main .img .free {
  right: -60%;
  left: auto;
}
.mainvisual{
  padding: 2rem 0 1rem;
}
.conts-main .text .doc {
  width: 25vw;
  height: 25vw;
  font-size: 3vw;
  left: auto;
  right: -4vw;
  top: 1vw;
}
.main-contact {
  display: flex;
  justify-content: space-between;
  margin-top: 0.5rem;
}
.contents_wrap{
  width: 100%;
}
.conts-trouble {
  position: relative;
  padding: 2rem 0 3rem;
}
.list-trouble > li {
  width: 30vw;
  height: 30vw;
  font-size: 3vw;
  line-height: 1.2;
}}




/**
 * Added on 2024/2/13
 */

html {
    scroll-behavior: smooth;
    scroll-padding-top: 80px;
}
.fixed-cv {
    display: none;
}
.fixed-right {
    position: fixed;
    top: 6rem;
    right: 0;
    margin: 0;
    padding: 0;
    height: calc( 100vh - 7.0rem );
    max-height: 680px;
}
.fixed-right > a {
    display: block;
    margin: 0;
    padding: 0;
    border-radius: 0;
    border: 0;
    width: auto;
    height: 33.3%;
}
.fixed-right > a img {
    display: block;
    margin: 0;
    padding: 0;
    width: auto;
    height: 100%;
}
.mainvisual {
    position: relative;
    padding-top: 2.0rem;
    padding-bottom: 2.0rem;
}
.mv-pic {
    margin: 0 auto;
    width: 100%;
    max-width: 1200px;
}
.mv-pic img {
    display: block;
    margin: 0 auto;
    width: 100%;
}
.mainvisual .sp-btn-mail {
    display: none;
}
.mainvisual .sp-btn-line {
    display: none;
}
@media ( max-width: 900px ) {
    .fixed-cv {
        display: flex;
    }
    .fixed-cv > a {
        margin: 0;
        padding: 0;
        width: calc( 100% / 3.0 );
    }
    .fixed-cv > a img {
        margin: 0;
        padding: 0;
        width: 100%;
        height: auto;
    }
    .fixed-right {
        display: none;
    }
    .mv-pic img {
        width: 92%;
    }
    .mainvisual {
        padding-top: 2.0rem;
        padding-bottom: 2.0rem;
    }
    .mainvisual .sp-btn-mail {
        position: absolute;
        display: block;
        top: 41%;
        left: 8%;
        width: 84%;
    }
    .mainvisual .sp-btn-mail img {
        width: 100%;
        height: auto;
    }
    .mainvisual .sp-btn-line {
        position: absolute;
        display: block;
        top: 50%;
        left: 8%;
        width: 84%;
    }
    .mainvisual .sp-btn-line img {
        width: 100%;
        height: auto;
    }
    .list-qa dt a {
        padding: 0 2.0em 0 0;
    }
}
.features-box {
    margin: 6.0rem auto 0;
    padding: 2.0rem;
    width: 90%;
    max-width: 1200px;
    background: #fff;
    border: 10px solid #0078c9;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
}
.features-box .img {
    width: 100%;
}
.features-box .img img {
    width: 100%;
    height: auto;
}
.features-box .txt {
    margin: 2.0rem 0 0;
    width: 100%;
    font-size: calc( 16px, 2.0vw, 20px );
}
@media ( min-width: 1080px ) {
    .features-box .img {
        width: 55%;
    }
    .features-box .txt {
        margin: 0;
        width: 43%;
    }
}
.cta-btn {
    display: block;
    margin: 6.0rem auto 0;
    width: 90%;
    max-width: 620px;
}
footer p {
    line-height: 1.8;
}
footer p.top-margin {
    margin-top: 1.0em;
}
