@charset "UTF-8";
/* import */
/* カラー */
/* レスポンシブ */
/*****STANDART CSS******/
:root {
  --view-size: 1920;
}

@media screen and (max-width: 768px) {
  :root {
    --view-size: 375;
  }
}
* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var,
video {
  margin: 0;
}

html {
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
  /******SMOOTH SCROLL ANCHOR******/
}

/*****STANDART CSS******/
/* ---------common--------- */
body {
  margin: 0;
  font-family: YuGothic, "Yu Gothic", sans-serif;
  font-size: calc(16 / var(--view-size) * 100vw);
}

ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

img {
  vertical-align: bottom;
  width: 100%;
}

a {
  transition: 0.3s;
  text-decoration: none;
  color: #000;
  cursor: pointer;
}
a:hover {
  opacity: 0.7;
}

.line_link {
  display: block;
}

/* flex */
.row {
  display: flex;
  flex-wrap: wrap;
}

.between {
  justify-content: space-between;
}

.align_start {
  align-items: flex-start;
}

.align_center {
  align-items: center;
}

.align_end {
  align-items: flex-end;
}

.flex_center {
  justify-content: center;
}

.flex_start {
  justify-content: flex-start;
}

.flex_end {
  justify-content: flex-end;
}

.stretch {
  align-items: stretch;
}

.reverse {
  flex-direction: row-reverse;
}

/* inner */
.inner {
  width: calc(1000 / var(--view-size) * 100vw);
  margin: 0 auto;
}
@media (max-width: 768px) {
  .inner {
    width: calc(345 / var(--view-size) * 100vw);
  }
}

/* display */
@media (max-width: 768px) {
  .sp_dn {
    display: none;
  }
}

.sp_db {
  display: none;
}
@media (max-width: 768px) {
  .sp_db {
    display: block;
  }
}

@media (max-width: 768px) {
  .tab_dn {
    display: none;
  }
}

.tab_db {
  display: none;
}
@media (max-width: 768px) {
  .tab_db {
    display: block;
  }
}

.top_btn {
  position: fixed;
  bottom: calc(30 / var(--view-size) * 100vw);
  right: calc(30 / var(--view-size) * 100vw);
  z-index: 100;
  width: calc(65 / var(--view-size) * 100vw);
  height: calc(65 / var(--view-size) * 100vw);
  transition: 0.3s;
  opacity: 0;
}
@media (max-width: 768px) {
  .top_btn {
    bottom: calc(90 / var(--view-size) * 100vw);
    right: calc(20 / var(--view-size) * 100vw);
  }
}

.top_btn.active {
  opacity: 1;
}

/* bigger back-to-top button */
.top_btn--lg {
  width: calc(110 / var(--view-size) * 100vw);
  height: calc(110 / var(--view-size) * 100vw);
  border-radius: 50%;
  background: #06C755;
  color: #fff;
  display: grid;
  place-items: center;
  box-shadow: 0 calc(6 / var(--view-size) * 100vw) calc(16 / var(--view-size) * 100vw) rgba(0, 0, 0, 0.25);
}

.top_btn--lg i {
  font-size: calc(40 / var(--view-size) * 100vw);
  color: #fff;
}

@media (max-width: 768px) {
  .top_btn--lg {
    width: calc(88 / var(--view-size) * 100vw);
    height: calc(88 / var(--view-size) * 100vw);
    bottom: calc(120 / var(--view-size) * 100vw); /* fix_telより少し上 */
  }
  .top_btn--lg i {
    font-size: calc(34 / var(--view-size) * 100vw);
  }
}
.contents {
  width: calc(760 / var(--view-size) * 100vw);
  margin: 0 auto;
}
@media (max-width: 768px) {
  .contents {
    width: calc(375 / var(--view-size) * 100vw);
  }
}

.shine {
  position: relative;
  overflow: hidden;
  display: block;
  border-radius: calc(120 / var(--view-size) * 100vw);
  box-shadow: 0px calc(4 / var(--view-size) * 100vw) calc(10 / var(--view-size) * 100vw) rgba(0, 0, 0, 0.35);
  margin-bottom: calc(20 / var(--view-size) * 100vw);
}
.shine::before {
  content: "";
  width: calc(30 / var(--view-size) * 100vw);
  height: 100%;
  background-color: #fff;
  animation: shine 3s ease-in-out infinite;
  position: absolute;
  top: calc(-180 / var(--view-size) * 100vw);
  left: 0;
  opacity: 0;
  transform: rotate(45deg);
  z-index: 10;
}
.shine img {
  position: relative;
}

