@charset "utf-8";
/* reset */
html, body, h1, h2, h3, p, ul, li, dl, dt, dd {
    padding: 0;
    line-height: 1.8;
    margin: 0;
}

ul {
    list-style: none;
}

a {
    color: inherit;
    text-decoration: none;
}

img {
    max-width: 100%;
    vertical-align: baseline;
}

.pc_only {
    display: block;
}

.sp_only {
    display: none;
}

/*----------------------
        全体設定
----------------------*/
body {
    color: #2B3033;
    font-family: "Hiragino Sans W5", "ヒラギノ角ゴシック", "メイリオ", "Meiryo", "Arial", sans-serif;
    font-weight: 500;
    position: relative;
}

h2 {
    font-family: "Hiragino Sans W5", "ヒラギノ角ゴシック", "メイリオ", "Meiryo", "Arial", sans-serif;
    font-weight: 600;
}

@media screen and (max-width: 767px) {
    .sp_only {
        display: block;
    }

    .pc_only {
        display: none !important;
    }
}

/*----　ボタン設定　 ----*/
.btn {
    background-color: #FAFAFB;
    border-radius: 20px;
    font-size: 12px;
    line-height: 1.3;
    padding: 8px 17px;
    text-align: center;
}

.btn a {
    display: block;
}

.btn i {
    line-height: 1;
    margin-right: 10px;
}

.btn img {
    margin-right: 10px;
    width: 16px;
}

.floating_btn {
    display: none;
}

.floating_btn .blue-btn {
    background-color: #4168AF;
    border: 2px #FFFFFF solid;
    border-radius: 100px;
    box-shadow: 0px 3px 15px rgba(0, 0, 0, 0.25);
    color: #fff;
    font-size: 16px;
    font-weight: 600;
    left: 4%;
    letter-spacing: 0.1em;
    margin: 0 auto;
    padding: 12px 0;
    position: fixed;
    top: 90%;
    width: 90%;
    z-index: 50;
}

.floating_btn .blue-btn img {
    margin-right: 10px;
}

.floating_btn .white-btn {
    box-shadow: 0px 3px 15px rgba(0, 0, 0, 0.25);
    font-weight: 600;
    left: 4%;
    letter-spacing: 0.08em;
    margin: 0 auto;
    padding: 10px 0;
    position: fixed;
    top: 90%;
    width: 90%;
    z-index: 50;
}

.floating_btn.move-upwards .blue-btn {
    top:70%;
}

.floating_btn.move-upwards .white-btn {
    top: 80%;
}

.bottom-btn {
    border: #2B3033 1px solid;
    border-radius: 26px;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.3;
    margin-top: 34px;
    padding: 14px 0;
}

/*----　コンテンツ移動　----*/
.content_block_move {
    animation-name:fadeInAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}

@keyframes fadeInAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

.fade-in-content-1 .fade-in-content-item-1,
.fade-in-content-2 .fade-in-content-item-2,
.fade-in-content-3 .fade-in-content-item-3,
.fade-in-content-4 .fade-in-content-item-4 {
    opacity: 0;
    right: 160px;
    top: 50px;
    transition: 0.3s;
    width: 100%;
}

.fade-in-content-5 .fade-in-content-item-5,
.fade-in-content-6 .fade-in-content-item-6,
.fade-in-content-7 .fade-in-content-item-7,
.fade-in-content-8 .fade-in-content-item-8,
.fade-in-content-9 .fade-in-content-item-9,
.fade-in-content-10 .fade-in-content-item-10,
.fade-in-content-11 .fade-in-content-item-11 {
    opacity: 0;
    transition: 0.3s;
}

