@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  border: none;
  box-sizing: border-box;
  list-style: none;
  text-decoration: none;
}
html{
  font-size: 62.5%;
  -webkit-text-size-adjust: 100%;
  scroll-behavior: smooth;
}
body{ 
  font-family: "BIZ UDPGothic", sans-serif;
  font-size: 1.5rem;
  font-weight: 400;
  font-style: normal;
  min-width: 320px;
  color: var(--black-color);
}
html.is-noscroll {
  overflow: hidden;
  width: 100%;
}
.anchor-target {
  scroll-margin-top: var(--header);
}
/* ------------------------------------------ */
/* ------------------------------------------ */
.tb{ display: none !important;}
.sp{ display: none !important;}
.tbsp{ display: none !important;}
.pcsp{ display: block !important;}
/* ------------------------------------------ */
/* ------------------------------------------ */
.section-inner-max{ padding:12.0rem 0;}
.section-inner{ padding:8.0rem 0 10.0rem;}
.section-inner-min{ padding:5.0rem 0;}
.wrap-wide{ max-width: 128.0rem; margin:0 auto; padding-inline: max(4.0rem);}
.wrap-normal{ max-width: 108.0rem; margin:0 auto; padding-inline: max(4.0rem);}
.wrap-min{ max-width: 98.0rem; margin:0 auto; padding-inline: max(4.0rem);}
.bg-color-wht{ background-color: var(--white-color);}
.bg-color-key{ background-color: var(--main-color);}
.bg-color-sub{ background-color: var(--bg-main-color);}
.bg-color-gray{ background-color: var(--bg-gray-color);}
.fc-wht{ color: var(--white-color);}
.fc-key{ color: var(--main-color);}
.v-t{ vertical-align: top;}
.v-m{ vertical-align: middle;}
.v-b{ vertical-align: bottom;}
.t-l{ text-align: left;}
.t-c{ text-align: center;}
.t-r{ text-align: right;}
.mr-auto{ margin-right: auto;}
.ml-auto{ margin-left: auto;}
.fw-500{ font-weight: 500;}
.fw-600{ font-weight: 600;}
.m-t10{ margin-top: 1.0rem;}
.m-t20{ margin-top: 2.0rem;}
.m-t30{ margin-top: 3.0rem;}
.m-t40{ margin-top: 4.0rem;}
.m-t50{ margin-top: 5.0rem;}
.p-t0{ padding-top: 0;}
.p-b0{ padding-bottom: 0;}
a{ color: var(--main-color); transition: 0.3s;}
p{ line-height: 1.5em;}
img{ width: 100%; height: auto; vertical-align: bottom;}
.txt-min{ line-height: 1.7em;}
.txt{ line-height: 2.0em;}
.txt-max{ line-height: 2.4em;}
.txt-underline{ text-decoration: underline;}
.fs-sml{ font-size: 80%;}
h1,h2,h3,h4,h5,h6{ font-weight: unset;}
:root {
  --main-color: #5084C4;
  --white-color: #fff;
  --black-color: #262626;
  --blue-color: #0852AD;
  --gray-color: #777;
  --orange-color: #EF7C5D;
  --bg-main-color: #EDF3FB;
  --bg-gray-color: #A0A0A0;
  --bg-gray2-color: #F9F9F9;
  --bg-orange-color: #FFFBF8;
  --fw-400: 400;
  --fw-600: 600;
  --txt-underline: underline;
  --fs-5: 0.5rem;
  --fs-6: 0.6rem;
  --fs-7: 0.7rem;
  --fs-8: 0.8rem;
  --fs-9: 0.9rem;
  --fs-10: 1.0rem;
  --fs-11: 1.1rem;
  --fs-12: 1.2rem;
  --fs-13: 1.3rem;
  --fs-14: 1.4rem;
  --fs-15: 1.5rem;
  --fs-16: 1.6rem;
  --fs-17: 1.7rem;
  --fs-18: 1.8rem;
  --fs-20: 2.0rem;
  --fs-22: 2.2rem;
  --fs-24: 2.4rem;
  --fs-26: 2.6rem;
  --fs-28: 2.8rem;
  --fs-30: 3.0rem;
  --fs-32: 3.2rem;
  --fs-34: 3.4rem;
  --fs-36: 3.6rem;
  --fs-40: 4.0rem;
  --fs-48: 4.8rem;
  --header: 8.0rem;
}

@media  only screen and (max-width: 1024px){
  body{ font-size: 1.5rem;}
  .section-inner-max{ padding:12.0rem 0;}
  .section-inner{ padding:8.0rem 0 10.0rem;}
  .section-inner-min{ padding:5.0rem 0;}
  .pc{ display: none !important;}
  .tb{ display: block !important;}
  .sp{ display: none !important;}
  .pctb{ display: block !important;}
  .tbsp{ display: block !important;}
  .pcsp{ display: none !important;}
  .p-t0{ padding-top: 0;}
  .p-b0{ padding-bottom: 0;}
}

@media screen and (max-width: 767px) {
  body { width: 100%; font-size: 3.733vw;}
  .block{ width: 100%; max-width: 100%;}
  .section-inner-max{ padding:10.667vw 0 16.333vw;}
  .section-inner{ padding:10.667vw 0 13.333vw;}
  .section-inner-min{ padding:13.333vw 0;}
  .wrap-wide{ padding-inline: 5%;}
  .wrap-normal{ padding-inline: 5%;}
  .wrap-min{ padding-inline: 5%;}
  .pc{ display: none !important;}
  .tb{ display: none !important;}
  .sp{ display: block !important;}
  .pctb{ display: none !important;}
  .tbsp{ display: block !important;}
  .pcsp{ display: block !important;}
  .sp-t-l{ text-align: left;}
  .p-t0{ padding-top: 0;}
  .p-b0{ padding-bottom: 0;}
  .sp_m-t0{ margin-top: 0 !important;}
  :root { 
    --header: 16vw;
    --fs-10: 2.667vw;
    --fs-11: 2.933vw;
  }
}
/* ------------------------------------------ */
/* ------------------------------------------ */
/* ------------------------------------------ */
/* ------------------------------------------ */

/* wrapper
--------------------------------------------- */
.wrapper {
  /* padding-top: 0; */
  padding-top: var(--header);
}
/*  --------------------------------------------
  header
--------------------------------------------- */
.header {
  width: 100%;
  top: 0;
  left: 0;
  height: var(--header);
  position: fixed;
  z-index: 6;
  background: var(--white-color);
  filter: drop-shadow(0 1px 20px rgba(240, 240, 240, 1));
}
.is-menu-opened .header,
.header.is-scroll{
  filter: none;
}
.header-container {
  display: flex;
  align-items: center;
  height: 100%;
  padding-inline: 3.0rem 2.0rem;
}
.header-logo {
  width: 18.0rem;
  margin-right: auto;
}
.header-logo-link img {
  display: block;
  width: 100%;
  height: auto;
}