@keyframes shine {
  0% {
    transform: scale(0) rotate(45deg);
    opacity: 0;
  }
  80% {
    transform: scale(0) rotate(45deg);
    opacity: 0.5;
  }
  81% {
    transform: scale(4) rotate(45deg);
    opacity: 1;
  }
  100% {
    transform: scale(50) rotate(45deg);
    opacity: 0;
  }
}
/* privacy */
.privacy-page .contents {
  padding: calc(40 / var(--view-size) * 100vw) 0 calc(60 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .privacy-page .contents {
    padding: calc(20 / var(--view-size) * 100vw) 0 calc(30 / var(--view-size) * 100vw);
  }
}
.privacy-page .privacy-wrap {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
  border-radius: calc(24 / var(--view-size) * 100vw);
  padding: calc(32 / var(--view-size) * 100vw) 0;
}
@media (max-width: 768px) {
  .privacy-page .privacy-wrap {
    width: calc(340 / var(--view-size) * 100vw);
    padding: calc(16 / var(--view-size) * 100vw) 0;
  }
}
.privacy-page .privacy-title {
  font-size: calc(38 / var(--view-size) * 100vw);
  margin-bottom: calc(20 / var(--view-size) * 100vw);
  line-height: 1.3;
}
@media (max-width: 768px) {
  .privacy-page .privacy-title {
    font-size: calc(18 / var(--view-size) * 100vw);
    margin-bottom: calc(10 / var(--view-size) * 100vw);
  }
}
.privacy-page .privacy-lead {
  font-size: calc(24 / var(--view-size) * 100vw);
  line-height: 1.8;
  margin-bottom: calc(36 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .privacy-page .privacy-lead {
    font-size: calc(14 / var(--view-size) * 100vw);
    margin-bottom: calc(20 / var(--view-size) * 100vw);
  }
}
.privacy-page .privacy-block {
  margin-bottom: calc(20 / var(--view-size) * 100vw);
  background-color: #C8E7F2;
  padding: calc(24 / var(--view-size) * 100vw);
  border-radius: calc(24 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .privacy-page .privacy-block {
    padding: calc(16 / var(--view-size) * 100vw);
    border-radius: calc(16 / var(--view-size) * 100vw);
  }
}
.privacy-page .privacy-block:last-child {
  margin-bottom: 0;
}
.privacy-page .privacy-block h2 {
  font-size: calc(28 / var(--view-size) * 100vw);
  margin-bottom: calc(8 / var(--view-size) * 100vw);
  line-height: 1.4;
}
@media (max-width: 768px) {
  .privacy-page .privacy-block h2 {
    font-size: calc(18 / var(--view-size) * 100vw);
  }
}
.privacy-page .privacy-block p {
  font-size: calc(22 / var(--view-size) * 100vw);
  line-height: 1.9;
}
@media (max-width: 768px) {
  .privacy-page .privacy-block p {
    font-size: calc(12 / var(--view-size) * 100vw);
  }
}
.privacy-page .back-home {
  width: calc(713 / var(--view-size) * 100vw);
  margin: calc(24 / var(--view-size) * 100vw) auto 0;
  text-align: center;
}
@media (max-width: 768px) {
  .privacy-page .back-home {
    width: calc(340 / var(--view-size) * 100vw);
  }
}
.privacy-page .back-home_btn {
  display: inline-block;
  width: 100%;
  padding: calc(36 / var(--view-size) * 100vw);
  border-radius: calc(64 / var(--view-size) * 100vw);
  background: #EA0000;
  color: #fff;
  font-size: calc(36 / var(--view-size) * 100vw);
  font-weight: bold;
  letter-spacing: 0.03em;
}
@media (max-width: 768px) {
  .privacy-page .back-home_btn {
    padding: calc(24 / var(--view-size) * 100vw);
    font-size: calc(18 / var(--view-size) * 100vw);
  }
}
.privacy-page .back-home_btn:hover {
  opacity: 0.9;
}

header {
  width: calc(760 / var(--view-size) * 100vw);
  margin: 0 auto;
}
@media (max-width: 768px) {
  header {
    width: calc(375 / var(--view-size) * 100vw);
  }
}

/* footer */
.mv {
  position: relative;
}
.mv .mv_img {
  position: absolute;
  top: 0;
  width: 100%;
  z-index: 1;
}
.mv .mv_cont {
  padding-top: calc(850 / var(--view-size) * 100vw);
  position: relative;
  z-index: 5;
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
}
@media (max-width: 768px) {
  .mv .mv_cont {
    width: calc(340 / var(--view-size) * 100vw);
    padding-top: calc(420 / var(--view-size) * 100vw);
  }
}
.mv .mv_cont .mv_tel_text {
  margin-bottom: calc(40 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .mv .mv_cont .mv_tel_text {
    margin-bottom: calc(20 / var(--view-size) * 100vw);
  }
}

.hoken {
  position: relative;
  z-index: 5;
  margin-top: calc(50 / var(--view-size) * 100vw);
  padding-bottom: calc(20 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .hoken {
    margin-top: calc(20 / var(--view-size) * 100vw);
  }
}
.hoken .hoken_img {
  margin-bottom: calc(20 / var(--view-size) * 100vw);
}

.area {
  padding-bottom: calc(40 / var(--view-size) * 100vw);
  padding-top: calc(20 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .area {
    padding-bottom: calc(20 / var(--view-size) * 100vw);
  }
}
.area .area_cont {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
}
@media (max-width: 768px) {
  .area .area_cont {
    width: calc(340 / var(--view-size) * 100vw);
  }
}
.area .area_tel {
  margin-top: calc(20 / var(--view-size) * 100vw);
  display: block;
}
.area .area_text {
  margin-bottom: calc(40 / var(--view-size) * 100vw);
  margin-top: calc(20 / var(--view-size) * 100vw);
  display: block;
}
@media (max-width: 768px) {
  .area .area_text {
    margin-bottom: calc(20 / var(--view-size) * 100vw);
  }
}
.area .line_link {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
  display: block;
}

.flow {
  background-color: #C8E7F2;
  padding-bottom: calc(40 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .flow {
    padding-bottom: calc(20 / var(--view-size) * 100vw);
  }
}
.flow .flow_cont {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
}
.flow .flow_cont .flow_img {
  margin: calc(40 / var(--view-size) * 100vw) 0;
  width: calc(636 / var(--view-size) * 100vw);
}
@media (max-width: 768px) {
  .flow .flow_cont .flow_img {
    width: calc(340 / var(--view-size) * 100vw);
    margin: calc(20 / var(--view-size) * 100vw) 0;
  }
}

.faq {
  padding-bottom: calc(18 / var(--view-size) * 100vw);
}
.faq .faq_ttl {
  margin-bottom: calc(18 / var(--view-size) * 100vw);
}
.faq .faq-list {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
  padding: calc(27 / var(--view-size) * 100vw);
  background-color: #C8E7F2;
  border-radius: calc(24 / var(--view-size) * 100vw);
}
.faq .faq-list details {
  margin-bottom: calc(20 / var(--view-size) * 100vw);
}
.faq .faq-list details:last-child {
  margin-bottom: 0;
}
.faq .faq-list details summary {
  list-style: none;
  display: inline-block;
  position: relative;
  padding: calc(20 / var(--view-size) * 100vw) calc(56 / var(--view-size) * 100vw) calc(20 / var(--view-size) * 100vw) calc(20 / var(--view-size) * 100vw);
  font-size: calc(22 / var(--view-size) * 100vw);
  font-weight: bold;
  line-height: 1.4;
  background-color: #06C755;
  border-radius: calc(8 / var(--view-size) * 100vw) calc(32 / var(--view-size) * 100vw) calc(32 / var(--view-size) * 100vw) calc(32 / var(--view-size) * 100vw);
  cursor: pointer;
}
.faq .faq-list details summary::-webkit-details-marker {
  display: none;
}
.faq .faq-list details summary::after {
  content: "\f078";
  font-family: "Font Awesome 6 Free";
  font-weight: 900;
  position: absolute;
  top: 50%;
  right: calc(20 / var(--view-size) * 100vw);
  transform: translateY(-50%);
  font-size: calc(22 / var(--view-size) * 100vw);
  transition: transform 0.25s ease;
}
.faq .faq-list details p {
  position: relative;
  width: calc(430 / var(--view-size) * 100vw);
  margin: calc(12 / var(--view-size) * 100vw) 0 0 auto;
  padding: calc(16 / var(--view-size) * 100vw) calc(52 / var(--view-size) * 100vw) calc(16 / var(--view-size) * 100vw) calc(18 / var(--view-size) * 100vw);
  font-size: calc(20 / var(--view-size) * 100vw);
  font-weight: bold;
  line-height: 1.45;
  color: #394762;
  background-color: #fff;
  border-radius: calc(36 / var(--view-size) * 100vw) calc(8 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw) calc(36 / var(--view-size) * 100vw);
}

/* open時のアイコン反転 */
.faq .faq-list details[open] > summary::after {
  transform: translateY(-50%) rotate(180deg);
}

.voice .voice_ttl {
  margin-bottom: calc(18 / var(--view-size) * 100vw);
}
.voice .voice_img {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
}

.cta {
  background-color: #C8E7F2;
  padding-bottom: calc(20 / var(--view-size) * 100vw);
}
.cta .cta_cont {
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
  transform: translateY(calc(-70 / var(--view-size) * 100vw));
}
@media (max-width: 768px) {
  .cta .cta_cont {
    transform: translateY(calc(-20 / var(--view-size) * 100vw));
  }
}
.cta .cta_text {
  margin-bottom: calc(10 / var(--view-size) * 100vw);
}

footer {
  padding: calc(13 / var(--view-size) * 100vw) 0 calc(200 / var(--view-size) * 100vw);
  width: calc(713 / var(--view-size) * 100vw);
  margin: 0 auto;
}
@media (max-width: 768px) {
  footer {
    padding-bottom: calc(120 / var(--view-size) * 100vw);
    font-size: calc(10 / var(--view-size) * 100vw);
  }
}
footer .copyright .privacy {
  text-decoration: underline;
}

.fix_tel {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  z-index: 100;
  width: calc(713 / var(--view-size) * 100vw);
  display: block;
  opacity: 0;
  pointer-events: none;
  transition: 0.3s opacity ease;
}
@media (max-width: 768px) {
  .fix_tel {
    bottom: calc(-10 / var(--view-size) * 100vw);
  }
}

.fix_tel.active {
  opacity: 1;
  pointer-events: auto;
}

/* （電話CTAアニメーションは削除） */
/* ========== SP (≤768px) responsive tweaks ========== */
@media (max-width: 768px) {
  .mv .mv_cont {
    width: calc(340 / var(--view-size) * 100vw);
  }
  .area .area_img {
    width: calc(340 / var(--view-size) * 100vw);
    margin: 0 auto;
    margin-top: calc(20 / var(--view-size) * 100vw);
  }
  .area .area_tel,
  .area .area_text,
  .area .line_link {
    width: calc(340 / var(--view-size) * 100vw);
  }
  .flow .flow_cont {
    width: calc(340 / var(--view-size) * 100vw);
  }
  .faq {
    padding-bottom: calc(24 / var(--view-size) * 100vw);
  }
  .faq .faq_ttl {
    margin-bottom: calc(16 / var(--view-size) * 100vw);
  }
  .faq .faq-list {
    width: calc(340 / var(--view-size) * 100vw);
    padding: calc(16 / var(--view-size) * 100vw);
    border-radius: calc(16 / var(--view-size) * 100vw);
  }
  .faq .faq-list details summary {
    padding: calc(16 / var(--view-size) * 100vw) calc(44 / var(--view-size) * 100vw) calc(16 / var(--view-size) * 100vw) calc(16 / var(--view-size) * 100vw);
    font-size: calc(12 / var(--view-size) * 100vw);
  }
  .faq .faq-list details summary::after {
    right: calc(14 / var(--view-size) * 100vw);
    font-size: calc(12 / var(--view-size) * 100vw);
  }
  .faq .faq-list details p {
    width: auto;
    max-width: 100%;
    margin: calc(12 / var(--view-size) * 100vw) 0 0 0;
    padding: calc(14 / var(--view-size) * 100vw);
    font-size: calc(12 / var(--view-size) * 100vw);
    border-radius: calc(20 / var(--view-size) * 100vw);
  }
  .voice .voice_img {
    width: calc(340 / var(--view-size) * 100vw);
  }
  .cta .cta_cont {
    width: calc(340 / var(--view-size) * 100vw);
  }
  footer {
    width: calc(340 / var(--view-size) * 100vw);
  }
  .fix_tel {
    width: calc(340 / var(--view-size) * 100vw);
  }
}
.fadein {
  opacity: 0;
  transform: translateY(3%);
}
.fadein.active {
  animation: 0.8s forwards fadein;
}

.fadein2 {
  opacity: 0;
  transform: translateY(3%);
}
.fadein2.active {
  animation: 0.8s forwards 0.1s fadein;
}

.leftin {
  transform: translateX(-100%);
  overflow: hidden;
}
.leftin.active {
  animation: 0.5s forwards leftin;
}

.rightin {
  transform: translateX(100%);
  overflow: hidden;
}
.rightin.active {
  animation: 0.5s forwards rightin;
}

@keyframes fadein {
  0% {
    opacity: 0;
    transform: translateY(3%);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
@keyframes leftin {
  0% {
    transform: translateX(-100%);
  }
  100% {
    transform: translateX(0);
  }
}
@keyframes rightin {
  0% {
    transform: translateX(100%);
  }
  100% {
    transform: translateX(0);
  }
}/*# sourceMappingURL=style.css.map */