.fade-in-content-1 .fade-in-content-item-1.fade_on,
.fade-in-content-2 .fade-in-content-item-2.fade_on,
.fade-in-content-3 .fade-in-content-item-3.fade_on,
.fade-in-content-4 .fade-in-content-item-4.fade_on,
.fade-in-content-5 .fade-in-content-item-5.fade_on,
.fade-in-content-6 .fade-in-content-item-6.fade_on,
.fade-in-content-7 .fade-in-content-item-7.fade_on,
.fade-in-content-8 .fade-in-content-item-8.fade_on,
.fade-in-content-9 .fade-in-content-item-9.fade_on,
.fade-in-content-10 .fade-in-content-item-10.fade_on,
.fade-in-content-11 .fade-in-content-item-11.fade_on {
    animation: fade_on1 0.5s linear 1 forwards;
}

@keyframes fade_on1 {
    0% {
    opacity: 0;
    left: 60px;
    }
    100% {
    opacity: 1;
    left: 80px;
    }
}

/*----------------------
       本文
----------------------*/
.main-content {
    max-width: 750px;
}

.content_block {
    padding: 0 20px;
}

.is-appear {
    display: block !important;
}

/*----　ファーストビュー　----*/
.header_fv.sp_content {
    background: #8BB5E5;
    position: relative;
}

.header_fv_top {
    align-items: center;
    display: flex;
    justify-content: space-between;
    margin-bottom: 25px;
    padding: 18px 20px 0;
}

.header_fv_top h1 {
    display: flex;
    width: 22%;
}

.header_fv_top h1 img {
    line-height: 1;
}

.header_fv_ttl h2{
    color: #FFFFFF;
    font-family: 'Zen Kaku Gothic New';
    font-size: 18px;
    letter-spacing: 0.005em;
    margin-bottom: 10px;
    padding: 0 20px;
    text-align: center;
    text-shadow: 0px 0px 7px rgb(48 104 204 / 35%);
}

.header_fv_ttl h2 span {
    font-size: 36px;
    font-weight: 900;
    line-height: 1.1;
}

.header_fv_top .white-btn i {
    margin-right: 10px;
}

.header_fv_top .btn a {
    color: #2B3033;
    letter-spacing: 0.05em;
}

.header_fv_ballon {
    color: #4168AF;
    font-size: 12px;
    font-weight: 600;
    line-height: 1.7;
    position: relative;
    padding: 16px 0;
    z-index: 1;
}

.header_fv_ballon p {
    display: inline-block;
    left: 30px;
    line-height: 1.2;
    position: absolute;
    text-align: center;
    top: 39px;
}

.header_fv_ballon::before {
    background-image: url(../img/fv-ballon.png);
    background-repeat: no-repeat;
    background-size: contain;
    content: "";
    display: inline-block;
    height: 153px;
    position: absolute;
    width: 140px;
    top: -5px;
    left: 0;
    z-index: -1;
}

.header_fv_ballon span {
    color: #4168AF;
    font-family: "Hiragino Sans W7";
    font-size: 24px;
}

.header_fv_ballon span span {
    font-size: 20px;
    font-weight: 600;
}

.header_fv_img {
    overflow: hidden;
    height: 458px;
}

.header_fv_img img {
    margin: -29% 0 0 -30%;
    max-width: none;
    object-fit: cover;
    width: 160%;
}

.header_fv_dl {
    background-color: rgba(255,255,255,0.5);
    border-radius: 999px;
    left: 10%;
    margin: 0 auto;
    padding: 13px 17px;
    position: absolute;
    top: 87%;
    width: 70%;
}

.header_fv_dl a {
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.1em;
}

.header_fv_top .btn a {
    align-items: center;
    display: flex;
}

/*----　実績　----*/
.content_block.record {
    background: #fff;
    padding: 20px 20px 0px;
}

.record-first {
    display: flex;
    justify-content: space-evenly;
    gap: 10px;
}

.record-first .record-box {
    width: 50%;
}

.record-box {
    position: relative;
}

.record-box::before {
    background-image: url(../img/deco-left.png);
    background-repeat: no-repeat;
    content: "";
    display: inline-block;
    height: 56px;
    left: 0;
    position: absolute;
    top: 0;
    width: 28px;
}