/* header-menu
--------------------------------------------- */
@media screen and (min-width: 1025px) {
  .header-menu { display: block !important;}
}
.header-menu-container{
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.header-nav{
  display: flex;
  align-items: center;
  gap: 2.7rem;
}
.header-nav-list {
  display: flex;
  align-items: center;
  gap: clamp(2.0rem, 3.125vw, 4.5rem);
}
.header-nav-item{
  font-weight: var(--fw-600);
  font-size: clamp(var(--fs-13), 1.016vw, var(--fs-14));
}
.header-nav-link{
  color: #000;
  display: block;
}
@media (hover: hover) and (pointer: fine) {
  .header-nav-link:hover{
    color: var(--main-color);
  }
}
@media screen and (max-width: 1200px) {
  .header-nav{
    gap: 2.2rem;
  }
  .header-nav-list {
    gap: clamp(2.0rem, 2.5vw, 3.0rem);
  }
}
@media screen and (min-width: 1025px) {
  .header-nav-button-link{
    background-color: var(--blue-color);
    border-radius: 5px;
    box-sizing: border-box;
    border: 2px solid var(--blue-color);
    color: var(--white-color);
    display: block;
    font-weight: var(--fw-600);
    font-size: clamp(1.3rem, 1.016vw, 1.4rem);
    padding: 1.3rem 2.5rem;
  }
  @media (hover: hover) and (pointer: fine) {
    .header-nav-button-link:hover{
      border: 2px solid var(--blue-color);
      background: var(--white-color);
      color: var(--blue-color);
    }
  }
}
@media  only screen and (min-width: 1025px){
  .header-subnav{
    display: none;
  }
}
@media  only screen and (max-width: 1280px) and (min-width: 1025px){
  .header-nav-button-link{
    padding: 1.5rem 1.953vw;
  }
}
@media  only screen and (max-width: 1024px){  
  .header-container {
    padding-inline: 2.0rem;
  }
  .header-menu-button { 
    display: block;
    position: relative;
    width: 30px;
    height: 10px;
    border: 0;
    margin: 0;
    outline: none;
    touch-action: manipulation;
    cursor: pointer;
  }
  .header-menu-button__lines {
    position: relative;
    display: block;
    width: 30px;
    height: 10px;
  }
  .header-menu-button__line {
    position: absolute;
    left: 0;
    display: block;
    width: 100%;
    height: 0;
    padding-top: 2px;
    background-color: var(--main-color);
    transition: 0.3s;
  }
  .header-menu-button__line--top {
    top: 0;
  }
  .is-menu-opened .header-menu-button__line--top {
    top: 50%;
    transform: translateY(-50%) rotate(25deg);
  }
  .header-menu-button__line--bottom {
    bottom: 0;
  }
  .is-menu-opened .header-menu-button__line--bottom {
    bottom: 50%;
    transform: translateY(50%) rotate(-25deg);
  }
  .header-menu {
    position: fixed;
    top: var(--header);
    left: 0;
    width: 100%;
    height: calc(100vh - var(--header));                
    overflow-y: auto;
    display: none;
    z-index: 2;
  }
  .header-menu-container {
    display: block;
    background-color: rgba(80, 132, 196, 0.9);
    padding: 1.0rem 2.0rem 3.5rem;
  }
  .header-nav{
    gap: 0;
    width: 100%;
    display: block;
  }
  .header-nav-list{
    width: 100%;
    gap: 0;
    display: block;
    flex-wrap: wrap;
    width: 100%;
    margin: 0 auto;
  }
  .header-nav-item { 
    border-bottom: 1px solid var(--white-color);
  }
  .header-nav-link {
    display: block;
    padding: 2.0rem 1.0rem;
    color: var(--white-color);
  }
  @media (hover: hover) and (pointer: fine) {
    .header-nav-link:hover,
    .header-nav-button-link:hover{
      color: var(--white-color);
      opacity: .6;
    }
  }
  .header-nav-button{
    border-bottom: 1px solid var(--white-color);
  }
  .header-nav-button-link{
    display: block;
    padding: 2.0rem 1.0rem;
    color: var(--white-color);
    font-weight: var(--fw-600);
    font-size: 1.4rem;
  }
  .header-subnav{
    margin-top: 2.5rem;
  }
  .is-menu-opened .header-subnav{
    display: block;
  }
  .header-sub-list{
    display: flex;
    flex-wrap: wrap;
    gap: 1.8rem;
  }
  .header-sub-item{
    width: 100%;
  }
  .header-sub-link{
    color: var(--white-color);
    display: block;
    font-size: var(--fs-11);
    font-weight: var(--fw-400);
    text-decoration: underline;
    text-underline-offset: 0.3rem;
  }
  .header-sub-link.external-link::after{
    content: '';
    display: inline-block;
    width: 11px;
    height: 12px;
    background-image: url(../../assets/images/icon/btn_external_wht.svg);
    background-repeat: no-repeat;
    background-size: contain;
    margin-left: 0.6rem;
    vertical-align: text-bottom;
  }
  @media (hover: hover) and (pointer: fine) {
    .header-sub-link:hover{
      color: var(--white-color);
      opacity: .6;
    }
  }
}
@media  only screen and (max-width: 767px){
  .header-logo{
    width: 33.333vw;
  }
  .header-container {
    padding-inline: 5%;
  }
  .header-menu-button { 
    width: 8vw;
    height: 2.667vw;
  }
  .header-menu-button__lines {
    width: 8vw;
    height: 2.667vw;
  }
  .header-menu-button__line {
    padding-top: 2px;
  }
  .header-menu-container {
    padding: 1.333vw 5% 8vw;
  }
  .header-nav-item{
    font-size: 3.467vw;
  }
  .header-nav-link {
    padding: 5.067vw 2.667vw;
  }
  .header-nav-button-link{
    font-size: 3.467vw;
    padding: 5.067vw 2.667vw;
  }
  .header-subnav{
    margin-top: 6.667vw;
  }
  .header-sub-list{
    gap: 4vw;
  }
  .header-sub-link{
    font-size: var(--fs-11);
    text-underline-offset: 0.8vw;
  }
  .header-sub-link.external-link::after{
    width: 2.933vw;
    height: 3.2vw;
    margin-left: 1.6vw;
  }
}

/*  --------------------------------------------
------------------------------------------------
共通
------------------------------------------------
--------------------------------------------- */
/*  ttl
--------------------------------------------- */
.ttl-block{ margin-bottom: 4.0rem;}
.ttl-block-max{ margin-bottom: 6.0rem;}
.ttl-block-mid{ margin-bottom: 3.0rem;}
.ttl-block-min{ margin-bottom: 2.0rem;}
.ttl-block,
.ttl-block-max,
.ttl-block-mid,
.ttl-block-min{
  text-align: center;
}
.main-ttl{
  font-weight: var(--fw-600);
  color: var(--main-color);
}
.en-ttl{
  font-size: var(--fs-14);
  font-weight: var(--fw-600);
  color: var(--blue-color);
  margin-bottom: 2.0rem;
}
.h2-ttl{
  font-size: var(--fs-34);
}
.h3-ttl{
  font-size: var(--fs-24);
  line-height: 1.3em;
}
.h4-ttl{
  font-size: var(--fs-20);
  line-height: 1.3em;
}
@media  only screen and (max-width: 767px){  
  .ttl-block{
    margin-bottom: 5.867vw;
  }
  .ttl-block-max{ 
    margin-bottom: 8vw;
  } 
  .ttl-block-mid{ 
    margin-bottom: 6.667vw;
  }
  .ttl-block-min{ 
    margin-bottom: 3.733vw;
  }
  .en-ttl{
    font-size: 3.2vw;
    margin-bottom: 2.667vw;
  }
  .h2-ttl{
    font-size: 6.133vw;
  }
  .h3-ttl{
    font-size: 4.533vw;
  }
  .h4-ttl{
    font-size: 4.533vw;
  }
}

/*  button
--------------------------------------------- */
.button-wrap{
  display: flex;
  justify-content: center;
  gap: 1.5rem;
}
.button-wrap .button{
  width: 100%;
  max-width: 32.0rem;
}
.button-block{
  margin-top: 6.0rem;
}
.button-block-min{
  margin-top: 2.5rem;
}
@media  only screen and (max-width: 767px){
  .button-wrap{
    flex-wrap: wrap;
    gap: 3.2vw;
  }
  .button-wrap .button{
    max-width: 100%;
  }
  .button-block-min{
    margin-top: 6.667vw;
  }
}
/*  button bgcolor */
.button-round a{
  position: relative;
  background: var(--blue-color);
  border: 2px solid var(--blue-color);
  border-radius: 10px;
  color: var(--white-color);
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: var(--fs-16);
  font-weight: var(--fw-600);
  padding: 2.5rem 0;
  max-width: 32.0rem;
  margin: 0 auto;
  transition: 0.3s ease-in-out;
}
.button-round .link-arrow:after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: 1.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2.6rem;
  height: 2.6rem;
  background: url(../../assets/images/icon/icon_arrow.svg) no-repeat center / contain;
  filter: brightness(0) saturate(100%) invert(97%) sepia(1%) saturate(2%) hue-rotate(331deg) brightness(109%) contrast(100%);
  transition: none; 
  animation: none; 
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .button-round a:hover{ 
    background-color: var(--white-color);
    color: var(--blue-color);
  }
  .button-round .link-arrow:hover:after{
    filter: brightness(0) saturate(100%) invert(21%) sepia(51%) saturate(3076%) hue-rotate(201deg) brightness(97%) contrast(97%);
  }
}
@media  only screen and (max-width: 767px){
  .button-round a{
    border-radius: 2.667vw;
    font-size: 4.267vw;
    padding: 5.867vw 0;
    max-width: 100%;
  }
  .button-round .link-arrow:after {
    right: 3.2vw;
    width: 6.667vw;
    height: 6.667vw;
  }
}

