@charset "UTF-8";
.gr .gr_wrap {
  backface-visibility: hidden;
  -webkit-backface-visibility: hidden;
  -webkit-transform-style: preserve-3d;
  z-index: 2;
  position: relative;
}
.gr h3 {
  transition: filter 0.1s ease;
}
.gr h3:before {
  transition: transform 0.15s ease;
}
.gr h3.on:before {
  opacity: 0;
}
.gr h3.on:after {
  opacity: 1 !important;
}
.is_pc .gr h3:hover, .is_sp .gr h3.touch {
  filter: contrast(1.25);
}
.is_pc .gr h3:hover:before, .is_sp .gr h3.touch:before {
  transform: translateY(-50%) rotate(90deg) !important;
}
.gr .btn_close {
  transition: filter 0.1s ease;
}
.is_pc .gr .btn_close:hover, .is_sp .gr .btn_close.touch {
  filter: contrast(0.9);
}
.gr a {
  padding-bottom: 1px;
  border-bottom: 1px solid #002e9f;
  transition: border 0.15s ease;
}
.is_pc .gr a:hover, .is_sp .gr a.touch {
  border-bottom: 1px solid transparent;
}

.btn_cv_fix {
  opacity: 1;
  transition: transform, opacity;
  transition-duration: 0.35s;
  transition-timing-function: cubic-bezier(0.215, 0.61, 0.355, 1);
}
.btn_cv_fix a img {
  transition: filter 0.1s ease;
}
.is_pc .btn_cv_fix a:hover img, .is_sp .btn_cv_fix a.touch img {
  filter: contrast(1.25);
}
.btm .btn_cv_fix {
  opacity: 0 !important;
  pointer-events: none !important;
}
@media screen and (min-width: 751px) {
  .btm .btn_cv_fix {
    transform: translateX(100%);
  }
}

.btn_area .btn_cv a img {
  transition: filter 0.1s ease;
}
.is_pc .btn_area .btn_cv a:hover img, .is_sp .btn_area .btn_cv a.touch img {
  filter: contrast(1.25);
}

.impression .btn_detail {
  transition: filter 0.1s ease;
}
.impression .btn_detail:before {
  transition: transform 0.15s ease;
}
.is_pc .impression .btn_detail:hover, .is_sp .impression .btn_detail.touch {
  filter: contrast(1.25);
}
.is_pc .impression .btn_detail:hover:before, .is_sp .impression .btn_detail.touch:before {
  transform: translateY(-50%) rotate(90deg) !important;
}
.impression a {
  color: #000;
  padding-bottom: 1px;
  border-bottom: 1px solid #000;
  transition: border 0.15s ease;
}
.is_pc .impression a:hover, .is_sp .impression a.touch {
  border-bottom: 1px solid transparent;
}

#flow a {
  padding-bottom: 1px;
  border-bottom: 1px solid #002e9f;
  transition: border 0.15s ease;
}
.is_pc #flow a:hover, .is_sp #flow a.touch {
  border-bottom: 1px solid transparent;
}

#info a {
  padding-bottom: 1px;
  border-bottom: 1px solid transparent;
  transition: border 0.15s ease;
}
.is_pc #info a:hover, .is_sp #info a.touch {
  border-bottom: 1px solid #002e9f;
}

.btn_pagetop:after {
  transition: transform 0.15s ease;
}
.is_pc .btn_pagetop:hover:after, .is_sp .btn_pagetop.touch:after {
  transform: translateY(-5px) scale(1.05);
}

/*------------------------------------------------------------------------------------------
*
*
    common_pc.css
*
*
------------------------------------------------------------------------------------------ */
@media screen and (min-width: 751px) {
  /*------------------------------------------------------------------------------------------
  *
  *
      min-width : 751px
  *
  *
  ------------------------------------------------------------------------------------------ */
  /* --------------------------------------------------
  *
      common settings
  *
  -------------------------------------------------- */
  body {
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
  }
  br.sp {
    display: none !important;
  }
  img.sp {
    display: none;
  }
  .switch_sp,
  .switch_sp * {
    display: none;
  }
  /* --------------------------------------------------
  * 
      header
  *
  -------------------------------------------------- */
  /* --------------------------------------------------
  * 
      footer
  *
  -------------------------------------------------- */
}
/* -------------------------------------------------- */
@media screen and (min-width: 1120px) {
  /* --------------------------------------------------
  * 
      header
  *
  -------------------------------------------------- */
}
/* -------------------------------------------------- */
@media screen and (min-width: 751px) and (max-width: 1120px) {
  /* --------------------------------------------------
  * 
      header
  *
  -------------------------------------------------- */
}
/* -------------------------------------------------- */
/*------------------------------------------------------------------------------------------
*
*
    home_pc.css
*
*
------------------------------------------------------------------------------------------ */
.gr .inner {
  display: none;
}