.record-box::after {
    background-image: url(../img/deco-right.png);
    background-repeat: no-repeat;
    content: "";
    display: inline-block;
    height: 56px;
    position: absolute;
    top: 0;
    right: 0;
    width: 28px;
}

.record-first .record-box:first-child .record-box-lower {
    margin-top: -5px;
    padding-left: 11%;
}

.record-first .record-box:last-child {
    align-items: center;
    display: flex;
    flex-direction: column;
}

.record-first .record-box:last-child .record-num {
    font-size: 42px;
    letter-spacing: -0.02em;
    padding: 0 0px 7px;
}

.record-first .record-box:last-child .record-box-upper {
    letter-spacing: 0.1em;
    line-height: 1.3;
    margin-top: -6px;
}

.record-first .record-box:last-child .record-box-lower {
    margin-top: -10px;
}

.man-en {
    font-size: 9px;
    font-weight: 600;
    margin-left: 5px;
}

.record-box-upper {
    font-size: 10px;
    font-weight: 600;
    line-height: 1.3;
    text-align: center;
}

.record-box-upper span {
    border: #2C3033 0.5px solid;
    border-radius: 12px;
    font-family: "Hiragino Sans W4", "ヒラギノ角ゴシック", "メイリオ", "Meiryo", "Arial", sans-serif;
    font-size: 10px;
    padding: 0 3px;
    text-align: center;
}

.record-box-lowest {
    font-size: 13px;
    font-weight: 600;
    letter-spacing: 0.1em;
    margin-top: -16px;
}

.record-box-lower {
    align-items: center ;
    display: flex;
    justify-content: space-evenly;
}

.record-num {
    color: #4168AF;
    font-family: 'Open Sans', sans-serif;
    font-size: 47px;
    font-weight: bold;
    line-height: 1.3;
}

.vertical-text {
    font-size: 13px;
    font-weight: 600;
    line-height: 1.2;
    writing-mode: vertical-rl;
    letter-spacing: 0.2em;
}

.company-num {
    font-size: 11px;
    font-weight: 600;
    width: 35%;
}

.company-num span {
    font-size: 15px;
    font-weight: 600;
    letter-spacing: 0.2em;
    line-height: 1.2;
}

.record-sec {
    margin-top: 8px;
}

.record-sec .record-box {
    align-items: center;
    color: #2B3033;
    display: flex;
    justify-content: center;
    font-size: 21px;
    font-weight: 600;
    text-align: center;
}

.record-sec .record-box span {
    font-size: 42px;
    font-weight: bold;
    padding-bottom: 8px;
}

/*----　ロゴ　----*/
.scroll_logo_wrap {
    align-items: center;
    display: flex;
    margin-bottom: 0;
    overflow: hidden;
    padding: 0 0 5px;
}

.scroll_logo {
    align-items: center;
    animation: loop 20s -2s linear infinite;
    display: flex;
    justify-content: space-between;
    margin-bottom: 0;
    height: 75px;
}

.scroll_logo img {
    margin-right: 15px;
    width: 80px;
    max-height: 100%;
}

@keyframes loop {
    0% {
        -webkit-transform: translateX(0%);
        -ms-transform: translateX(0%);
        transform: translateX(0%);
    }
    to {
        -webkit-transform: translateX(-285%);
        -ms-transform: translateX(-285%);
        transform: translateX(-285%);
    }
}

@media screen and (max-width: 414px) {
    @keyframes loop {
        0% {
            -webkit-transform: translateX(0%);
            -ms-transform: translateX(0%);
            transform: translateX(0%);
        }
        to {
            -webkit-transform: translateX(-275%);
            -ms-transform: translateX(-275%);
            transform: translateX(-275%);
        }
    }
}

@media screen and (max-width: 393px) {
    @keyframes loop {
        0% {
            -webkit-transform: translateX(0%);
            -ms-transform: translateX(0%);
            transform: translateX(0%);
        }
        to {
            -webkit-transform: translateX(-291%);
            -ms-transform: translateX(-291%);
            transform: translateX(-291%);
        }
    }
}