/*  button bordercolor */
.button-border a{
  position: relative;
  background: var(--white-color);
  border: 2px solid var(--blue-color);
  border-radius: 10px;
  color: var(--blue-color);
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: var(--fs-16);
  font-weight: var(--fw-600);
  padding: 2.5rem 0;
  max-width: 32.0rem;
  margin: 0 auto;
  transition: 0.3s ease-in-out;
}
.button-border .link-arrow:after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: 1.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2.6rem;
  height: 2.6rem;
  background: url(../../assets/images/icon/icon_arrow.svg) no-repeat center / contain;
  transition: none; 
  animation: none; 
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .button-border a:hover{ 
    background-color: var(--blue-color);
    color: var(--white-color);
  }
  .button-border .link-arrow:hover:after{
    filter: brightness(0) saturate(100%) invert(97%) sepia(1%) saturate(2%) hue-rotate(331deg) brightness(109%) contrast(100%);
  }
}
@media  only screen and (max-width: 767px){
  .button-border a{
    border-radius: 2.667vw;
    font-size: 4.267vw;
    padding: 5.867vw 0;
    max-width: 100%;
  }
  .button-border .link-arrow:after {
    right: 3.2vw;
    width: 6.667vw;
    height: 6.667vw;
  }
}

.button-border.max a{
  color: #0A4EA3;
  font-size: var(--fs-22);
  font-weight: var(--fw-600);
  padding: 3.7rem 0;
  max-width: 43.0rem;
}
.button-border.max .link-arrow:after {
  right: 2.0rem;
  width: 4.2rem;
  height: 4.2rem;
}
@media (hover: hover) and (pointer: fine) {
  .button-border.max a:hover{ 
    color: var(--white-color);
  }
}
@media  only screen and (max-width: 767px){
  .button-border.max a{
    border-radius: 2.667vw;
    font-size: 4.267vw;
    padding: 5.867vw 0;
    max-width: 100%;
  }
  .button-border.max .link-arrow:after {
    right: 3.2vw;
    width: 6.667vw;
    height: 6.667vw;
  }
}

/*  button bgcolor pdf */
.button-pdf a{
  position: relative;
  background: var(--blue-color);
  border: 2px solid var(--blue-color);
  border-radius: 10px;
  color: var(--white-color);
  display: flex; 
  align-items: center; 
  justify-content: center;
  font-size: var(--fs-16);
  font-weight: var(--fw-600);
  padding: 2.5rem 0;
  max-width: 65.5rem;
  margin: 0 auto;
  transition: 0.3s ease-in-out;
}
.button-pdf .link-arrow:after {
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: 1.5rem;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 2.6rem;
  height: 2.6rem;
  background: url(../../assets/images/icon/icon_pdf.svg) no-repeat center / contain;
  filter: brightness(0) saturate(100%) invert(97%) sepia(1%) saturate(2%) hue-rotate(331deg) brightness(109%) contrast(100%);
  transition: none; 
  animation: none; 
  pointer-events: none;
}
@media (hover: hover) and (pointer: fine) {
  .button-pdf a:hover{ 
    background-color: var(--white-color);
    color: var(--blue-color);
  }
  .button-pdf .link-arrow:hover:after{
    filter: brightness(0) saturate(100%) invert(21%) sepia(51%) saturate(3076%) hue-rotate(201deg) brightness(97%) contrast(97%);
  }
}
@media  only screen and (max-width: 767px){
  .button-pdf a{
    border-radius: 2.667vw;
    font-size: 4.267vw;
    padding: 5.867vw 0;
    max-width: 100%;
  }
  .button-pdf .link-arrow:after {
    right: 3.2vw;
    width: 6.667vw;
    height: 6.667vw;
  }
}

/*  movie
--------------------------------------------- */
.movie{
  text-align: center;
}
.movie iframe{
  max-width: 90.0rem;
  width: 100%;
  aspect-ratio: 16/9 ;
  margin: 0 auto;
  border-radius: 2.0rem;
}
@media  only screen and (max-width: 767px){
  .movie iframe{
    border-radius: 5.333vw;
  }
}

/*  bg
--------------------------------------------- */
.bg-blue{
  background: var(--bg-main-color);
}
.bg-gray{
  background: url(../../assets/images/bg_gray.png);
  background-size: auto;
}

/*  list
--------------------------------------------- */
.li2 ul , .li3 ul, .li4 ul, .li5 ul{
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
}
.li2 ul{ gap: 4%;}
.li2 ul li{ width: 48%;}
.li3 ul{ gap: 2.5%;}
.li3 ul li{ width: 31.6666%;}
.li4 ul{ gap: 2.6%;}
.li4 ul li{ width: 23%;}
.li5 ul{ gap: 4%;}
.li5 ul li{ width: 16.8%;}

@media  only screen and (max-width: 767px){
  .li2 ul,
  .li3 ul{
    gap: 2.667vw;
  }
  .li4 ul{
    gap: 2.667vw 4%;
  }
  .li2 ul li,
  .li3 ul li{
    width: 100%;
  }
  .li4 ul li{
    width: 48%;
  }
}
.txt-link{
  color: var(--main-color);
  word-wrap: break-word;
}
@media (hover: hover) and (pointer: fine) {
  .txt-link:hover{
    text-decoration: underline; 
  }
}

/*  ----------------------------------------  */
/*  ----------------------------------------  */

/*  mv / point
--------------------------------------------- */
.mv{
  position: relative;
  overflow: hidden;
}
.mv-img img{
  width: 100%;
  height: auto;
}
.concept-point{
  position: relative;
}
.service-point{
  position: absolute;
  width: 100%;
  top: -4.0rem;
  left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}
.service-point-wrapper{
  background: var(--white-color);
  border-radius: 2.0rem;
  filter: drop-shadow(0 1px 10px rgba(0, 0, 0, 0.08));
  padding: 3.2rem 5.0rem;
}
.service-point-ttl-block{
  color: var(--main-color);
  line-height: 1.8em;
  text-align: center;
  display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: baseline;
}
.service-point-ttl-block .sub-ttl{
  font-size: clamp(var(--fs-12), 1.25vw, var(--fs-16));
  font-weight: var(--fw-600);
  color: #686767;
}
.service-point-ttl-block .main-ttl{
  font-size: clamp(var(--fs-18), 1.875vw, var(--fs-24));
  font-weight: var(--fw-600);
  color: #686767;
}
.service-point-ttl-block .main-ttl span{
  color: var(--main-color);
}
.service-point-list{
  display: flex;
  margin-top: 1.0rem;
}
.service-point-item{
  display: flex;
  align-items: center;
  gap: 1.0rem;
  flex: 1;
}
.service-point-item-img{
  max-width: 11.5rem;
}
.service-point-item-ttl{
  color: var(--main-color);
  font-size: var(--fs-16);
  font-weight: var(--fw-600);
}
.service-point-item-txt{
  text-align: center;
  position: relative;
  padding-top: 2.5rem;
}
.service-point-item-txt::before{
  position: absolute;
  content: "";
  top: 0;
  left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  width: 2.4rem;
  height: 1.2rem;
  background: url(../../assets/images/icon/icon_bottom_arrow.svg) no-repeat center / contain;
  transition: none; 
}
.service-point-item-txt p{
  margin-top: 1.0rem;
  font-size: var(--fs-13);
  font-weight: var(--fw-600);
}

