@charset "UTF-8";
/*------------------------------------------------------------------------------------------
*
*
    common_sp.css
*
*
------------------------------------------------------------------------------------------ */
@media screen and (max-width: 750px) {
  /*------------------------------------------------------------------------------------------
  *
  *
      max-width : 640px
  *
  *
  ------------------------------------------------------------------------------------------ */
  body {
    width: 100vw;
    z-index: 10;
    overflow-x: hidden;
  }
  /* --------------------------------------------------
  *
      common settings sp
  *
  -------------------------------------------------- */
  body {
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
  }
  br {
    display: none !important;
  }
  br.sp {
    display: inherit !important;
  }
  img.pc {
    display: none;
  }
  .switch_pc,
  .switch_pc * {
    display: none;
  }
  /* --------------------------------------------------
  * 
      header
  *
  -------------------------------------------------- */
}
/* -------------------------------------------------- */
/*------------------------------------------------------------------------------------------
*
*
    home_sp.css
*
*
------------------------------------------------------------------------------------------ */
@media screen and (max-width: 750px) {
  /*------------------------------------------------------------------------------------------
  *
  *
      max-width : 750px
  *
  *
  ------------------------------------------------------------------------------------------ */
  main {
    max-width: 100vw;
    overflow: hidden;
  }
  /*------------------------------------------------------------------------------------------
  *
  *
      min-width : 751px
  *
  *
  ------------------------------------------------------------------------------------------ */
  .btn_cv_fix {
    width: 100%;
    text-align: center;
    position: fixed;
    top: inherit;
    bottom: 2.6666666667vw;
    transform: translate3d(0, 0, 0);
    z-index: 100;
    opacity: 0;
    pointer-events: none;
  }
  .btn_cv_fix img {
    width: 89.3333333333vw;
  }
  .spFix .btn_cv_fix {
    opacity: 1;
    pointer-events: inherit;
  }
  header {
    height: 14.1333333333vw;
    display: flex;
    justify-content: center;
    align-items: center;
  }
  header .logo img {
    width: 41.8666666667vw;
  }
  #kv {
    font-feature-settings: "palt" 1;
    width: 100%;
    position: relative;
  }
  #kv .pic {
    line-height: 0;
  }
  #kv .pic img {
    width: 100%;
  }
  .kv {
    font-feature-settings: "palt" 1;
    width: 100%;
    height: 488px;
    background-repeat: no-repeat;
    background-image: url(../images/mobile/kv_bg.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: 33px;
    font-weight: 800;
    text-align: center;
    letter-spacing: 5px;
    line-height: 1;
    padding-bottom: 8px;
    z-index: 1;
  }
  .kv-title span small {
    font-size: 26px;
    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.pc {
    display: none;
  }
  .kv-sub {
    font-size: 18px;
    font-weight: 700;
    margin: 15px 0 40px;
    letter-spacing: 2px;
  }
  .kv-sub small {
    font-size: 14px;
  }
  .kv-desc {
    font-size: 10px;
    letter-spacing: 5px;
    margin-bottom: -20px;
    padding-left: 90px;
  }
  .kv-logo img {
    display: block;
    width: 100%;
    max-width: 420px;
    margin: 0 auto 20px;
    padding: 0 15px;
    box-sizing: border-box;
  }
  .kv-boxes {
    display: flex;
    justify-content: center;
    gap: 33px;
  }
  .kv-box {
    background: #2B2727;
    width: 156px;
    height: 64px;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-wrap: wrap;
  }
  .kv-box .box-main {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1.2;
  }
  .kv-box .box-sub {
    width: 100%;
    font-size: 14px;
    font-weight: 700;
    letter-spacing: 1px;
    margin-bottom: -20px;
  }
  #mov {
    position: relative;
    line-height: 0;
  }
  #mov .v {
    text-align: center;
  }
  #mov .v iframe {
    width: 100vw;
    height: 56.2666666667vw;
  }
  #feature {
    padding: 0 2.6666666667vw;
    padding-bottom: 5.3333333333vw;
    background-color: #e3f0f8;
    overflow: hidden;
  }
  #feature h2 {
    padding: 13.3333333333vw 0 10.6666666667vw 0;
    font-size: 5.0666666667vw;
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #002e9f;
    text-align: center;
    position: relative;
  }
  #feature h2 .bd {
    background: linear-gradient(transparent 3.3333333333vw, #fffe00 1.3333333333vw);
    border-bottom: 0.5333333333vw solid #fffe00;
  }
  #feature .gr {
    margin: 0 auto;
    margin-bottom: 8.6666666667vw;
    position: relative;
    border-radius: 1.3333333333vw;
    background-color: #fff;
    box-shadow: 0.4vw 0.4vw 1.7333333333vw rgba(0, 0, 0, 0.1);
  }
  #feature .gr:last-child {
    margin-bottom: 0;
  }
  #feature .gr .no {
    position: absolute;
    top: -3.2vw;
    left: -1.3333333333vw;
    z-index: 10;
    pointer-events: none;
  }
  #feature .gr .no img {
    width: 17.4666666667vw;
  }
  #feature .gr .gr_wrap {
    overflow: hidden;
    border-radius: 1.3333333333vw;
  }
  #feature .gr h3 {
    height: 20.8vw;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    font-size: 4.5333333333vw;
    line-height: 1.6764705882em;
    border-radius: 1.3333333333vw 1.3333333333vw 0 0;
    letter-spacing: 0.06em;
    background-image: url(../images/mobile/bg_stripe_l.png);
    position: relative;
    cursor: pointer;
    box-shadow: 0px 0.4vw 1.7333333333vw rgba(0, 0, 0, 0.1);
  }
  #feature .gr h3:before {
    content: "";
    width: 3.0666666667vw;
    height: 3.0666666667vw;
    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.5333333333vw;
    transform: translateY(-50%);
  }
  #feature .gr h3:after {
    content: "";
    width: 3.0666666667vw;
    height: 3.0666666667vw;
    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.5333333333vw;
    transform: translateY(-50%);
    opacity: 0;
  }
  #feature .inner {
    padding: 0 6.6666666667vw;
    padding-bottom: 9.3333333333vw;
    margin: 0 auto;
  }
  #feature .inner dl {
    padding-top: 4.6666666667vw;
    width: 100%;
  }
  #feature .inner dl dt {
    margin-bottom: 4vw;
    font-size: 3.6vw;
    line-height: 1.7037037037em;
    letter-spacing: 0.06em;
  }
  #feature .inner dl dt .s {
    font-size: 1.8666666667vw;
    position: relative;
  }
  #feature .inner dl dd .img img {
    width: 100%;
  }
  #feature .inner .note {
    margin-top: 4.6666666667vw;
    font-size: 2.6666666667vw;
    line-height: 1.8em;
  }
  #feature .inner h4 {
    margin-top: 6.6666666667vw;
    width: 92vw;
    height: 11.7333333333vw;
    background-color: #466fce;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 3.7333333333vw;
    letter-spacing: 0.06em;
    position: relative;
    left: -5.3333333333vw;
  }
  #feature .inner h4.sub {
    margin-top: 8vw;
    margin-bottom: 1.3333333333vw;
    background-color: inherit;
    background-image: url(../images/sp/bg_sub_title.png);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center bottom;
  }
  #feature .inner h5 {
    padding: 7.3333333333vw 0 0 0;
    font-size: 5.0666666667vw;
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #002e9f;
    text-align: center;
    position: relative;
  }
  #feature .inner h5 .bd {
    background: linear-gradient(transparent 3.3333333333vw, #fffe00 1.3333333333vw);
    border-bottom: 0.5333333333vw solid #fffe00;
  }
  #feature .inner dl.rev dt {
    margin-bottom: 5.3333333333vw;
  }
  #feature .inner dl.rev dt .d {
    display: inline-block;
    text-align: left;
  }
  #feature .desc {
    padding-top: 6.6666666667vw;
    font-size: 3.6vw;
    letter-spacing: 0.04em;
    line-height: 1.7037037037em;
  }
  #feature .desc .s {
    margin-top: 2.6666666667vw;
    font-size: 2.6666666667vw;
    letter-spacing: inherit;
  }
  #feature .g2 dl {
    display: flex;
    flex-direction: column-reverse !important;
  }
  #feature .g2 dl dt {
    padding-top: 5.3333333333vw;
  }
  #feature .g2 dl dt p {
    margin-bottom: 2em;
  }
  #feature .g2 dl dt p:last-child {
    margin-bottom: 0;
  }
  #feature .g2 dl dd {
    padding-top: 2.6666666667vw;
    width: 100%;
    text-align: center;
  }
  #feature .g2 dl dd .img {
    margin: 0 auto;
  }
  #feature .g2 dl dd .i1 {
    width: 32.9333333333vw;
  }
  #feature .g2 dl dd .i2 {
    width: 47.7333333333vw;
    margin-left: 33.3333333333vw;
  }
  #feature .g2 dl.rev dt {
    margin-bottom: 0 !important;
  }
  #feature .g3 dl {
    display: flex;
    flex-direction: column-reverse !important;
  }
  #feature .g3 dl dt {
    padding-top: 5.3333333333vw;
    margin-bottom: 0;
  }
  #feature .g3 dl dd {
    padding-top: 2.6666666667vw;
    width: 100%;
    text-align: center;
  }
  #feature .g3 dl dd .img {
    margin: 0 auto;
  }
  #feature .g3 dl dd .i1 {
    width: 55.3333333333vw;
  }
  #feature .g3 dl dd .i2 {
    width: 43.8666666667vw;
  }
  #feature .g3 dl.rev dt {
    margin-bottom: 0 !important;
  }
  #feature .g4 dl {
    display: flex;
    flex-direction: column-reverse !important;
  }
  #feature .g4 dl dt {
    padding-top: 5.3333333333vw;
    padding-bottom: 2.6666666667vw;
  }
  #feature .g4 dl dd {
    padding-top: 2.6666666667vw;
    width: 100%;
    text-align: center;
  }
  #feature .g4 dl dd .img {
    margin: 0 auto;
  }
  #feature .g4 dl dd .i1 {
    width: 59.0666666667vw;
  }
  #feature .g4 dl dd .i2 {
    width: 89.3333333333vw;
    position: relative;
    left: -4vw;
  }
  #feature .g4 dl.rev dt {
    margin-bottom: 0 !important;
  }
  #feature .g4 .row {
    padding-top: 8vw;
    display: block;
  }
  #feature .g4 .row .note {
    margin-top: 4vw;
    margin-bottom: 2.6666666667vw;
    font-size: 2.6666666667vw;
    line-height: 1.55em;
    text-align: left;
  }
  #feature .btn_close {
    width: 35.2vw;
    height: 10.5333333333vw;
    margin: 0 auto;
    margin-top: 8vw;
    background-color: #e3f0f8;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #002e9f;
    font-size: 3.7333333333vw;
    letter-spacing: 0.06em;
    border-radius: 10.6666666667vw;
    position: relative;
    cursor: pointer;
  }
  #feature .btn_close:before {
    content: "";
    display: block;
    width: 1.8666666667vw;
    height: 1.8666666667vw;
    background-repeat: no-repeat;
    background-image: url(../images/ico_close.png);
    background-size: contain;
    position: absolute;
    top: 50%;
    left: 7.4666666667vw;
    transform: translateY(-50%);
  }
  #feature .outline_table {
    padding-top: 5.3333333333vw;
  }
  #feature .outline_table table {
    width: 85.3333333333vw;
    height: 143px;
    margin-bottom: 12px;
    position: relative;
    left: -2vw;
  }
  #feature .outline_table table.row_s {
    height: auto !important;
    min-height: auto !important;
  }
  #feature .outline_table table.row_s td {
    height: auto !important;
    padding: 0 !important;
  }
  #feature .outline_table table th {
    width: 30.6666666667vw;
    padding: 2.6666666667vw 0;
    font-size: 3.2vw;
    background-color: #e3f0f8;
    color: #002e9f;
    vertical-align: middle;
    text-align: center;
  }
  #feature .outline_table table td {
    height: 28vw;
    padding: 5.3333333333vw 0;
    font-size: 3.7333333333vw;
    line-height: 1.3928571429em;
    background-color: #ebebeb;
    vertical-align: middle;
    text-align: center;
    border-left: 1.3333333333vw solid #fff;
    box-sizing: border-box;
  }
  #feature .outline_table table td .s {
    font-size: 2.6666666667vw;
  }
  #feature .outline_table table td .m {
    font-size: 4.5333333333vw;
    line-height: 1.4705882353em;
  }
  #feature .outline_table table td .l {
    font-size: 5.3333333333vw;
  }
  #feature .outline_table table.rs th {
    border-bottom: 0.6666666667vw solid #fff;
  }
  #feature .video {
    padding-top: 10.6666666667vw;
  }
  #feature .video h5 {
    width: 89.3333333333vw;
    height: 11.7333333333vw;
    padding: 0;
    padding-top: 1.3333333333vw;
    display: block;
    margin: 0 auto;
    margin-bottom: 4vw;
    background-image: url(../images/sp/gr_04_s-ttile-bg.png);
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    font-size: 4.5333333333vw;
    letter-spacing: 0.06em;
    color: #fff;
    box-sizing: border-box;
    position: relative;
    left: -4vw;
  }
  #feature .video .v {
    position: relative;
    left: -4.6666666667vw;
  }
  #feature .video .v iframe {
    width: 90.6666666667vw;
    height: 50.6666666667vw;
  }
  .btn_area {
    padding: 4.6666666667vw 0;
    text-align: center;
  }
  .btn_area img {
    width: 89.3333333333vw;
  }
  .impression {
    position: relative;
  }
  .impression#cost {
    padding-bottom: 17.3333333333vw;
    background-color: #e3f0f8;
  }
  .impression#cost .h {
    margin-bottom: 7.3333333333vw;
  }
  .impression#voice {
    padding-top: 58px;
  }
  .impression#voice .name {
    margin-top: -5.3333333333vw !important;
  }
  .impression#voice .h {
    padding-bottom: 2.6666666667vw;
  }
  .impression#voice .h .desc .box {
    background: #fff;
    padding: 5px 10px;
    line-height: 1.6;
    margin: 0px 0 20px;
    font-size: 14px;
  }
  .impression .inner {
    margin: 0 auto;
  }
  .impression h3 {
    height: 19.3333333333vw;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    font-size: 5.0666666667vw;
    letter-spacing: 0.06em;
    background-image: url(../images/mobile/bg_stripe_l.png);
    position: relative;
    box-shadow: 0px 0.4vw 1.7333333333vw rgba(0, 0, 0, 0.1);
  }
  .impression .h {
    padding: 0 5.3333333333vw;
    padding-top: 5.3333333333vw;
  }
  .impression .h .profile {
    position: relative;
  }
  .impression .h .profile .pic img {
    width: 100%;
  }
  .impression .h .profile .name {
    display: inline-block;
    padding: 2.6666666667vw 3.3333333333vw;
    margin-bottom: -2.4vw;
    align-items: center;
    background-color: #fff;
    box-sizing: border-box;
    font-size: 4.2666666667vw;
    line-height: 1.5625em;
    letter-spacing: 0.06em;
    top: 100%;
    left: 0;
    white-space: nowrap;
    transform: translateY(-7.7333333333vw);
  }
  .impression .h .profile .name .s {
    font-size: 3.2vw;
  }
  .impression .h .desc {
    box-sizing: border-box;
  }
  .impression .h .desc p {
    font-size: 3.6vw;
    line-height: 1.8518518519em;
    letter-spacing: 0.06em;
  }
  .impression .btn_detail {
    width: 89.3333333333vw;
    height: 9.7333333333vw;
    margin: 0 auto;
    margin-top: 8vw;
    background-color: #06339c;
    display: flex;
    justify-content: center;
    align-items: center;
    color: #fff;
    font-size: 3.7333333333vw;
    letter-spacing: 0.06em;
    border-radius: 10.6666666667vw;
    position: absolute;
    bottom: 8vw;
    left: 5.3333333333vw;
    cursor: pointer;
  }
  .impression .btn_detail:before {
    content: "";
    display: block;
    width: 3.0666666667vw;
    height: 3.0666666667vw;
    background-repeat: no-repeat;
    background-image: url(../images/ico_plus.png);
    background-size: contain;
    position: absolute;
    top: 50%;
    right: 5.6vw;
    transform: translateY(-50%);
  }
  .impression .detail {
    display: none;
    overflow: hidden;
    padding: 0 5.3333333333vw;
    margin-bottom: -8vw;
  }
  .impression .detail p {
    margin-bottom: 2em;
    font-size: 3.6vw;
    line-height: 1.8518518519em;
    letter-spacing: 0.06em;
  }
  .impression .detail p .s {
    font-size: 1.8666666667vw;
  }
  .impression .detail .caution p {
    margin-bottom: 5px;
    font-size: 2.6666666667vw;
    line-height: 1.6666666667em;
    letter-spacing: 0.04em;
  }
  .impression p .c {
    color: #06339c;
    background: linear-gradient(transparent 2.4vw, #fffe00 1.3333333333vw);
    border-bottom: 0.6666666667vw solid #fffe00;
  }
  #flow .inner {
    margin: 0 auto;
  }
  #flow h3 {
    height: 19.3333333333vw;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    color: #fff;
    font-size: 5.0666666667vw;
    letter-spacing: 0.06em;
    background-image: url(../images/mobile/bg_stripe_l.png);
    position: relative;
    box-shadow: 0px 0.4vw 1.7333333333vw rgba(0, 0, 0, 0.1);
  }
  #flow .desc {
    padding: 6.6666666667vw 0;
    text-align: center;
  }
  #flow .desc p {
    font-size: 3.6vw;
    letter-spacing: 0.04em;
    line-height: 1.8518518519em;
  }
  #flow .flow_table {
    padding: 0 5.3333333333vw;
  }
  #flow table {
    width: 89.3333333333vw;
    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: 4.6666666667vw 0 9.3333333333vw 0;
    height: 100%;
    min-height: 20vw;
    width: 22.4vw;
    position: relative;
    text-align: center;
    box-sizing: border-box;
    color: #fff;
    font-size: 3.2vw;
    line-height: 1.4166666667em;
    letter-spacing: 0.06em;
  }
  #flow table th:before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: #436cd0;
    position: absolute;
    left: 0;
    top: 0;
    z-index: -1;
  }
  .isIE #flow table th:before {
    min-height: 9999px;
  }
  #flow table th:after {
    content: "";
    width: 100%;
    height: 6vw;
    display: block;
    background-image: url(../images/sp/flow_bg-title.png);
    background-color: #fff;
    background-repeat: no-repeat;
    background-position: center;
    background-size: cover;
    position: absolute;
    left: 0;
    bottom: 0;
    z-index: 2;
  }
  #flow table td {
    width: 66.9333333333vw;
    position: relative;
    padding-top: 4vw;
    padding-bottom: 2vw;
    padding-left: 4vw;
    vertical-align: top;
    box-sizing: border-box;
  }
  #flow table td:before {
    content: "";
    width: 100%;
    height: 1px;
    border-top: 1px dashed #5c80d4;
    display: block;
    position: absolute;
    left: 4vw;
    top: 0;
    z-index: -1;
  }
  #flow table td .row {
    width: 100%;
    display: flex;
    align-items: center;
  }
  #flow table td .row .img {
    text-align: center;
    min-width: 20.6666666667vw;
  }
  #flow table td .row .t p {
    padding-left: 1.3333333333vw;
    font-size: 3.2vw;
    line-height: 1.4166666667em;
    letter-spacing: 0.06em;
  }
  #flow table td .row .t .note {
    margin-top: 1.3333333333vw;
    font-size: 2.6666666667vw;
  }
  #flow table td .example {
    padding-top: 5.3333333333vw;
  }
  #flow table td .example p {
    font-size: 3.2vw;
    letter-spacing: 0.06em;
  }
  #flow table td .example .s {
    margin-top: 3.3333333333vw;
    font-size: 2.6666666667vw;
    display: block;
  }
  #flow table td .example h4 {
    padding: 2vw 0;
    margin-bottom: 2.6666666667vw;
    margin-top: 6.6666666667vw;
    text-align: center;
    background-color: #eff8fd;
    font-size: 2.6666666667vw;
    letter-spacing: 0.06em;
  }
  #flow table td .example .img img {
    width: 100%;
  }
  #flow table .i1 img {
    width: 19.0666666667vw;
  }
  #flow table .i2 img {
    width: 14.9333333333vw;
  }
  #flow table .i3 img {
    width: 53.7333333333vw;
  }
  #flow table .i4 img {
    width: 12.4vw;
  }
  #flow table .i5 img {
    width: 19.0666666667vw;
  }
  #info {
    font-feature-settings: "palt" 1;
    padding-top: 6.6666666667vw;
    padding-bottom: 5.3333333333vw;
  }
  #info .inner {
    padding: 0 5.3333333333vw;
    margin: 0 auto;
  }
  #info p {
    font-size: 2.6666666667vw;
    margin-bottom: 2em;
    letter-spacing: 0.06em;
    line-height: 1.5em;
  }
  footer {
    height: 35.2vw;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    background-color: #282828;
  }
  footer .btn_pagetop {
    width: 10.6666666667vw;
    height: 10.6666666667vw;
    margin-bottom: 3.3333333333vw;
    cursor: pointer;
    position: relative;
  }
  footer .btn_pagetop img {
    width: 10.6666666667vw;
    height: 10.6666666667vw;
    opacity: 0;
  }
  footer .btn_pagetop:after {
    content: "";
    display: block;
    width: 10.6666666667vw;
    height: 10.6666666667vw;
    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: 2.9333333333vw;
    color: #fff;
    letter-spacing: 0.025em;
  }
  .bg_blue {
    background: #e2f0f8;
  }
  #achievements {
    margin-bottom: 40px;
  }
  #achievements .inner {
    max-width: 375px;
    width: 100%;
    margin: 0 auto;
  }
  #achievements h2 {
    padding: 30px 0 0px 0;
    font-size: 23px;
    line-height: 1.5em;
    letter-spacing: 0.06em;
    color: #002e9f;
    text-align: center;
    position: relative;
    margin-bottom: 30px;
  }
  #achievements h2 .sp {
    display: block;
  }
  #achievements .achievements_flex {
    display: block;
    padding: 0 4px;
  }
  #achievements .achievements_flex_box {
    background: #002E9F;
    width: 100%;
    min-height: 73px;
    box-shadow: 0px 2px 5px 0px rgba(0, 0, 0, 0.27);
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 20px;
  }
  #achievements .achievements_flex_box .title {
    width: 128px;
    background: #fff;
    padding: 11px 0px 10px;
    margin: 10px;
    text-align: center;
    font-size: 20px;
    color: #002E9F;
    margin-right: 10px;
    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: 5px 0px 10px;
    line-height: 1.3;
    width: 276px;
    margin: 0 auto;
  }
  #achievements .achievements_flex_box .num {
    text-align: center;
    font-size: 22px;
    color: #fff;
    margin-left: 20px;
  }
  #achievements .achievements_flex_box .num span {
    font-size: 48px;
  }
  #achievements .achievements_flex_box .num02 {
    text-align: center;
    font-size: 25px;
    color: #fff;
    margin-left: 10px;
  }
  #achievements .achievements_flex_box .num02 span {
    font-size: 34px;
  }
  #achievements .achievements_flex_box_02 {
    color: #fff;
    display: flex;
    justify-content: center;
    gap: 30px;
  }
  #achievements .achievements_flex_box_02 .txt {
    font-size: 17px;
    text-align: center;
    line-height: 1.2;
  }
  #achievements .achievements_flex_box_02 .num03 {
    font-size: 38px;
    margin-top: 10px;
  }
  #achievements .achievements_flex_box_02 .num03 sup {
    font-size: 10px;
  }
  #achievements .attention {
    margin-top: 20px;
    font-size: 10px;
    line-height: 1.1;
    letter-spacing: 2px;
    font-weight: 500;
  }
  #comparison {
    margin: 60px auto 50px;
  }
  #comparison img {
    max-width: 100%;
    width: 100%;
    margin-top: 50px;
  }
  #flow .txt_area {
    max-width: 756px;
    margin: 40px auto;
    letter-spacing: 2px;
    line-height: 1.5;
    margin-bottom: 10px;
    padding: 0 16px;
  }
  #flow .txt_area p {
    font-size: 14px;
  }
  #flow .txt_area p.attention {
    font-size: 10px;
  }
  .flow_tabs {
    position: relative;
    padding-top: 50px;
    margin-bottom: 100px;
    /* 中央の境界線 */
    /* おすすめ*/
  }
  .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: 14px;
    letter-spacing: 0.02em;
    cursor: pointer;
    -webkit-user-select: none;
       -moz-user-select: none;
            user-select: none;
    border: 1px solid rgba(47, 99, 198, 0.14);
    box-shadow: none;
    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: -15px;
    left: 50%;
    transform: translateX(-50%);
    /* 見た目 */
    background: #ffe600;
    color: #002E9F;
    font-size: 10px;
    font-weight: 900;
    line-height: 1;
    padding: 5px 10px;
    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: -4px;
    /* しっぽの位置 */
    transform: translateX(-50%);
    width: 0;
    height: 0;
    /* 三角形（吹き出しのしっぽ） */
    border-left: 7px solid transparent;
    border-right: 7px solid transparent;
    border-top: 7px solid #ffe600;
  }
  .flow_tabs__panel {
    display: none;
  }
  /* =========================
     Active tab（段差＋色）
  ========================= */
  #tab-online:checked ~ .flow_tabs__list label[for=tab-online],
  #tab-mail:checked ~ .flow_tabs__list label[for=tab-mail] {
    height: 40px;
    margin-top: 0;
    background: #2f63c6;
    color: #fff;
    border-color: #2f63c6;
    z-index: 2;
    align-items: end;
    padding-bottom: 13px;
  }
  /* 非アクティブ側は下げる */
  #tab-online:checked ~ .flow_tabs__list label[for=tab-mail],
  #tab-mail:checked ~ .flow_tabs__list label[for=tab-online] {
    height: 25px;
    margin-top: 14px;
    z-index: 1;
    align-items: end;
    padding-bottom: 13px;
  }
  /* アクティブ時：中央の境界線を消す*/
  #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: 40px 0 60px;
    color: #4c627e;
    line-height: 1.6;
    font-size: 14px;
  }
  .steps {
    list-style: none;
    padding: 0;
    margin: 0;
    display: grid;
    gap: 30px;
    margin: 60px 0;
  }
  .step {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 100vw;
    margin: 0 16px;
    padding-bottom: 20px;
    position: relative;
    border-bottom: 1px dashed #5C80D4;
    /* 数字（直書き表示） */
  }
  .step:last-child {
    border-bottom: unset;
  }
  .step__no {
    width: 70px;
    height: 75px;
    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: -4.5px;
    transform: translateX(-50%);
    width: 0;
    height: 0;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-top: 7px solid var(--bg);
    z-index: 0;
  }
  .step__number {
    width: 70px;
  }
  .step__number img {
    width: 100%;
  }
  .step__label {
    position: absolute;
    top: 15px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 10px;
    font-weight: 500;
    color: var(--fg);
    letter-spacing: 0.2em;
    padding-left: 0.35em;
    line-height: 1;
    white-space: nowrap;
    z-index: 2;
  }
  .step__num {
    position: absolute;
    top: 27px;
    left: 50%;
    transform: translateX(-50%);
    font-size: 30px;
    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% - 70px);
    display: flex;
    justify-content: space-between;
    box-sizing: border-box;
    align-items: center;
  }
  .step__body__img {
    width: 70px;
  }
  .step__body__img img {
    width: 100%;
  }
  .step__body__txt {
    width: calc(100% - 75px);
  }
  .step__body__txt .step__heading {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 17px;
    color: #002E9F;
    letter-spacing: 1px;
  }
  .step__body__txt p {
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 1px;
    margin-bottom: 17px;
  }
  .step__body__txt .step__meta {
    display: inline-flex;
    align-items: center;
    border: 1px solid #466FCE;
    font-size: 11px;
  }
  .step__body__txt .step__meta .left {
    background: #466FCE;
    color: #fff;
    text-align: center;
    min-width: 63px;
    padding: 5px;
  }
  .step__body__txt .step__meta .right {
    color: #466FCE;
    text-align: center;
    min-width: 63px;
    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;
  }
  /* data-step を表示 */
  .step__no[data-step] .step__num::before {
    content: attr(data-step);
  }
  .step__text {
    margin: 0 0 10px;
    color: #4c627e;
    line-height: 1.7;
  }
  #faq {
    margin-top: 100px;
    padding: 0 8px;
    /* 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 20px;
    /* 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: 20px;
    color: #002E9F;
  }
  #faq .acc__title {
    font-weight: 700;
    color: #002E9F;
    line-height: 1.35;
    font-size: 14px;
    padding-left: 10px;
  }
  #faq .acc__head::after {
    content: "＋";
    justify-self: end;
    font-size: 18px;
    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: 20px;
    color: #E92118;
    /* Aの赤 */
    line-height: 1;
    margin-top: 2px;
    /* “本文1行目”に合わせて微調整 */
  }
  #faq .acc__answer {
    color: #111827;
    line-height: 1.9;
    font-size: 14px;
    padding-left: 10px;
  }
  #faq .acc__answer p {
    margin: 0 0 10px;
  }
  #faq .acc__answer p:last-child {
    margin-bottom: 0;
  }
}