@media screen and (max-width: 390px) {
    @keyframes loop {
        0% {
            -webkit-transform: translateX(0%);
            -ms-transform: translateX(0%);
            transform: translateX(0%);
        }
        to {
            -webkit-transform: translateX(-293%);
            -ms-transform: translateX(-293%);
            transform: translateX(-293%);
        }
    }
}

@media screen and (max-width: 375px) {
    @keyframes loop {
        0% {
            -webkit-transform: translateX(0%);
            -ms-transform: translateX(0%);
            transform: translateX(0%);
        }
        to {
            -webkit-transform: translateX(-305%);
            -ms-transform: translateX(-305%);
            transform: translateX(-305%);
        }
    }
}

@media screen and (max-width: 360px) {
    @keyframes loop {
        0% {
            -webkit-transform: translateX(0%);
            -ms-transform: translateX(0%);
            transform: translateX(0%);
        }
        to {
            -webkit-transform: translateX(-317%);
            -ms-transform: translateX(-317%);
            transform: translateX(-317%);
        }
    }
}

/*----------------------
        お悩み
----------------------*/
.problem {
    background: linear-gradient(#8BB5E5 0%, #FAFAFB 100%);
    padding: 43px 20px 20px;
    position: relative;
}

.problem_small {
    color: #fff;
    font-weight: 600;
    font-size: 16px;
    letter-spacing: 0.12em;
    line-height: 44px;
    text-align: center;
    text-shadow: 0px 0px 7px rgba(48, 104, 204, 0.5);
}

.problem h2 {
    color: #fff;
    font-weight: 600;
    font-size: 28px;
    letter-spacing: 0.1em;
    line-height: 1.2;
    text-align: center;
    text-shadow: 0px 0px 7px rgba(48, 104, 204, 0.5);
}

.problem h2 span {
    font-size: 36px;
    font-weight: 600;
}

.line-blue {
    text-align: center;
    width: 230px;
    margin: -20px auto 0;
}

.problem_list_box {
    background-size: cover;
    border-radius: 12px;
    box-shadow: 0px 0px 7px rgba(48, 104, 204, 20%);
    height: 160px;
    margin: 25px 0;
    opacity: 0.8;
    width: 100%;
}

.problem_list_box.fade-in-content-item-1 {
    background: url(../img/problem-bg-01.jpg) no-repeat;
    background-size: cover
}

.problem_list_box.fade-in-content-item-2 {
    background: url(../img/problem-bg-02.jpg) no-repeat;
    background-size: cover
}

.problem_list_box.fade-in-content-item-3 {
    background: url(../img/problem-bg-03.jpg) no-repeat;
    background-size: cover
}

.problem_list_box.fade-in-content-item-4 {
    background: url(../img/problem-bg-04.jpg) no-repeat;
    background-size: cover
}

.problem_list_box.fade-in-content-item-2 h3,
.problem_list_box.fade-in-content-item-4 h3 {
    text-align: right;
    padding-right: 17px;
}

 .problem_list_box.fade-in-content-item-4 {
    height: 198px;
 }

.problem_list_box_tt h3 {
    color: #2B3033;
    font-weight: 600;
    font-size: 20px;
    letter-spacing: 0.025em;
    text-align: left;
    padding: 30px 0 0 27px;
}

.problem_list_box_tt h3 span {
    background: linear-gradient(transparent 60%, #FFF850 60% 90%, transparent 90%);
    color: #4168AF;
}

.problem_list-wrap {
    margin-bottom: 55px;
}

.problem_ans {
    color: #2b3033;
    font-size: 24px;
    font-weight: 600;
    letter-spacing: 0.06em;
    line-height: 1.7;
    text-align: center;
}

.problem_ans span {
    background-color: #4168AF;
    border-radius: 5px;
    color: #fff;
    margin-right: 5px;
    padding: 3px 5px;
}

.problem_ans .problem_ans_img {
    align-items: center;
    display: flex;
    background-color: transparent;
    justify-content: center;
    margin-top: 10px;
}

.problem_ans .problem_ans_img img {
    width: 176px;
}

.problem:after {
    border-style: solid;
    border-width: 50px 50vw 0 50vw;
    border-color: #FAFAFB transparent transparent transparent;
    content: "";
    width: 0;
    height: 0;
    left: 0;
    position: absolute;
    top: 100%;
    right: 0;
}

/*----------------------
        メリット
----------------------*/
.content_block.merit {
    padding: 100px 20px 36px;
    position: relative;
}

.merit::after {
    border-style: solid;
    border-width: 40px 50vw 0 50vw;
    border-color: #FFFFFF transparent transparent transparent;
    content: "";
    width: 0;
    height: 0;
    left: 0;
    position: absolute;
    top: 99.9%;
    right: 0;
    z-index: 10;
}

.content_block .ballon {
    text-align: center;
}

.content_block .ballon img {
    width: 65px;
}

.merit h2 {
    color: #2b3033;
    font-family: "Zen Kaku Gothic New";
    font-weight: bold;
    font-size: 24px;
    letter-spacing: 0.03em;
    line-height: 1.2;
    margin-bottom: 28px;
    text-align: center;
}

.merit h2 div {
    align-items: center;
    display: flex;
    justify-content: center;
}

.merit h2 div img {
    height: 26px;
    margin-right: 5px;
}

.merit h2 span {
    color: #4168AF;
    font-size: 36px;
    line-height: 1.1;
}

.merit h2 span span {
    font-size: 30px;
}

.merit-img {
    margin: 0 auto 40px;
    text-align: center;
    width: 195px;
}

.merit .content_block_move p {
    color: #2b3033;
    font-weight: 600;
    font-size: 14px;
    letter-spacing: -0.01em;
    line-height: 29px;
    text-align: left;
}

.merit .content_block_move p span {
    background: linear-gradient(transparent 60%, #FFF850 60% 90%, transparent 90%);
    font-weight: 700;
}

.merit .content_block_move p:last-of-type {
    margin-top: 30px;
}

/*----------------------
    サブスク＠とは？
----------------------*/
.content_block.what {
    padding: 0;
}

.content-slider {
    background-color: #fff;
}

.content-slider-box {
    background-size: 110%;
    background-repeat: no-repeat;
    padding: 80px 0 30px;
}

.content-slider-box1 {
    background-image: url(../img/what-bg-01.jpg);
}

.content-slider-box2 {
    background-image: url(../img/what-bg-02.jpg);
}

.content-slider-box3 {
    background-image: url(../img/what-bg-03.jpg);
}

.content-slider-box4 {
    background-image: url(../img/what-bg-04.jpg);
}

.content-slider-box5 {
    background-image: url(../img/what-bg-05.jpg);
}

.content-slider-box h2 {
    align-items: center;
    color: #fff;
    display: flex;
    font-family: "Zen Kaku Gothic New";
    justify-content: center;
    letter-spacing: 0.05em;
    margin-bottom: 34px;
    text-align: center;
}

.content-slider-box h2 img {
    margin-right: 10px;
}

.content-slider-box p {
    color: #fff;
    font-weight: 500;
    font-size: 14px;
    line-height: 2;
    letter-spacing: 0.01em;
    padding: 0 20px 0;
}

.content-slider-box .btn {
    background-color: transparent;
    border: #FFF 1px solid;
    border-radius: 26px;
    color: #FFF;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.1em;
    line-height: 1.3;
    margin: 30px auto 0;
    padding: 15px 0;
    width: 90%;
}

/*----------------------
　サブスク＠で出来ること
----------------------*/
.service {
    padding: 50px 20px 0;
}

.service_box > img {
    height: auto;
    width: 100%;
}

.service h2 {
    font-size: 24px;
    font-family: "Zen Kaku Gothic New";
    font-weight: 600;
    line-height: 1.7;
    margin-bottom: 36px;
    text-align: center;
}

.service h2 img {
    margin-right: 8px;
    width: 139px;
}

.service h2 span {
    font-size: 30px;
}

.service.content_block {
    padding: 50px 0 0;
}

.tab-btn {
    background-color: #4168AF;
    border-radius: 5px 5px 0 0;
    color: #fff;
    cursor: pointer;
    font-size: 14px;
    font-weight: 600;
    letter-spacing: 0.2em;
    list-style: none;
    padding: 10px 0;
    text-align: center;
    width: 44%;
}

.tab-btn i {
    font-size: 10px;
    margin-right: 10px;
    position: relative;
}


.tab-btn i::after {
    border: solid #fff 1px;
    border-radius: 50%;
    box-sizing: border-box;
    content: "";
    height: 17px;
    position: absolute;
    width: 17px;
    top: -4px;
    left: -6px;
}

.tab-btn.show i::before {
    content: "\f107";
}

.tab-btn.show i::after {
    border: solid #2B3033 1px;
}

.tab-btn:first-child.show i::after {
    left:-5px;
    top: -5px
}

.tab-btn:last-child.show i::after {
    left: -5.5px;
}

.tab-btn img {
    margin-right: 10px;
}

.tab-btn.show {
    background: #FFFFFF;
    border: 1px solid #4168AF;
    border-bottom: 1px solid #FFFFFF;
    color: #2B3033;
}

.tab-contents.show {
    border-top: 1px solid #4168AF;
}

.tab-wrap ul {
    display: flex;
    gap: 9px;
    justify-content: center;
}

.tab-wrap ul li {
    position: relative;
}

.tab-wrap ul li.show::after {
    background: #ffffff;
    content: "";
    display: inline-block;
    height: 2px;
    left: 0;
    position: absolute;
    top: 46px;
    width: 100%;
}

.service_box {
    padding: 28px 0 0;
}

.service_box_ttl {
    align-items: center;
    color: #2B3033;
    display: flex;
    margin-bottom: 26px;
    padding: 0 20px;
}

.tab-contents {
    display: none;
}

.tab-contents.show {
    display: block;
}

.service_box_ttl_num {
    color: #4168AF;
    font-family: 'Open Sans', sans-serif;
    font-size: 42px;
    line-height: 1.3;
    margin-right: 25px;
}

.service_box_ttl_tt {
    color: #2b3033;
    font-weight: 600;
    font-size: 20px;
    letter-spacing: 0.03em;
    line-height: 1.3;
}

.service_box_ttl_tt.service_box_smaller {
    font-size: 17.7px;
    letter-spacing: 0.01em;
}

.service_box p {
    color: #2B3033;
    font-size: 14px;
    font-weight: 600;
    line-height: 1.7;
    margin-bottom: 23px;
    padding: 0 20px;
}

.service_box_explain {
    background-color: #FAFAFB;
    margin-top: -10px;
    padding: 16px 20px 28px;
    position: relative;
}

.service_box_explain::before {
    border-radius: 50px 50px 0 0;
    background: #FAFAFB;
    content: "";
    display: inline-block;
    height: 45px;
    left: 42%;
    position: absolute;
    top: -40px;
    width: 65px;
}

.box_bright_img {
    margin-top: -40px;
    text-align: center;
}

.box_bright_img img {
    height: 25px;
    width: 25px;
}

.service_box_explain_ttl {
    color: #4168AF;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.025em;
    line-height: 1.3;
    margin: 10px 0 11px;
    text-align: center;
}

.service_box_explain_arrow {
    margin-bottom: 19px;
    text-align: center;
}

.service_box_explain_arrow img {
    width: 15px;
}

.service_tab .service_box_explain_list {
    display: block;
    padding: 0 20px;
}

.service_box_explain_list li {
    color: #4168AF;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.75;
    list-style: disc;
}

.service_tab .service_box_explain_list li::before {
    content: none;
}

.service_box_explain_list li:first-child {
    margin-bottom: 22px;
}

.service_box_explain_list li span {
    color: #2B3033;
    font-weight: 600;
}

.abt_ticket, .abt_product {
    font-size: 14px;
    font-weight: 500;
    margin: 23px 0 55px;
    padding-right: 20px;
    text-align: right;
}

.abt_ticket a, .abt_product a {
    align-items: center;
    color: #2B3033;
    display: flex;
    font-weight: 600;
    justify-content: flex-end;
}

.abt_ticket img, .abt_product img {
    height: 16px;
    margin-right: 10px;
    width: 16px;
}

/*----------------------
    資料ダウンロード
----------------------*/
.download {
    background-color: #FAFAFB;
    padding: 42px 20px 52px;
}

.content_block.download h2 {
    font-size: 28px;
    font-weight: 600;
    letter-spacing: 0.025em;
    line-height: 1.5;
    text-align: center;
}

.download-slider {
    margin: 0 auto;
    width: 94%;
}

.download-slider-box img {
    border-radius: 10px 10px 0 0;
}

.download-slider-box {
    background-color: #FFFFFF;
    border-radius: 0 0 10px 10px;
    margin: 47px 20px 25px;
    position: relative;
}

.download-slider-ttl {
    color: #2B3033;
    font-size: 18px;
    font-weight: 600;
    letter-spacing: 0.025em;
    line-height: 1.4;
    margin-bottom: 13px;
    padding: 0 26px;
}

.download-slider-tt {
    color: #808385;
    font-size: 14px;
    letter-spacing: 00.025em;
    line-height: 1.7;
    padding: 0 26px;
    margin-bottom: 25px;
}

.download-tt-btn {
    color: #4168AF;
    font-size: 16px;
    font-weight: 600;
    letter-spacing: 0.07em;
    line-height: 1.3;
    padding-bottom: 35px;
    text-align: center;
}

.download-tt-btn i {
    margin-top: 10px;
}
.download .swiper-pagination-bullet-active {
    background: #4168AF;
}

.download .swiper-button-next.swiper-button-disabled, .download .swiper-button-prev.swiper-button-disabled {
    opacity: 1;
}

.download .swiper-button-next:after, .download .swiper-button-prev:after {
    font-size: 15px;
}

.download .swiper-button-next, .download .swiper-button-prev {
    color: #EBE7E7;
    top: 98.8%;
}

.download .swiper-button-prev {
    left: 26%;
}

.download .swiper-button-next {
    right: 26%;
}

.swiper-slide:first-child .download-slider-box:before,
.swiper-slide:nth-child(2) .download-slider-box:before {
    border-radius: 50%;
    background-color: #4168AF;
    content: "";
    display: inline-block;
    width: 53px;
    height: 53px;
    top: -20px;
    position: absolute;
    right: -20px;
}

.swiper-slide:first-child .download-slider-box::after,
.swiper-slide:nth-child(2) .download-slider-box:after {
    color: #fff;
    content: "UP \A DATE";
    display: inline-block;
    line-height: 1.1;
    font-size: 12px;
    font-weight: bold;
    letter-spacing: 0.025em;
    text-align: center;
    top: -8px;
    position: absolute;
    right: -12px;
    white-space: pre;
}


.swiper-slide:nth-child(n + 6) {
    display: none;
}

.swiper-pagination-clickable .swiper-pagination-bullet:nth-child(n + 6) {
    display: none;
}

.download .swiper-pagination.swiper-pagination-bullets.swiper-pagination-horizontal {
    bottom: -4px;

}

/*----------------------
        CTA
----------------------*/

.cta {
    background-color: #FAFAFB;
    padding: 42px 20px 52px;
}

.content_block.cta h2 {
    font-size: 24px;
    font-weight: 600;
    letter-spacing: 0.025em;
    line-height: 1.5;
    text-align: center;
}

.logo {
    text-align: center;
}

.logo img {
    margin: 35px 0 0;
    width: 177px;
}

/*----------------------
        フッター
----------------------*/
.footer_block {
    padding: 26px 20px 32px;
}

.footer_block_link ul {
    display: flex;
    justify-content: space-between;
    margin-bottom: 10px;
}

.footer_block_link ul li {
    color: #808385;
    font-weight: normal;
    font-size: 12px;
    letter-spacing: 0.03em;
    line-height: 24px;
    text-align: left;
}

.footer_block_copyright {
    color: #808385;
    font-weight: normal;
    font-size: 12px;
    letter-spacing: 0.03em;
    line-height: 24px;
    text-align: center;
}

.footer_block_link img {
    width: 88px;
}

.header_fv.pc_only {
    background: url(../img/pc-bg.png) no-repeat center top;
    background-size: cover;
    display: block;
    height: 100%;
    left: 0;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: -1;
}

/*----------------------
        PC版
----------------------*/
@media screen and (min-width: 768px) {
    /*----　PC画面　----*/
    .header_fb_btn img {
        width: 16px;
    }

    .main-content {
        margin-left: 50%;
        max-width: 400px;
        padding-top: 87px;
        width: 100%;
    }

    .header_fv.sp_content {
        border-radius: 30px 30px 0 0;
    }

    .header_fv_left {
        align-items: center;
        position: fixed;
        display: flex;
        flex-direction: column;
        left: 17%;
        top: 358px;
    }

    .header_fv_left h2 {
        font-size: 16px;
        font-weight: 500;
        line-height: 1.3;
        letter-spacing: 0.025em;
        text-align: center;
    }

    .header_fv_left h2 img {
        margin: 35px 0 31px;
        width: 177px;
    }

    .pc-page-top {
        font-family: "Roboto";
        font-size: 14px;
        top: 642px;
        font-weight: 500;
        font-style: italic;
        margin-top: 84px;
    }

    .pc-page-top::before {
        background: url(../img/pc-arrow.png) no-repeat;
        content: "";
        display: inline-block;
        height: 14px;
        left: 47%;
        position: absolute;
        margin-top: -10px;
        width: 20px;
    }

    .problem:after,
    .merit::after {
        border-width: 35px 200px;
    }

    .footer_block {
        max-width: 400px;
        margin-left: 50%;
        padding: 26px 0 32px;
    }

    .content_block.merit,
    .scroll_logo_wrap,
    .service.content_block,
    .footer_block,
    .abt_ticket,
    .abt_product {
        background: #fff;
        background-size: cover;
    }

    .problem:after {
        z-index: 5;
    }

    .abt_ticket, .abt_product {
        margin: 23px 0 0;
        padding-bottom: 55px;
    }

    .footer_block_link ul {
        padding: 0 20px;
    }

    /*----　ボタン　----*/
    .floating_btn .blue-btn,
    .floating_btn .white-btn {
        margin-left: 47%;
        max-width: 372px;
    }

    .header_fb_btn i {
        margin-right: 15px;
    }

    .floating_btn .white-btn {
        top: 88%;
    }

    .header_fb_btn {
        background-color: #4168AF;
        border: 2px #FFFFFF solid;
        border-radius: 26px;
        color: #fff;
        font-size: 16px;
        font-weight: 600;
        text-align: center;
        margin: 0 auto;
        padding: 12px 0;
        width: 304px;
    }

    .header_fb_btn a {
        display: block;
    }

    .header_fb_btn img {
        margin-right: 10px;
    }
}

/*----------------------
        ipad
----------------------*/
@media screen and (min-width: 768px) and (max-width: 1024px){
    .header_fv_left {
        left: 5%;
    }

    .main-content {
        margin-left: 46% ;
    }

    .footer_block {
        margin-left: 46%;
    }

    .floating_btn .blue-btn, .floating_btn .white-btn {
        margin-left: 43%;
    }

    .merit::after {
        top: 99.8%;
    }

}