@media  only screen and (max-width: 1024px){  
  .service-point-wrapper{
    padding: 2.8rem 2.0rem;
  }
  .service-point-container{
    flex-wrap: wrap;
    gap: 1.465vw;
  }
  .service-point-ttl-block,
  .service-point-list{
    width: 100%;
  }
  .service-point-item{
    justify-content: center;
  }
  .service-point-item-img{
    max-width: 11.5rem;
    width: 11.23vw;
  }
  .service-point-ttl-block{
    line-height: 1.6em;
  }
  .service-point-ttl-block .sub-ttl:nth-child(1){
    width: 100%;
  }
  .service-point-ttl-block .sub-ttl{
    font-size: clamp(var(--fs-13), 1.563vw, var(--fs-16));
  }
  .service-point-ttl-block .main-ttl{
    font-size: clamp(var(--fs-18), 2.344vw, var(--fs-24));
  }
  .service-point-item-ttl{
    font-size: clamp(var(--fs-14), 1.563vw, var(--fs-16));
  }
  .service-point-item-txt p{
    font-size: clamp(var(--fs-11), 1.27vw, var(--fs-13));
  }
}
@media  only screen and (max-width: 767px){
  .service-point-item{
    flex-wrap: wrap;
  }
  .service-point{
    top: -8vw;
  }
  .service-point-wrapper{
    border-radius: 3.467vw;
    padding: 4vw 2.667vw;
  }
  .service-point-container{
    gap: 2.667vw;
  }
  .service-point-ttl-block .sub-ttl{
    font-size: 3.2vw;
  }
  .service-point-ttl-block .main-ttl{
    font-size: 4.8vw;
  }
  .service-point-item{
    gap: 2.467vw;
  }
  .service-point-item-img{
    max-width: unset;
    width: 17.333vw;
  }
  .service-point-item-ttl{
    font-size: 3.467vw;
  }
  .service-point-item-txt{
    padding-top: 4.8vw;
  }
  .service-point-item-txt p{
    margin-top: 1.6vw;
    font-size: 2.667vw;
  }
  .service-point-item-txt::before{
    width: 4.8vw;
    height: 2.4vw;
  }
}