@media screen and (min-width: 751px) {
  main {
    max-width: 100vw;
    overflow: hidden;
  }
  /*------------------------------------------------------------------------------------------
  *
  *
      min-width : 751px
  *
  *
  ------------------------------------------------------------------------------------------ */
  .btn_cv_fix {
    position: fixed;
    bottom: 25px;
    right: 0;
    z-index: 10;
  }
  .btn_cv_fix img {
    width: 324px;
  }
  header {
    height: 106px;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  header .logo {
    width: 312px;
  }
  #kv {
    font-feature-settings: "palt" 1;
    width: 100%;
    height: 663px;
    background-repeat: no-repeat;
    background-image: url(../images/pc/kv.jpg);
    background-position: center;
    background-size: cover;
    position: relative;
  }
  #kv .pic img {
    display: none;
  }
  #kv .copy {
    width: 758px;
    height: auto;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
  #kv .copy h1 {
    width: 100%;
    position: relative;
    z-index: 2;
  }
  #kv .copy h1 img {
    width: 100%;
  }
  #kv .desc {
    width: 100%;
    height: 122px;
    background-color: rgba(255, 255, 255, 0.7);
    position: absolute;
    bottom: 0;
    left: 0;
  }
  #kv .desc .inner {
    width: 100%;
    max-width: 960px;
    height: 122px;
    margin: 0 auto;
    padding: 28px 0;
    display: flex;
    justify-content: center;
    align-items: center;
    box-sizing: border-box;
    color: #002e9f;
    white-space: nowrap;
  }
  #kv .desc .inner .col {
    width: 50%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
  }
  #kv .desc .inner .col.l:before {
    content: "";
    width: 2px;
    height: 100%;
    background-color: rgba(161, 161, 161, 0.3);
    display: block;
    position: absolute;
    top: 0;
    left: 0;
  }
  #kv .desc .inner .col.l:after {
    content: "";
    width: 2px;
    height: 100%;
    background-color: rgba(161, 161, 161, 0.3);
    display: block;
    position: absolute;
    top: 0;
    right: 0;
  }
  #kv .desc .inner .col.l .c.r {
    letter-spacing: 0.22em;
  }
  #kv .desc .inner .col.r:after {
    content: "";
    width: 2px;
    height: 100%;
    background-color: rgba(161, 161, 161, 0.3);
    display: block;
    position: absolute;
    top: 0;
    right: 0;
  }
  #kv .desc .inner .col.r .c.r {
    letter-spacing: -0.02em;
  }
  #kv .desc .inner .col .c.l {
    padding-right: 2.6785714286vw;
    font-size: 2.1428571429vw;
    line-height: 1.25em;
    letter-spacing: 0.06em;
  }
  /* =========================
     Active tab（段差＋色）
  ========================= */
  /* 非アクティブ側は下げる */
  /* アクティブ時：中央の境界線を消す*/
  /* data-step を表示 */
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #kv .desc .inner .col .c.l {
    padding-right: 30px;
    font-size: 24px;
  }
}
@media screen and (min-width: 751px) {
  #kv .desc .inner .col .c.r {
    font-size: 4.2857142857vw;
    font-weight: 700;
  }
  #kv .desc .inner .col .c.r .m {
    font-size: 3.2142857143vw;
  }
  #kv .desc .inner .col .c.r .s {
    font-size: 1.4285714286vw;
    font-weight: 400;
    letter-spacing: 0.06em;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #kv .desc .inner .col .c.r {
    font-size: 48px;
  }
  #kv .desc .inner .col .c.r .m {
    font-size: 36px;
  }
  #kv .desc .inner .col .c.r .s {
    font-size: 16px;
  }
}
@media screen and (min-width: 751px) {
  .kv {
    font-feature-settings: "palt" 1;
    width: 100%;
    height: 663px;
    background-repeat: no-repeat;
    background-image: url(../images/pc/kv.jpg);
    background-position: center;
    background-size: cover;
    position: relative;
    color: #fff;
    box-sizing: border-box;
    display: flex;
    align-items: center;
  }
  .kv-inner {
    max-width: 785px;
    margin: 0 auto;
    text-align: center;
  }
  .kv-title span {
    position: relative;
    display: inline-block;
    font-size: 50px;
    font-weight: 800;
    text-align: center;
    letter-spacing: 10px;
    line-height: 1.2;
    padding-bottom: 8px;
    z-index: 1;
    white-space: nowrap;
  }
  .kv-title span small {
    font-size: 40px;
    font-weight: inherit;
  }
  .kv-title span::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: 6px;
    transform: translateX(-50%);
    width: 100%;
    height: 14px;
    background: #1e88e5;
    border-radius: 8px;
    z-index: -1;
  }
  .kv-title.sp {
    display: none;
  }
  .kv-sub {
    font-size: 33px;
    font-weight: 700;
    margin: 0px 0 40px;
    letter-spacing: 3px;
  }
  .kv-sub small {
    font-size: 26px;
  }
  .kv-desc {
    font-size: 20px;
    letter-spacing: 6px;
  }
  .kv-logo img {
    display: block;
    width: 100%;
    max-width: 420px;
    margin: 0 auto 20px;
  }
  .kv-boxes {
    display: flex;
    justify-content: center;
    gap: 33px;
  }
  .kv-box {
    background: #2B2727;
    padding: 25px 0px;
    width: 230px;
    height: 130px;
    box-sizing: border-box;
  }
  .kv-box .box-main {
    font-size: 35px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1.2;
  }
  .kv-box .box-sub {
    font-size: 24px;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: 12px;
  }
  #mov {
    padding: 55px 0 55px 0;
    position: relative;
  }
  #mov .v {
    text-align: center;
  }
  #mov .v iframe {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    height: 48.2142857143vw !important;
    max-height: 540px !important;
  }
  #feature {
    padding-bottom: 120px;
    background-color: #e3f0f8;
    overflow: hidden;
  }
  #feature h2 {
    padding: 45px 0 50px 0;
    font-size: 38px;
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #002e9f;
    text-align: center;
    position: relative;
  }
  #feature h2 .bd {
    background: linear-gradient(transparent 30px, #fffe00 10px);
    border-bottom: 4px solid #fffe00;
  }
  #feature .gr_wrap {
    overflow: hidden;
    border-radius: 10px;
    background-color: #fff;
    box-shadow: 3px 3px 13px rgba(0, 0, 0, 0.1);
  }
  #feature .gr {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    margin: 0 auto;
    margin-bottom: 55px;
    position: relative;
  }
  #feature .gr:last-child {
    margin-bottom: 0;
  }
  #feature .gr .no {
    position: absolute;
    top: -16px;
    left: 0;
    z-index: 10;
    pointer-events: none;
  }
  #feature .gr .no img {
    width: 98px;
  }
  #feature .gr h3 {
    height: 117px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    font-size: 24px;
    letter-spacing: 0.06em;
    background-image: url(../images/pc/bg_stripe.png);
    position: relative;
    cursor: pointer;
    box-shadow: 0px 3px 13px rgba(0, 0, 0, 0.1);
    white-space: nowrap;
  }
  #feature .gr h3:before {
    content: "";
    width: 2.0535714286vw;
    height: 2.0535714286vw;
    background-image: url(../images/ico_plus.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
    position: absolute;
    top: 50%;
    right: 4.1071428571vw;
    transform: translateY(-50%);
  }
  #feature .gr h3:after {
    content: "";
    width: 2.0535714286vw;
    height: 2.0535714286vw;
    background-image: url(../images/ico_minus.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    display: block;
    position: absolute;
    top: 50%;
    right: 4.1071428571vw;
    transform: translateY(-50%);
    opacity: 0;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #feature .gr h3:before {
    width: 23px;
    height: 23px;
    right: 46px;
  }
  #feature .gr h3:after {
    width: 23px;
    height: 23px;
    right: 46px;
  }
}
@media screen and (min-width: 751px) {
  #feature .inner {
    width: 78.5714285714vw !important;
    max-width: 880px !important;
    margin: 0 auto;
  }
  #feature .inner dl {
    padding-top: 60px;
    width: 100%;
    display: flex;
    justify-content: space-between;
  }
  #feature .inner dl dt {
    font-size: 1.7857142857vw;
    line-height: 2em;
    letter-spacing: 0.06em;
    white-space: nowrap;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #feature .inner dl dt {
    font-size: 20px;
  }
}
@media screen and (min-width: 751px) {
  #feature .inner dl dt .s {
    font-size: 12px;
  }
  #feature .inner dl dd .img {
    padding-left: 40px;
  }
  #feature .inner dl dd .img img {
    width: 100%;
  }
  #feature .inner .note {
    margin-top: 20px;
    font-size: 12px;
    line-height: 1.6666666667em;
  }
  #feature .inner h4 {
    margin-top: 50px;
    width: 100%;
    height: 68px;
    background-color: #466fce;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 20px;
    letter-spacing: 0.06em;
  }
  #feature .inner h4.sub {
    margin-top: 85px;
    margin-bottom: 60px;
    background-color: inherit;
    background-image: url(../images/pc/bg_sub_title.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center bottom;
  }
  #feature .inner h5 {
    padding: 55px 0 0 0;
    font-size: 38px;
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #002e9f;
    text-align: center;
    position: relative;
  }
  #feature .inner h5 .bd {
    background: linear-gradient(transparent 30px, #fffe00 10px);
    border-bottom: 4px solid #fffe00;
  }
  #feature .inner dl.rev {
    flex-direction: row-reverse;
  }
  #feature .inner dl.rev dt {
    width: 50%;
    text-align: center;
  }
  #feature .inner dl.rev dt .d {
    display: inline-block;
    text-align: left;
  }
  #feature .inner dl.rev dt .s {
    margin-top: 0.8928571429vw;
    font-size: 1.0714285714vw;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #feature .inner dl.rev dt .s {
    margin-top: 10px;
    font-size: 12px;
  }
}
@media screen and (min-width: 751px) {
  #feature .inner dl.rev dd {
    width: 50%;
    padding: 0;
  }
  #feature .desc {
    padding-top: 50px;
    margin-bottom: -15px;
    font-size: 20px;
    letter-spacing: -0.04em;
    line-height: 1.8em;
  }
  #feature .desc .s {
    margin-top: 10px;
    font-size: 12px;
    letter-spacing: inherit;
  }
  #feature .g1 .rev {
    margin-bottom: 16.9642857143vw;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #feature .g1 .rev {
    margin-bottom: 190px;
  }
}
@media screen and (min-width: 751px) {
  #feature .g2 dl dd .i1 {
    width: 16.6071428571vw !important;
    max-width: 186px !important;
    margin-right: 6.25vw;
  }
  #feature .g2 dl dd .i2 {
    width: 24.8214285714vw !important;
    max-width: 278px !important;
    margin: 0 auto;
    margin-left: 6.6964285714vw;
  }
  #feature .g2 .rev dt {
    padding-left: 3.5714285714vw;
    padding-top: 2.6785714286vw;
    text-align: left !important;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #feature .g2 dl dd .i1 {
    margin-right: 70px;
  }
  #feature .g2 dl dd .i2 {
    margin-left: 75px;
  }
  #feature .g2 .rev dt {
    padding-left: 40px;
    padding-top: 30px;
  }
}
@media screen and (min-width: 751px) {
  #feature .g3 dl dd .i1 {
    width: 29.4642857143vw !important;
    max-width: 330px !important;
    margin-right: 2.6785714286vw;
  }
  #feature .g3 dl dd .i2 {
    width: 23.3035714286vw !important;
    max-width: 261px !important;
    margin: 0 auto;
    margin-top: 1.3392857143vw;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  #feature .g3 dl .i1 {
    margin-right: 30px;
  }
  #feature .g3 dl .i2 {
    margin-top: 15px;
  }
}
@media screen and (min-width: 751px) {
  #feature .g4 dl dd .i1 {
    width: 32.0535714286vw !important;
    max-width: 359px !important;
  }
  #feature .g4 dl dd .i2 {
    width: 76.3392857143vw !important;
    max-width: 855px !important;
    margin: 0 auto;
    margin-top: -35px;
    padding: 0;
  }
  #feature .g4 .row {
    display: block;
  }
  #feature .g4 .row .note {
    margin-top: 40px;
    padding: 0 30px;
    line-height: 2.0833333333em;
  }
  #feature .btn_close {
    width: 135px;
    height: 36px;
    margin: 0 auto;
    margin-top: 70px;
    margin-bottom: 70px;
    background-color: #e3f0f8;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #002e9f;
    font-size: 14px;
    letter-spacing: 0.06em;
    border-radius: 50px;
    position: relative;
    cursor: pointer;
  }
  #feature .btn_close:before {
    content: "";
    display: block;
    width: 10px;
    height: 10px;
    background-repeat: no-repeat;
    background-image: url(../images/ico_close.png);
    background-size: contain;
    position: absolute;
    top: 13px;
    left: 28px;
  }
  #feature .outline_table {
    padding: 0 30px;
    padding-top: 24px;
  }
  #feature .outline_table table {
    width: 100%;
    height: 143px;
    margin-bottom: 12px;
  }
  #feature .outline_table table.row_s {
    height: auto;
  }
  #feature .outline_table table th {
    width: 230px;
    padding: 15px 0;
    font-size: 20px;
    background-color: #e3f0f8;
    color: #002e9f;
    vertical-align: middle;
    text-align: center;
  }
  #feature .outline_table table td {
    font-size: 24px;
    line-height: 1.25em;
    background-color: #ebebeb;
    vertical-align: middle;
    text-align: center;
    border-left: 8px solid #fff;
  }
  #feature .outline_table table td .s {
    font-size: 14px;
  }
  #feature .outline_table table.rs th {
    border-bottom: 2px solid #fff;
  }
  #feature .video {
    padding-top: 32px;
  }
  #feature .video h5 {
    width: 400px;
    height: 88px;
    padding: 0;
    padding-top: 18px;
    display: block;
    margin: 0 auto;
    margin-bottom: 15px;
    background-image: url(../images/pc/gr_04_s-ttile-bg.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    font-size: 24px;
    letter-spacing: 0.06em;
    color: #fff;
    box-sizing: border-box;
  }
  #feature .video .v iframe {
    width: 77.6785714286vw !important;
    max-width: 870px !important;
    height: 43.6607142857vw !important;
    max-height: 489px !important;
  }
  .btn_area {
    padding: 30px 0;
    text-align: center;
  }
  .btn_area img {
    width: 600px;
  }
  .impression#cost {
    background-color: #e3f0f8;
    padding-bottom: 55px;
  }
  .impression#voice {
    padding-top: 58px;
    padding-bottom: 100px;
  }
  .impression#voice .name {
    transform: translateY(-12.9464285714vw) !important;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  .impression#voice .name {
    transform: translateY(-145px) !important;
  }
}
@media screen and (min-width: 751px) {
  .impression#voice .h {
    padding-bottom: 5.3571428571vw;
    align-items: center;
    padding-top: 58px;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  .impression#voice .h {
    padding-bottom: 60px;
  }
}
@media screen and (min-width: 751px) {
  .impression#voice .h .desc .box {
    background: #fff;
    padding: 5px 10px;
    line-height: 1.6;
    margin: 0px 0 20px;
  }
  .impression .inner {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    margin: 0 auto;
  }
  .impression h3 {
    height: 132px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    font-size: 28px;
    letter-spacing: 0.06em;
    background-image: url(../images/pc/bg_stripe_l.png);
    position: relative;
    box-shadow: 0px 3px 13px rgba(0, 0, 0, 0.1);
  }
  .impression .h {
    padding: 20px 0 30px 0;
    display: flex;
    align-items: center;
  }
  .impression .h .profile {
    width: 50%;
    position: relative;
  }
  .impression .h .profile .pic img {
    width: 100%;
  }
  .impression .h .profile .name {
    padding: 1.7857142857vw 2.2321428571vw;
    background-color: #fff;
    box-sizing: border-box;
    font-size: 1.7857142857vw;
    line-height: 1.65em;
    letter-spacing: 0.06em;
    position: absolute;
    top: 100%;
    left: 0;
    white-space: nowrap;
    transform: translateY(-3.5714285714vw);
    width: 32vw;
    max-width: 325px;
  }
  .impression .h .profile .name .m {
    font-size: 1.6071428571vw;
  }
  .impression .h .desc {
    width: 50%;
    padding-left: 3.5714285714vw;
    box-sizing: border-box;
  }
  .impression .h .desc p {
    font-size: 1.7857142857vw;
    line-height: 1.75em;
    letter-spacing: 0.06em;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  .impression .h .profile .name {
    padding: 20px 25px;
    font-size: 20px;
    transform: translateY(-40px);
  }
  .impression .h .profile .name .m {
    font-size: 18px;
  }
  .impression .h .desc {
    padding-left: 40px;
  }
  .impression .h .desc p {
    font-size: 20px;
  }
}
@media screen and (min-width: 751px) {
  .impression .detail {
    padding-top: 8.0357142857vw;
  }
  .impression .detail p {
    margin-bottom: 2em;
    font-size: 1.7857142857vw;
    line-height: 1.75em;
    letter-spacing: 0.06em;
  }
  .impression .detail .caution p {
    margin-bottom: 5px;
    font-size: 12px;
    line-height: 1.6666666667em;
    letter-spacing: 0.04em;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  .impression .detail {
    padding-top: 90px;
  }
  .impression .detail p {
    font-size: 20px;
  }
}
@media screen and (min-width: 751px) {
  .impression p .c {
    color: #06339c;
    background: linear-gradient(transparent 15px, #fffe00 10px);
    border-bottom: 3px solid #fffe00;
  }
  .impression p .s {
    font-size: 1.0714285714vw;
  }
}
@media screen and (min-width: 751px) and (min-width: 1120px) {
  .impression p .s {
    font-size: 12px;
  }
}
@media screen and (min-width: 751px) {
  #flow {
    padding-top: 35px;
    margin-bottom: 35px;
  }
  #flow .inner {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    margin: 0 auto;
  }
  #flow h3 {
    height: 132px;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    font-size: 28px;
    letter-spacing: 0.06em;
    background-image: url(../images/pc/bg_stripe_l.png);
    position: relative;
    box-shadow: 0px 3px 13px rgba(0, 0, 0, 0.1);
  }
  #flow .desc {
    padding: 40px 0;
    text-align: center;
  }
  #flow .desc p {
    font-size: 20px;
    letter-spacing: 0.04em;
    line-height: 1.85em;
  }
  #flow table {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    overflow: hidden;
    word-wrap: break-word;
    overflow-wrap: break-word;
  }
  .isIE #flow table {
    table-layout: fixed;
  }
  #flow table tr {
    border-bottom: 15px solid #fff;
  }
  #flow table tr:first-child td:before {
    display: none !important;
  }
  #flow table th {
    vertical-align: top;
    padding: 35px 0 71px 0;
    height: 100%;
    min-height: 150px;
    width: 168px;
    min-width: 168px;
    position: relative;
    text-align: center;
    box-sizing: border-box;
    color: #fff;
    font-size: 18px;
    line-height: 1.5555555556em;
    letter-spacing: 0.06em;
  }
  #flow table th span {
    position: relative;
    z-index: 2;
  }
  .isIE #flow table th {
    line-height: 1.555em;
  }
  #flow table th:before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: #466fce;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 1;
  }
  .isIE #flow table th:before {
    line-height: 0;
    min-height: 9999px;
    z-index: 1;
  }
  #flow table th:after {
    content: "";
    width: 100%;
    height: 46px;
    display: block;
    background-image: url(../images/pc/flow_bg-title.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 2;
  }
  #flow table td {
    width: 100%;
    position: relative;
    padding-top: 25px;
    padding-bottom: 15px;
    padding-left: 70px;
    vertical-align: middle;
    box-sizing: border-box;
  }
  #flow table td:before {
    content: "";
    width: 100%;
    height: 1px;
    border-top: 1px dashed #5c80d4;
    display: block;
    position: absolute;
    left: 70px;
    top: 0;
    z-index: -1;
  }
  #flow table td .row {
    width: 100%;
    display: flex;
  }
  #flow table td .row .img {
    min-width: 170px;
  }
  #flow table td .row .t p {
    font-size: 18px;
    line-height: 1.8888888889em;
    letter-spacing: 0.06em;
  }
  #flow table td .row .t .note {
    margin-top: 5px;
    font-size: 12px;
  }
  #flow table td .example {
    padding: 0 25px;
    padding-top: 15px;
    padding-bottom: 35px;
  }
  #flow table td .example p {
    font-size: 18px;
    letter-spacing: 0.06em;
  }
  #flow table td .example .s {
    margin-top: 15px;
    font-size: 12px;
    display: block;
  }
  #flow table td .example h4 {
    padding: 10px 0;
    margin-bottom: 20px;
    margin-top: 25px;
    text-align: center;
    background-color: #eff8fd;
    font-size: 14px;
    letter-spacing: 0.06em;
  }
  #flow table td .example .img img {
    width: 59.9107142857vw !important;
    max-width: 671px !important;
  }
  #flow table .i1 img {
    width: 12.7678571429vw !important;
    max-width: 143px !important;
  }
  #flow table .i2 img {
    width: 7.4107142857vw !important;
    max-width: 83px !important;
  }
  #flow table .i4 img {
    width: 8.2142857143vw !important;
    max-width: 92px !important;
  }
  #flow table .i5 img {
    width: 12.7678571429vw !important;
    max-width: 143px !important;
  }
  #info {
    font-feature-settings: "palt" 1;
    padding: 75px 0 40px 0;
  }
  #info .inner {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    margin: 0 auto;
  }
  #info p {
    font-size: 14px;
    margin-bottom: 2em;
    letter-spacing: 0.06em;
    line-height: 1.8571428571em;
  }
  footer {
    height: 184px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #282828;
  }
  footer .btn_pagetop {
    width: 48px;
    height: 48px;
    margin-bottom: 20px;
    cursor: pointer;
    position: relative;
  }
  footer .btn_pagetop img {
    width: 48px;
    height: 48px;
    opacity: 0;
  }
  footer .btn_pagetop:after {
    content: "";
    display: block;
    width: 48px;
    height: 48px;
    text-align: center;
    background-image: url(../images/btn_pagetop.png);
    background-size: contain;
    background-position: center bottom;
    position: absolute;
    top: 0;
    left: 0;
  }
  footer .copyright {
    font-size: 10px;
    color: #fff;
    letter-spacing: 0.025em;
  }
  #flow {
    padding-top: 150px;
    padding-bottom: 110px;
  }
  #flow .txt_area {
    max-width: 756px;
    margin: 40px auto;
    letter-spacing: 2px;
    line-height: 1.5;
    margin-bottom: 10px;
  }
  #flow .txt_area p {
    font-size: 20px;
  }
  #flow .txt_area p.attention {
    font-size: 16px;
  }
  .flow_tabs {
    position: relative;
    padding-top: 50px;
    margin-bottom: 180px;
    /* 中央の境界線 */
    /* おすすめ*/
  }
  .flow_tabs__state {
    position: absolute;
    opacity: 0;
    pointer-events: none;
  }
  .flow_tabs__list {
    position: relative;
    display: flex;
    align-items: flex-end;
    border-radius: 14px;
    background: transparent;
    /* 土台背景なし */
    overflow: visible;
    /* バッジを切らない */
  }
  .flow_tabs__tab {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    /* 非アクティブ */
    height: 93px;
    margin-top: 14px;
    background: #dfeef9;
    color: #2f63c6;
    font-weight: 700;
    font-size: 28px;
    letter-spacing: 0.02em;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    box-shadow: 2px 2px 2px 0px rgba(0, 0, 0, 0.25);
    transition: background-color 0.15s ease, color 0.15s ease, height 0.15s ease, margin-top 0.15s ease;
  }
  .flow_tabs__tab--left {
    border-radius: 15px 15px 0 0;
    border-right: 0;
  }
  .flow_tabs__tab--right {
    border-radius: 15px 15px 0 0;
    border-left: 0;
  }
  .flow_tabs__tab--left::after {
    content: "";
    position: absolute;
    top: 10px;
    bottom: 10px;
    right: 0;
    width: 1px;
    background: rgba(47, 99, 198, 0.16);
  }
  .flow_tabs__badge {
    position: absolute;
    top: -28px;
    left: 50%;
    transform: translateX(-50%);
    /* 見た目 */
    background: #ffe600;
    color: #002E9F;
    font-size: 24px;
    font-weight: 900;
    line-height: 1;
    padding: 14px 20px;
    border-radius: 999px;
    box-shadow: 0px 5px 9px -4px rgba(0, 0, 0, 0.3);
    white-space: nowrap;
    z-index: 10;
    pointer-events: none;
    /* 念のため */
    opacity: 1 !important;
    visibility: visible !important;
    display: inline-flex !important;
    align-items: center;
    justify-content: center;
    /* しっぽの基準 */
  }
  .flow_tabs__badge::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -10px;
    /* しっぽの位置 */
    transform: translateX(-50%);
    width: 0;
    height: 0;
    /* 三角形（吹き出しのしっぽ） */
    border-left: 14px solid transparent;
    border-right: 14px solid transparent;
    border-top: 16px solid #ffe600;
  }
  .flow_tabs__panel {
    display: none;
  }
  #tab-online:checked ~ .flow_tabs__list label[for=tab-online],
  #tab-mail:checked ~ .flow_tabs__list label[for=tab-mail] {
    height: 100px;
    margin-top: 0;
    background: #2f63c6;
    color: #fff;
    border-color: #2f63c6;
    z-index: 2;
    align-items: end;
    padding-bottom: 30px;
  }
  #tab-online:checked ~ .flow_tabs__list label[for=tab-mail],
  #tab-mail:checked ~ .flow_tabs__list label[for=tab-online] {
    height: 63px;
    margin-top: 14px;
    z-index: 1;
    align-items: end;
    padding-bottom: 30px;
  }
  #tab-online:checked ~ .flow_tabs__list label[for=tab-online]::after,
  #tab-mail:checked ~ .flow_tabs__list label[for=tab-online]::after {
    opacity: 0;
  }
  #tab-online:checked ~ .flow_tabs__panels #panel-online {
    display: block;
  }
  #tab-mail:checked ~ .flow_tabs__panels #panel-mail {
    display: block;
  }
  .panel__title {
    margin: 8px 0 14px;
    font-size: 18px;
    font-weight: 800;
  }
  .panel__lead {
    padding: 0 20px;
    margin: 60px 0;
    color: #4c627e;
    line-height: 1.6;
  }
  .steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 30px;
    margin: 60px 0;
  }
  .step {
    display: flex;
    gap: 14px;
    align-items: center;
    justify-content: space-between;
    /* 数字（直書き表示） */
  }
  .step__no {
    width: 131px;
    height: 140px;
    position: relative;
    overflow: visible;
    --bg: #dfeef9;
    --fg: #0a36a8;
    /* 背景（丸） */
    /* 背景（しずく） */
  }
  .step__no:before {
    content: "";
    position: absolute;
    inset: 0;
    background: var(--bg);
    border-radius: 999px;
    z-index: 0;
  }
  .step__no:after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: -7.5px;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 46px solid transparent;
    border-right: 46px solid transparent;
    border-top: 30px solid var(--bg);
    z-index: 0;
  }
  .step__number {
    width: 130px;
  }
  .step__number img {
    width: 100%;
  }
  .step__label {
    position: absolute;
    top: 34px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 18px;
    font-weight: 500;
    color: var(--fg);
    letter-spacing: 0.2em;
    line-height: 1;
    white-space: nowrap;
    z-index: 2;
  }
  .step__num {
    position: absolute;
    top: 58px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 56px;
    font-weight: 300;
    color: var(--fg);
    line-height: 1;
    z-index: 2;
    /* 念のため：他CSSに負けないように */
    display: block !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  .step__body {
    width: calc(100% - 170px);
    display: flex;
    justify-content: space-between;
    padding: 0 0px 20px;
    border-bottom: 1px dashed #5C80D4;
    box-sizing: border-box;
  }
  .step__body__img {
    width: 170px;
  }
  .step__body__img img {
    width: 100%;
  }
  .step__body__txt {
    width: calc(100% - 170px);
    padding-left: 15px;
  }
  .step__body__txt .step__heading {
    font-size: 26px;
    font-weight: 700;
    margin-bottom: 6px;
    color: #002E9F;
    letter-spacing: 1px;
  }
  .step__body__txt p {
    font-size: 18px;
    line-height: 1.5;
    letter-spacing: 1px;
    margin-bottom: 10px;
  }
  .step__body__txt .step__meta {
    display: inline-flex;
    align-items: center;
    border: 1px solid #466FCE;
    font-size: 18px;
  }
  .step__body__txt .step__meta .left {
    background: #466FCE;
    color: #fff;
    text-align: center;
    min-width: 89px;
    padding: 5px;
  }
  .step__body__txt .step__meta .right {
    color: #466FCE;
    text-align: center;
    min-width: 89px;
    padding: 5px;
  }
  .step__body__txt .step__meta .right span {
    background: linear-gradient(transparent 60%, #ff6 60%);
  }
  .step__body__txt .step__meta span {
    font-weight: 700;
    color: #4c627e;
  }
  .step__body__txt .step__link {
    color: #002E9F;
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    padding-bottom: 1px;
    border-bottom: 1px solid #002e9f;
  }
  .step__body__txt .step__link:hover {
    opacity: 0.75;
  }
  .step .no_border {
    border: unset !important;
  }
  .step__no[data-step] .step__num::before {
    content: attr(data-step);
  }
  .step__text {
    margin: 0 0 10px;
    color: #4c627e;
    line-height: 1.7;
  }
  .bg_blue {
    background: #e2f0f8;
  }
  #achievements {
    margin-bottom: 90px;
  }
  #achievements .inner {
    width: 85.7142857143vw !important;
    max-width: 960px !important;
    margin: 0 auto;
  }
  #achievements h2 {
    padding: 80px 0 50px 0;
    font-size: 38px;
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #002e9f;
    text-align: center;
    position: relative;
  }
  #achievements .achievements_flex {
    display: flex;
    gap: 20px;
  }
  #achievements .achievements_flex_box {
    background: #002E9F;
    padding: 0 13px 7px;
    width: 24%;
    min-height: 180px;
    box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.27);
  }
  #achievements .achievements_flex_box .title {
    background: #fff;
    padding: 8px;
    text-align: center;
    font-size: 24px;
    color: #002E9F;
    margin: 18px auto 30px;
    box-shadow: inset 0px 0px 6px 0px rgba(0, 0, 0, 0.24);
  }
  #achievements .achievements_flex_box .attention_txt {
    font-size: 10px;
    color: #fff;
    padding-top: 10px;
  }
  #achievements .achievements_flex_box .num {
    text-align: center;
    font-size: 22px;
    color: #fff;
  }
  #achievements .achievements_flex_box .num span {
    font-size: 48px;
  }
  #achievements .achievements_flex_box .num02 {
    text-align: center;
    font-size: 25px;
    color: #fff;
    margin-top: 40px;
  }
  #achievements .achievements_flex_box .num02 span {
    font-size: 34px;
  }
  #achievements .achievements_flex_box_02 {
    color: #fff;
  }
  #achievements .achievements_flex_box_02 .txt {
    font-size: 17px;
    text-align: center;
    line-height: 1.2;
    margin-top: 48px;
  }
  #achievements .achievements_flex_box_02 .num03 {
    text-align: center;
    font-size: 38px;
    margin-top: 10px;
  }
  #achievements .achievements_flex_box_02 .num03 sup {
    font-size: 10px;
  }
  #achievements .attention {
    margin-top: 20px;
    font-size: 14px;
    line-height: 1.1;
    letter-spacing: 2px;
    font-weight: 500;
  }
  #comparison {
    margin: 120px auto 120px;
  }
  #comparison img {
    max-width: 100%;
    width: 100%;
    margin-top: 50px;
  }
  #faq {
    margin-top: 250px;
    /* summaryのデフォルト矢印消し */
    /* ==== 質問行 ==== */
    /* 右端の＋/ー（スクショは右端に記号だけ） */
    /* ==== 回答行 ==== */
  }
  #faq .acc {
    border-radius: 10px;
    overflow: hidden;
    margin: 0px 0 20px;
  }
  #faq .acc > summary {
    list-style: none;
  }
  #faq .acc > summary::-webkit-details-marker {
    display: none;
  }
  #faq .acc__head {
    display: grid;
    grid-template-columns: 40px 1fr 44px;
    /* Q列 / テキスト / 右端アイコン */
    align-items: center;
    gap: 0;
    padding: 14px 14px;
    border-radius: 10px;
    background: #E3F0F8;
    cursor: pointer;
  }
  #faq .acc__q {
    justify-self: center;
    font-weight: 800;
    font-size: 24px;
    color: #002E9F;
  }
  #faq .acc__title {
    font-weight: 700;
    color: #002E9F;
    line-height: 1.35;
    font-size: 20px;
    padding-left: 30px;
  }
  #faq .acc__head::after {
    content: "＋";
    justify-self: end;
    font-size: 22px;
    font-weight: 900;
    color: #1f5fbf;
  }
  #faq .acc[open] .acc__head::after {
    content: "ー";
    font-weight: 500;
  }
  #faq .acc__body {
    display: grid;
    grid-template-columns: 40px 1fr;
    /* A列 / 本文 */
    gap: 0;
    padding: 18px 16px 20px;
    background: #fff;
  }
  #faq .acc__a {
    justify-self: center;
    align-self: start;
    /* Aを上基準に */
    font-weight: 800;
    font-size: 26px;
    color: #E92118;
    /* Aの赤 */
    line-height: 1;
    margin-top: 2px;
    /* “本文1行目”に合わせて微調整 */
  }
  #faq .acc__answer {
    color: #111827;
    line-height: 1.9;
    font-size: 18px;
    padding-left: 30px;
  }
  #faq .acc__answer p {
    margin: 0 0 10px;
  }
  #faq .acc__answer p:last-child {
    margin-bottom: 0;
  }
}
.onResize * {
  transition: inherit !important;
}
.onResize *:before, .onResize *:after {
  transition: inherit !important;
}