/*  concept
--------------------------------------------- */
.concept{
  background: linear-gradient(to bottom, #EEEEEE 0%,#EEEEEE 50%, #FFFFFF 80%, #FFFFFF 100%);
}
.concept .section-inner{
  padding-top: clamp(10.0rem, 20.313vw, 26.0rem);
  padding-bottom: 0;
}
.concept .h1-ttl{
  color: var(--main-color);
  font-weight: var(--fw-600);
  font-size: clamp(var(--fs-40), 3.75vw, var(--fs-48));
}
.concept .concept-imgtxt{
  position: relative;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column-reverse;
}
.concept-img {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
}
.concept-txt{
  position: relative;
  z-index: 3;
  font-size: clamp(var(--fs-14), 1.25vw, var(--fs-16));
  max-width: clamp(50%, 47.656vw, 61.0rem);
  margin-left: auto;
}
.concept-txt .txt{
  line-height: 2.3em;
}
.concept-movie{
  margin-top: 8.0rem;
}
/* concept slider */
.slider-container {
  position: relative;
  width: clamp(40.0rem, 49.219vw, 64.0rem);
  height: auto;
  overflow: hidden;
  padding: 5% 20% 20% 0%;
  z-index: 1;
}
/* Swiperの画像を全画面に */
.swiper-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* 上に重ねる画像 */
.overlay-image {
  position: absolute;
  top: 50%;
  left: 50%;
  width: clamp(40.0rem, 49.219vw, 64.0rem);
  transform: translate(-50%, -50%);
  padding: 5% 20% 20% 0%;
  z-index: 2; /* 最前面に */
  pointer-events: none; /* ← クリックをSwiperに通す */
}
.overlay-image2 {
  position: absolute;
  z-index: 1;
  top: 50%;
  left: 50%;
  width: clamp(40.0rem, 49.219vw, 64.0rem);
  transform: translate(-50%, -50%);
  padding: 5% 20% 20% 0%;
  z-index: 0;
  pointer-events: none; /* ← クリックをSwiperに通す */
  filter: drop-shadow(35px 20px 14px rgba(0,0,0,0.5));
}


@media  only screen and (max-width: 1024px){  
  .concept .section-inner{
    padding-top: clamp(20.0rem, 29.297vw, 30.0rem);
    padding-bottom: 0;
  }
  .concept .h1-ttl{
    font-size: var(--fs-34);
  }
  .concept-img {
    left: -2%;
  }
}
@media  only screen and (max-width: 767px){  
  .concept{
    background: linear-gradient(to bottom, #EEEEEE 0%,#EEEEEE 50%, #FFFFFF 70%, #FFFFFF 100%);
    overflow-x: hidden;
  }
  .concept .section-inner{
    padding-top: 60vw;
    padding-bottom: 5.333vw;
  }
  .concept .h1-ttl{
    font-size: 6.4vw;
  }
  .concept-img {
    position: unset;
  }
  .concept-txt{
    font-size: 3.333vw;
    max-width: 100%;
    letter-spacing: -0.01em;
  }
  .concept-txt .txt{
    line-height: 2.0em;
  }
  .concept-txt .txt.m-t30{
    margin-top: 6.667vw;
  }
  .concept-movie{
    margin-top: 0;
  }
  /* concept slider */
  .slider-container {
    width: 70vw;
    margin-left: auto;
    padding: 5.333vw 10.333vw 10.333vw 2.667vw;
  }
  /* 上に重ねる画像 */
  .overlay-image {
    width: 70vw;
    padding: 5.333vw 10.333vw 10.333vw 2.667vw;
  }
  .overlay-image2 {
    width: 70vw;
    padding: 5.333vw 10.333vw 10.333vw 2.667vw;
    filter: drop-shadow(2.667vw 6.667vw 2.333vw rgba(0,0,0,0.4));
  }
}

/*  case
--------------------------------------------- */
.case-wrapper{
  max-width: 138.0rem;
  width: 100%;
  margin: 0 auto; 
  padding-inline: max(4.0rem);
}
.case-container{
  background: linear-gradient(to bottom, #EDF3FB 0%,#EDF3FB 15%, #CFE8FF 40%, #CFE8FF 100%);
  border-radius: 2.0rem;
  padding: 7.0rem 0 5.0rem;
}
.case-content{
  background: var(--white-color);
  border-radius: 1.0rem;
  position: relative;
  padding: 10.0rem 0 4.0rem;
}
.case .ttl-round{
  position: absolute;
  top: -45px;
  left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  width: max-content;
}
.case .ttl-round .h2-ttl{
  background: var(--main-color);
  border-radius: 5.0rem;
  color: var(--white-color);
  font-size: var(--fs-34);  
  
  padding: 2.3rem 9.0rem;
  position: relative;
}
.case .ttl-round .h2-ttl::after{
  position: absolute;
  content: "";
  display: block;
  bottom: -15px;
  left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 15px solid transparent;
  border-right: 15px solid transparent; 
  border-top: 17px solid var(--main-color);
}

.case-item{
  max-width: 110.0rem;
  margin: 0 auto;
}
hr{
  border-top: 1px solid #CACACA;
  margin: 4.0rem 5.0rem;
  max-width: 110.0rem;
}
.case-item .ttl-block-mid{
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 1.5rem;
  font-weight: var(--fw-600);
}
.case-item .ttl-block-mid .no{
  background: var(--blue-color);
  border-radius: 3.0rem;
  color: var(--white-color);
  display: inline-block;
  font-size: var(--fs-14);
  padding: 1.0rem 1.6rem;
}
.case-item .ttl-block-mid .ttl{
  color: var(--blue-color);
  font-size: var(--fs-26);
}
.case-item .h4-ttl{
  color: var(--orange-color);
  margin-top: 4.0rem;
}
.case-item .img{
  max-width: 105.0rem;
  margin: 2.0rem auto 0;
  padding-inline: 3.0rem;
}
.process{
  font-weight: var(--fw-600);
}
.process.bg .before,
.process.bg .after{
  background: var(--bg-gray2-color);
  border-radius: 1.0rem;
  padding: 3.0rem;
}
.process .before,
.process .after{
  display: flex;
  align-items: center;
  gap: 2.5rem;
}
.process.bg .after{
  background: var(--bg-orange-color);
  margin-top: 2.0rem;
}
.process .before .bef-ttl,
.process .after .aft-ttl{
  background: var(--main-color);
  border-radius: 0.4rem;
  color: var(--white-color);
  font-size: var(--fs-18);
  padding: 2.4rem 1.5rem;
  width: 7.4rem;
}
.process .after .aft-ttl{
  background: var(--orange-color);
}
.process .before ul,
.process .after ul{
  width: calc( 100% - 10.0rem);
}
.process .before ul li:not(:first-child),
.process .after ul li:not(:first-child){
  margin-top: 0.5rem;
}
.process .before ul li,
.process .after ul li{
  padding-left: 2.0rem;
  text-indent: -2.2rem;
  line-height: 1.5em;
  font-size: clamp(var(--fs-14), 1.172vw, var(--fs-15));
}
.process .before ul li::before,
.process .after ul li::before{
  display: inline-block;
  content: "";
  margin-right: 1.0rem;
  width: 1.2rem;
  height: 1.2rem;
  vertical-align: baseline;
  border-radius: 1.2rem;
  background-color: var(--main-color);
}
.process .after ul li::before{
  background: var(--orange-color);
}
.process .after ul li span{
  color: var(--orange-color);
}

.scene-content{
  padding-top: 9.0rem;
}
.scene-item{
  background: var(--white-color);
  border-radius: 1.0rem;
  padding: 5.0rem 0;
}
.scene-item:not(:first-child){
  margin-top: 3.0rem;
}
.scene-item .scene-inner{
  display: flex;
  align-items: center;
  gap: 4.5rem;
}
.scene-item .img{
  max-width: 38.0rem;
  height: auto;
}
.scene-item .img img{
  border-radius: 1.5rem;
}
.scene-item .h3-ttl{
  color: var(--blue-color);
  font-size: var(--fs-24);
  text-align: left;
}
.scene-item .h3-ttl span{
  padding-left: 1.0rem;
  font-size: var(--fs-15);
}
.scene-item .process .before,
.scene-item .process .after{
  align-items: flex-start;
  gap: 2.2rem;
}
.scene-item .process .after{
  margin-top: 2.0rem;
}
@media  only screen and (max-width: 1024px){
  .case .section-inner{
    padding-top: 8vw;;
  }
  .case-container{
    padding: 7.0rem 2.0rem 2.0rem;
  }
  .case-container .wrap-wide{
    padding-inline: 0;
  }
  .case-content{
    padding: 8.0rem 0 4.0rem;
  }
  .case .ttl-round{
    top: -30px;
  }
  .case .ttl-round .h2-ttl{
    font-size: var(--fs-26);      
    padding: 2.0rem 8.0rem;
  }
  .case-item .ttl-block-mid .no{
    font-size: var(--fs-12);
    padding: 1.0rem 1.6rem;
  }
  .case-item .ttl-block-mid .ttl{
    font-size: var(--fs-22);
  }
  .case-item .h4-ttl{
    line-height: 1.6em;
  }
  hr{
    margin: 4.0rem 3.0rem;
  }
  .scene-content .h2-ttl{
    font-size: var(--fs-30);
  }
  .scene-item .scene-inner{
    align-items: flex-start;
    gap: 3.0rem;
  }
  .scene-item .img{
    max-width: 26.0rem;
  }
  .scene-item .h3-ttl span{
    display: block;
    padding-left: 0;
    padding-top: 1.0rem;
  }
  .scene-item .process .before, 
  .scene-item .process .after{
    flex-wrap: wrap;
    gap: 1.5rem;
  }
  .scene-item .process .before .bef-ttl,
  .scene-item .process .after .aft-ttl{
    width: 100%;
    padding: 1.3rem 1.5rem;
  }
  .scene-item .process .before ul, 
  .scene-item .process .after ul{
    width: 100%;
  }
}
@media  only screen and (max-width: 767px){
  .case-wrapper{
    padding-inline: 5%;
  }
  .case-container{
    border-radius: 5.333vw;
    padding: 26.667vw 3.333vw 2.667vw;
    background: linear-gradient(to bottom, #EDF3FB 0%,#EDF3FB 30%, #CFE8FF 70%, #CFE8FF 100%);
  }
  .case-content{
    border-radius: 2.667vw;
    padding: 5.333vw 0;
    box-shadow: 0 0 2.667vw rgba(0, 0, 0, 0.1);
  }
  .case .ttl-round{
    top: -17.333vw;
  }
  .case .ttl-round .h2-ttl{
    border-radius: 10.667vw;
    font-size: 4.267vw;      
    padding: 4.533vw 16.533vw;
  }
  .case .ttl-round .h2-ttl::after{
    bottom: -2.667vw;
    border-left: 3.2vw solid transparent;
    border-right: 3.2vw solid transparent; 
    border-top: 2.933vw solid var(--main-color);
  }
  hr{
    margin: 8vw 5%;
  }
  .case-item .ttl-block-mid{
    flex-wrap: wrap;
    gap: 2.667vw;
    margin-bottom: 4vw;
  }
  .case-item .ttl-block-mid .no{
    border-radius: 3.733vw;
    font-size: 3.2vw;
    padding: 1.867vw 3.733vw;
    display: block;
  }
  .case-item .ttl-block-mid .ttl{
    font-size: 4vw;
    width: 100%;
  }
  .case-item .h4-ttl{
    margin-top: 6.667vw;
    font-size: 4.267vw;
  }
  .case-item .img{
    margin: 6.667vw auto 0;
    padding-inline: 5%;
  }
  .process.bg .before,
  .process.bg .after{
    border-radius: 2.667vw;
    padding: 0;
  }
  .process .before,
  .process .after{
    flex-wrap: wrap;
    gap: 0;
  }
  .process.bg .after{
    margin-top: 5.333vw;
    background: var(--bg-gray2-color);
  }
  .process .before .bef-ttl,
  .process .after .aft-ttl{
    border-radius: 1.067vw 1.067vw 0 0;
    font-size: 3.733vw;
    text-align: center;
    padding: 1.867vw;
    width: 100%;
  }
  .process .before ul,
  .process .after ul{
   width: 100%;
   padding: 3.2vw 5%;
  }
  .process .before ul li:not(:first-child),
  .process .after ul li:not(:first-child){
    margin-top: 2.667vw;
  }
  .process .before ul li,
  .process .after ul li{
    padding-left: 5.0vw;
    text-indent: -4.8vw;
    font-size: 3.1vw;
  }
  .process .before ul li::before,
  .process .after ul li::before{
    margin-right: 2.667vw;
    width: 2.133vw;
    height: 2.133vw;
    border-radius: 2.133vw;
  }
  .scene-content{
    padding-top: 10.667vw;
  }
  .scene-content .h2-ttl{
    font-size: 4.8vw;
  }
  .scene-item{
    border-radius: 5.333vw;
    padding: 4vw 0;
  }
  .scene-item:not(:first-child){
    margin-top: 5.333vw;
  }
  .scene-item .scene-inner{
    flex-wrap: wrap;
    gap: 5.333vw;
  }
  .scene-item .ttl-block-mid{
    margin-bottom: 3.2vw;
  }
  .scene-item .img{
    max-width: 100%;
  }
  .scene-item .img img{
    border-radius: 2.667vw;
  }
  .scene-item .h3-ttl{
    font-size: 4.8vw;
  }
  .scene-item .h3-ttl span{
    padding-top: 1.867vw;
    font-size: 3.733vw;
  }
  .scene-item .process .before,
  .scene-item .process .after{
    gap: 0;
  }
  .scene-item .process .after{
    margin-top: 2.133vw;
  }
  .scene-item .process .before .bef-ttl,
  .scene-item .process .after .aft-ttl{
    border-radius: 1.067vw;
    font-size: 3.733vw;
    padding: 2.667vw;
  }
  .scene-item .process .before ul,
  .scene-item .process .after ul{
   padding: 3.2vw 0;
  }
}


/*  plan
--------------------------------------------- */
.plan-content{
  background: var(--white-color);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 2.0rem;
  padding: 3.0rem 0;
}
.content{
  max-width: 96.0rem; 
  margin:0 auto; 
  padding-inline: max(3.0rem);
}
.plan-block{
  display: flex;
}
.price-item{
  width: 90%;
  text-align: center;
  padding: 3.0rem 5.0rem;
}
.price-item .ttl,
.price-item .number,
.price-item .price{
  font-weight: var(--fw-600);
}
.price-item .number{
  font-size: clamp(var(--fs-18), 1.719vw, var(--fs-22));
  color: #999;
  margin-top: 1.0rem;
}
.main-price .ttl{
  font-size: clamp(var(--fs-16), 1.719vw, var(--fs-22));
  color: var(--main-color);
}
.main-price .price{
  font-size: clamp(var(--fs-28), 2.5vw, var(--fs-32));
  margin-top: 4.5rem;
}
.main-price .price span{
  font-size: clamp(var(--fs-20), 1.875vw, var(--fs-24));
}
.main-price .txt-min{
  margin-top: 4.5rem;
}
.add-price{
  background: var(--bg-orange-color);
  border-radius: 2.0rem;
  margin-top: 7.0rem;
}
.add-price .ttl{
  font-size: clamp(var(--fs-14), 1.25vw, var(--fs-16));
  color: var(--orange-color);
}
.add-price .price{
  font-size: clamp(var(--fs-20), 1.875vw, var(--fs-24));
  margin-top: 2.0rem;
}
.add-price .price span{
  font-size: clamp(var(--fs-18), 1.563vw, var(--fs-20));
}
.add-price .txt-min{
  margin-top: 2.0rem;
}
@media  only screen and (max-width: 1024px){
  .price-item{
    width: 100%;
    padding: 3.0rem;
  }
}
@media  only screen and (max-width: 767px){
  .plan .section-inner{
    padding-bottom: 0;
  }
  .plan-content{
    border-radius: 5.333vw;
    padding: 8vw 0 6.667vw;
  }
  .content{
    padding-inline: 5%;
  }
  .plan-block{
    flex-wrap: wrap;
  }
  .price-item{
    width: 100%;
    padding: 0 5% 8vw;
  }
  .price-item .number{
    font-size: 3.733vw;
    margin-top: 2.133vw;
  }
  .price-item .price{
    margin-top: 2.667vw;
  }
  .price-item .price span{
    font-size: 3.733vw;
  }
  .price-item .txt-min{
    font-size: 3.467vw;
    margin-top: 2.667vw;
  }
  .main-price .ttl{
    font-size: 4.8vw;
  }
  .main-price .price{
    font-size: 5.333vw;
  }
  .add-price{
    border-radius: 5.333vw;
    padding: 5.333vw 5%;
    margin-top: 0;
  }
  .add-price .ttl{
    font-size: 4.267vw;
  }
  .add-price .price{
    font-size: 4.8vw;
  }
}


/*  device
--------------------------------------------- */
.device-content{
  background: var(--white-color);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 2.0rem;
  padding: 6.0rem 0 4.0rem;
}
.series-block:not(:first-child){
  margin-top: 6.0rem;
}
.series-block .ttl-btn{
  text-align: center;
}
.series-block .ttl-btn .h3-ttl{
  position: relative;
  color: var(--black-color);
  display: inline-block;
  padding-right: 5.2rem;
}
.series-block .ttl-btn .h3-ttl::after{
  position: absolute;
  content: "";
  top: 50%;
  transform: translateY(-50%);
  right: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 4.2rem;
  height: 4.2rem;
  background: url(../../assets/images/icon/icon_arrow.svg) no-repeat center / contain;
  transition: none; 
  animation: none; 
  pointer-events: none;
  transition: all 0.3s ease-out; 
}
@media (hover: hover) and (pointer: fine) {
  .series-block .ttl-btn a:hover .h3-ttl::after{
    right: -5px;
    transition: all 0.3s ease-out; 
  }
}
.desc-list{
  width: 65.0rem;
  margin: 2.0rem auto 0;
}
.desc-list dl{
  display: flex;
  align-items: baseline;
  gap: 1.0rem;
  font-size: var(--fs-14);
}
.desc-list dl:not(:first-child){
  margin-top: 0.8rem;
}
.desc-list dt{
  background: #D9D9D9;
  border-radius: 1.0rem;
  width: 14.0rem;
  text-align: center;
  padding: 0.8rem 0;
}
.series-item{
  text-align: center;
  margin-top: 1.0rem;
}
.series-item .ttl{
  padding-top: 2.0rem;
}
.series-item .ttl,
.series-item .number{
  font-size: var(--fs-12);
  line-height: 1.8em;
}

@media  only screen and (max-width: 767px){
  .device-content{
    border-radius: 5.333vw;
    padding: 10.667vw 0 10.667vw;
  }
  .series-block:not(:first-child){
    margin-top: 8vw;
    padding-top: 10.667vw;
    border-top: 1px solid #CACACA;
  }
  .series-block .ttl-btn{
    text-align: left;
  }
  .series-block .ttl-btn .h3-ttl{
    font-size: 4.533vw;
    display: block;
    padding-right: 9.333vw;
  }
  .series-block .ttl-btn .h3-ttl::after{
    right: 0;
    width: 8vw;
    height: 8vw;
  }
  @media (hover: hover) and (pointer: fine) {
    .series-block .ttl-btn a:hover .h3-ttl::after{
      right: -1.333vw;
    }
  }
  .desc-list{
    width: 100%;
    margin: 4.533vw auto 0;
  }
  .desc-list dl{
    flex-wrap: wrap;
    gap: 1.6vw;
    font-size: 3.467vw;
  }
  .desc-list dl:not(:first-child){
    margin-top: 2.667vw;
  }
  .desc-list dt{
    border-radius: 1.067vw;
    width: 37.333vw;
    padding: 2.133vw 0;
  }
  .desc-list dd{
    line-height: 1.6em;
  }
  .series-item{
    margin-top: 2.667vw;
  }
  .series-item .ttl{
    padding-top: 2.667vw;
  }
  .series-item .ttl,
  .series-item .number{
    font-size: 3.2vw;
    line-height: 1.8em;
  }
}


/*  flow
--------------------------------------------- */
.flow-item{
  background: var(--white-color);
  border-radius: 0.4rem;
  padding: 3.0rem 2.8rem;
  position: relative;
  display: flex;
  flex-direction: column;
}
.flow-item .number,
.flow-item .ttl{
  color: var(--blue-color);
  font-weight: var(--fw-600);
  text-align: center;
}
.flow-item .number{
  font-size: var(--fs-14);
}
.flow-item .step-ttl-block{
  flex-grow: 1;
}
.flow-item .ttl{
  font-size: clamp(var(--fs-14), 1.25vw, var(--fs-16));
  line-height: 1.6em;
  margin-top: 2.0rem;
}
.flow-item .txt-min{
  margin-top: 2.5rem;
  flex-grow: 1;
  font-size: var(--fs-14);
}
.flow-movie-container{
  margin-top: 5.0rem;
}
.flow-item:not(:last-child)::after{
  position: absolute;
  top: 50%;
  right: clamp(-4.6rem, -3.906vw, -5.0rem);
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
  content: '';
  width: clamp(3.2rem, 2.969vw, 3.8rem);
  height: clamp(2.0rem, 1.875vw, 2.4rem);
  background: url(../../assets/images/icon/icon_arrow2.svg) no-repeat center;
  background-size: contain;
  z-index: 1;
}
.flow-btn-container{
  margin-top: 5.0rem;
}
.flow-btn-container .button-wrap{
  margin-top: 1.5rem;
}
.flow-btn-container .ttl-block-min.second{
  margin-top: 4.0rem;
}

@media  only screen and (max-width: 1024px){
  .flow-item:not(:last-child)::after{
    right: clamp(-3.8rem, -3.281vw, -4.2rem);
  }
}
@media  only screen and (max-width: 767px){
  .flow-item{
    border-radius: 1.067vw;
    padding: 6.667vw 8vw;
  }
  .step-ttl-block{
    display: flex;
    align-items: center;
    gap: 5.333vw;
  }
  .flow-item .number,
  .flow-item .ttl{
    text-align: left;
  }
  .flow-item .number{
    font-size: 3.733vw;
  }
  .flow-item .ttl{
    font-size: 3.733vw;
    margin-top: 0;
  }
  .flow-item .txt-min{
    font-size: 3.2vw;
    margin-top: 4vw;
  }
  .flow-movie-container{
    margin-top: 8vw;
  }
  .flow-item:not(:last-child)::after{
    top: unset;
    bottom: -3.6vw;
    left: calc( 50% - 3.6vw );
      transform: translateX(-50%);
      -webkit-transform: translateX(-50%);
      -ms-transform: translateX(-50%);
    width: 7.2vw;
    height: 6.4vw;
    transform: rotate(90deg);
  }
  .flow-btn-container{
    margin-top: 8vw;
  }
  .flow-btn-container .button-wrap{
    margin-top: 3.2vw;
  }
  .flow-btn-container .ttl-block-min.second{
    margin-top: 8vw;
  }
}

/*  network
--------------------------------------------- */
.network .section-inner{
  padding-bottom: 4.0rem;
}
.summary-txt{
  font-weight: var(--fw-600);
  font-size: var(--fs-16);
  line-height: 1.8em;
}
.network-container{
  margin-top: 7.0rem;
}

.network-block{
  /* position: relative; */
  width: 100%;
  height: 100%;
  /* aspect-ratio: 16 / 9; */
}
.iframe-block iframe{
  /* position: absolute;
  top: 0;
  left: 0; */
  width: 100%;
  height: 100%;
}
@media  only screen and (max-width: 1024px){
  .network-block{
    /* aspect-ratio: 16 / 10; */
  }
}
@media  only screen and (max-width: 767px){
  .network .section-inner{
    padding-bottom: 0;
  }
  .summary-txt{
    font-size: 3.733vw;
  }
  .network-container{
    margin-top: 7.667vw;
  }
  .network-block{
    /* aspect-ratio: 16 / 12; */
  }
}


/*  faq
--------------------------------------------- */
.faq .section-inner{
  padding-bottom: 5.0rem;
}
.acc-container {
  width: 100%;
}
.acc-list{
  line-height: 1.7em;
}
.acc-list:not(:first-child){
  margin-top: 3.0rem;
}
.acc-ttl {
  background: var(--bg-main-color);
  border-radius: 0.4rem;
  cursor: pointer;
  padding: 2.2rem 5.0rem 2.2rem 2.0rem;
  position: relative;
}
.acc-ttl.open{
  border-radius: 0.4rem 0.4rem 0 0;
}
.acc-ttl:before {
  content: "";
  display: inline-block;
  position: absolute;
  top: 48%;
  right: 2.0rem;
  transform: translateY(-50%) rotate(135deg);
  width: 12px;
  height: 12px;
  border-top: 2px solid var(--blue-color);
  border-right: 2px solid var(--blue-color);
  transition: .3s;
}
.acc-ttl.open:before {
  transform: rotate(-45deg);
}
.acc-txt {
  display: none;
  background: #F7F9FA;
  border-radius: 0 0 0.4rem 0.4rem;
  padding: 2.2rem 2.5rem 2.2rem 2.0rem;
}
.acc-q-ttl{
  position: relative;
  padding-left: 4.0rem;
}
.acc-q-ttl:before{
  position: absolute;
  top: 0;
  left: 0;
  content: "Q.";
  color: var(--blue-color);
  font-size: var(--fs-20);
  font-weight: var(--fw-600);
}
.acc-a-txt{
  position: relative;
  padding-left: 4.0rem;
}
.acc-a-txt:before{
  position: absolute;
  top: 0;
  left: 0;
  content: "A.";
  color: var(--orange-color);
  font-size: var(--fs-20);
  font-weight: var(--fw-600);
}
@media  only screen and (max-width: 767px){
  .faq .section-inner{
    padding-bottom: 0;
  }
  .acc-list:not(:first-child){
    margin-top: 5.333vw;
  }
  .acc-ttl {
    font-size: 3.2vw;
    border-radius: 1.067vw;
    padding: 5.333vw 12vw 5.333vw 4vw;
  }
  .acc-ttl.open{
    border-radius: 1.067vw 1.067vw 0 0;
  }
  .acc-ttl:before {
    top: 48%;
    right: 4vw;
    width: 3.467vw;
    height: 3.467vw;
    border-top: 0.533vw solid var(--blue-color);
    border-right: 0.533vw solid var(--blue-color);
  }
  .acc-txt {
    font-size: 3.2vw;
    border-radius: 0 0 1.067vw 1.067vw;
    padding: 5.333vw 5.867vw 5.333vw 4vw;
  }
  .acc-q-ttl{
    padding-left: 9.333vw;
  }
  .acc-q-ttl:before{
    font-size: 5.333vw;
  }
  .acc-a-txt{
    padding-left: 9.333vw;
  }
  .acc-a-txt:before{
    font-size: 5.333vw;
  }
}


/*  download
--------------------------------------------- */
.download .wrap-min{
  max-width: 80.0rem; margin:0 auto; padding-inline: max(4.0rem);
}
.download .section-inner{
  padding-top: 5.0rem;
}
.download-block{
  background: var(--main-color);
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.1);
  border-radius: 0.4rem;
  padding: 3.0rem;
}
.download-inner{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 3.0rem;
  position: relative;
}
.download-inner .ttl-item{
  min-width: 33.0rem;
}
.download-block .ttl-item .en-ttl{
  color: var(--white-color);
}
.download-inner .ttl-item .text{
  color: var(--white-color);
  font-size: clamp(var(--fs-16), 1.406vw, var(--fs-18));
  margin: 0 auto;
  width: fit-content;
}
.download-inner .ttl-block-min{
  margin-bottom: 1.5em;
}
.download-inner .button-border{
  margin-top: 1.5rem;
}
.download-inner .txt-item{
  background: var(--main-color);
  border-radius: 0 0.4rem 0.4rem 0;
  width: 23.0rem;
  display: flex;
  align-items: center;
}
.download-inner .file-item{
  width: 100%;
}
@media  only screen and (max-width: 1024px){
  .download-block .ttl-item .en-ttl,
  .download-inner .ttl-block-min{
    margin-bottom: 0.5em;
  }
  .download-inner .txt-item{
    width: 20.0rem;
  }
}
@media  only screen and (max-width: 767px){
  .download .wrap-min{
    padding-inline: 5%;
  }
  .download .section-inner{
    padding-top: 10.667vw;
  }
  .download-block{
    border-radius: 1.067vw;
    padding: 5%;  
  }
  .download-inner{
    gap: 5.333vw;
  }
  .download-inner .ttl-item{
    min-width: unset;
  }
  .download-block .ttl-item .en-ttl,
  .download-block .ttl-block-min{
    margin-bottom: 1.733vw;
  }
  .download-block .ttl-item .text{
    font-size: 3.733vw;
    margin: unset;
  }
  .download-inner .txt-item{
    width: 30.667vw;
  }
  .download-block .button-border{
    margin-top: 2.733vw;
  }
}

/*  fixedbtn
--------------------------------------------- */
#fixedbtn {
  display: none;
}
.fixedbtn {
  width: 19.0rem;
  height: 19.0rem;
  position: fixed;
  right: 3.0rem;
  bottom: 3.0rem;
  background: var(--main-color);
  border: 2px solid var(--main-color);
  filter: drop-shadow(0 0 5px rgba(0,0,0,0.1));
  border-radius: 50%;
  transition: border-radius .3s, background-color .3s, opacity .3s;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  z-index: 5;
  text-align: center;
}
.fixedbtn .maintxt,
.fixedbtn .subtxt{
  display: block;
  font-weight: var(--fw-600);
  line-height: 1.3em;
}
.fixedbtn .maintxt{
  color: var(--white-color);
  font-size: var(--fs-24);
}
.fixedbtn .subtxt{
  color: var(--white-color);
  font-size: var(--fs-20);
}
.fixedbtn .arrow {
  position: relative;
  width: 10.0rem;
  height: 0.5rem;
  margin: 1.0rem auto 0;
}
.fixedbtn .arrow:before,
.fixedbtn .arrow:after {
  position: absolute;
  top: 50%;
  right: 0;
  height: 1px;
  background: var(--white-color);
  content: '';
}
.fixedbtn .arrow:before {
  width: 10.0rem;
  transform: translateY(-50%);
}
.fixedbtn .arrow:after {
  width: 8px;
  transform: translateY(-50%) rotate(45deg);
  transform-origin: right center;
}
@media (hover: hover) and (pointer: fine) {
  .fixedbtn:hover{ background: var(--white-color);  transition: border-radius .3s, background-color .3s, opacity .3s;}
  .fixedbtn:hover .maintxt{ color: var(--main-color);}
  .fixedbtn:hover .subtxt{ color: var(--main-color);}
  .fixedbtn:hover .arrow:before,
  .fixedbtn:hover .arrow:after { background: var(--main-color);}
}
@media  only screen and (max-width: 1024px){
  .fixedbtn {
    width: 16.0rem;
    height: 16.0rem;
    right: 2.0rem;
    bottom: 2.0rem;
    display: flex !important;
  }
  .fixedbtn .maintxt{
    font-size: var(--fs-20);
  }
  .fixedbtn .subtxt{
    font-size: var(--fs-17);
  }
  .fixedbtn .arrow {
    width: 8.0rem;
  }
  .fixedbtn .arrow:before {
    width: 8.0rem;
  }
  .fixedbtn .arrow:after {
    width: 6px;
  }
}
@media  only screen and (max-width: 767px){
  .fixedbtn {
    width: 90%;
    max-width: 100%;
    height: auto;
    right: auto;
    bottom: 5.333vw;
    border: 2px solid var(--main-color);
    border-radius: 1.6vw;
    box-shadow: 0 0 0 2px #E3EFFF; /* 外側の線 */
    transition: background-color .3s, opacity .3s;
    filter: unset;
    margin: 0 5%;
    padding: 5.333vw 0;
  }
  .fixedbtn-container{
    font-size: 0;
    display: flex;
    align-items: center;
  }
  .fixedbtn .maintxt,
  .fixedbtn .subtxt{
    display: inline-block;
    line-height: normal;
  }
  .fixedbtn .maintxt{
    font-size: 4.8vw;
  }
  .fixedbtn .maintxt br{
    display: none;
  }
  .fixedbtn .maintxt .sp-mintxt,
  .fixedbtn .subtxt{
    font-size: 3.733vw;
  }
  .fixedbtn .arrow:before, 
  .fixedbtn .arrow:after{
    display: none;
  }
  .fixedbtn .arrow {
    width: 8vw;
    height: 8vw;
    background: url(../../assets/images/icon/icon_arrow.svg) no-repeat center;
    background-size: 8vw 8vw;
    filter: brightness(0) saturate(100%) invert(97%) sepia(1%) saturate(2%) hue-rotate(331deg) brightness(109%) contrast(100%);
    margin: 0 0 0 1.333vw;
  }
  @media (hover: hover) and (pointer: fine) {
    .fixedbtn:hover .arrow{ 
      filter: brightness(0) saturate(100%) invert(47%) sepia(65%) saturate(474%) hue-rotate(173deg) brightness(92%) contrast(81%);
    }
  }
}


/*  pagetop
--------------------------------------------- */
#pagetop {
  position: absolute;
  top: -4.5rem;
  right: 0;
  z-index: 1;
  width: 4.5rem;
  height: 4.5rem;
  background: var(--blue-color);
  transition: 0.3s;
}
@media (hover: hover) and (pointer: fine) {
  #pagetop:hover{ background: #064592; transition: 0.3s;}
}
.pagetop{
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.pagetop-arrow {
  width: 1.2rem;
  height: 1.2rem;
  border-top: 2px solid #fff;
  border-right: 2px solid #fff;
  transform: translateY(20%) rotate(-45deg);
}
@media  only screen and (max-width: 767px){  
  #pagetop {
    top: -12vw;
    width: 12vw;
    height: 12vw;
  }
  .pagetop-arrow {
    width: 3.2vw;
    height: 3.2vw;
    border-top: 0.533vw solid #fff;
    border-right: 0.533vw solid #fff;
  }
}


/*  footer
--------------------------------------------- */
.footer{
  background: var(--main-color);
  color: var(--white-color);
  padding: 7.5rem 0 4.0rem;
  position: relative;
}
.footer-logo{
  padding: 3.5rem 0;
  width: 12.5rem;
  margin: 0 auto;
}
.footer-logo img{
  width: 100%;
}
.footer-menu-container{
  padding: 6.5rem 0;
}
.footer-sub-list{
  display: flex;
  justify-content: space-between;
}
.footer-sub-link{
  color: var(--white-color);
  display: block;
  font-size: clamp(var(--fs-12), 1.016vw, var(--fs-13));
  font-weight: var(--fw-400);
  text-decoration: underline;
  text-underline-offset: 0.3rem;
}
.footer-sub-link.external-link::after{
  content: '';
  display: inline-block;
  width: 11px;
  height: 12px;
  background-image: url(../../assets/images/icon/btn_external_wht.svg);
  background-repeat: no-repeat;
  background-size: contain;
  margin-left: 0.6rem;
  vertical-align: text-bottom;
}
.footer-copy{
  font-size: var(--fs-12);
  text-align: center;
}
@media (hover: hover) and (pointer: fine) {
  .footer-sub-link:hover{ color: var(--white-color); opacity: .6;}
}
@media  only screen and (max-width: 1024px){  
  .footer{
    padding: 4.5rem 0 4.0rem;
  }
  .footer-logo{
    padding: 1.5rem 0;
  }
  .footer-menu-container{
    padding: 3.5rem 0;
  }
  .footer-sub-list{
    flex-wrap: wrap;
    gap: 1.5rem;
  }
  .footer-sub-item{
    width: 100%;
  }
}
@media  only screen and (max-width: 767px){
  .footer{
    padding: 0 0 29vw;
  }
  .footer-logo{
    padding: 8vw 0;
    width: 20vw;
  }
  .footer-menu-container{
    padding: 0 0 8vw;
  }
  .footer-sub-list{
    gap: 4vw;
  }
  .footer-sub-link{
    font-size: 2.933vw;
  }
  .footer-copy{
    font-size: 2.933vw;
  }
}

/*  page-container
--------------------------------------------- */
.page-wrapper{
  
}