﻿@import"https://fonts.googleapis.com/css2?family=M+PLUS+1p:wght@700&family=Montserrat:wght@500&family=Noto+Sans+JP:wght@100..900&family=Open+Sans:wdth,wght@75..100,300..800&display=swap";

* {
    box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box
}

html {
    min-height: 100%;
    position: relative;
    text-align: center
}

body {
    color: #000;
    font-family: "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", "Yu Gothic", YuGothic, "メイリオ", Meiryo, sans-serif;
    font-size: 16px;
    margin: 0;
    padding: 115px 0 0 !important;
    position: relative;
    text-align: center
}

@media screen and (max-width: 767px) {
    body {
        padding-top: 18.4615384615vw !important;
        width: 100%
    }
}

table {
    border-collapse: collapse;
    border-style: none;
    border-spacing: 0
}

a {
    color: #2073c8;
    outline: none;
    transition: all .2s ease-in
}

a:link,
a:active,
a a:visited {
    text-decoration: none
}

a:hover {
    opacity: .7;
    text-decoration: underline
}

h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
form,
input,
select,
label {
    font-weight: normal;
    margin: 0;
    outline: none;
    padding: 0
}

ul {
    list-style: none outside
}

p,
li,
dt,
dd {
    font-size: 16px;
    letter-spacing: .05em;
    line-height: 1.8;
    margin: 0
}

@media screen and (max-width: 767px) {

    p,
    li,
    dt,
    dd {
        font-size: 3.8461538462vw
    }
}

img {
    border-style: none;
    height: auto;
    vertical-align: bottom;
    width: 100%
}

header {
    background: rgba(255, 255, 255, .8);
    height: 115px;
    margin: 0 auto;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 999;
    border-bottom: 2px solid #ff9900;
}

@media screen and (max-width: 767px) {
    header {
        height: 72px
    }
}

header .header__txt {
    color: #000;
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
    position: absolute;
    top: 10px;
    left: 20px
}

@media screen and (max-width: 767px) {
    header .header__txt {
        left: 10px;
        zoom: .8
    }
}

header .header__logo {
    line-height: 1;
    position: absolute;
    top: 35px;
    left: 20px;
    width: 260px
}

@media screen and (max-width: 767px) {
    header .header__logo {
        top: 5.4102564103vw;
        left: 2.0512820513vw;
        width: 52.641025641vw
    }
}

header .header__btn {
    display: none
}

@media screen and (max-width: 767px) {
    header .header__btn {
        display: block;
        height: 10.2564102564vw;
        position: absolute;
        top: 5.1282051282vw;
        right: 2.5641025641vw;
        width: 10.2564102564vw
    }

    header .header__btn span {
        background: #000;
        content: "";
        height: .2564102564vw;
        pointer-events: none;
        position: absolute;
        top: 50%;
        left: 1.2820512821vw;
        transform: translate(0, -50%);
        width: 7.6923076923vw
    }

    header .header__btn::before {
        background: #000;
        content: "";
        pointer-events: none;
        height: .2564102564vw;
        position: absolute;
        top: 2.5641025641vw;
        left: 1.2820512821vw;
        width: 7.6923076923vw
    }

    header .header__btn::after {
        background: #000;
        content: "";
        pointer-events: none;
        height: .2564102564vw;
        position: absolute;
        bottom: 2.5641025641vw;
        left: 1.2820512821vw;
        width: 7.6923076923vw
    }
}

header .header__btn--close {
    display: none
}

@media screen and (max-width: 767px) {
    header .header__btn--close {
        cursor: pointer;
        display: block;
        height: 5.1282051282vw;
        position: absolute;
        top: 7.4358974359vw;
        right: 4.1025641026vw;
        width: 6.6666666667vw;
        z-index: 2
    }

    header .header__btn--close::before {
        background: #000;
        content: "";
        height: 7.6923076923vw;
        pointer-events: none;
        position: absolute;
        top: -5px;
        left: 50%;
        transform: translate(-50%, 0) rotate(45deg);
        width: .2564102564vw
    }

    header .header__btn--close::after {
        background: #000;
        content: "";
        height: 7.6923076923vw;
        pointer-events: none;
        position: absolute;
        top: -5px;
        left: 50%;
        transform: translate(-50%, 0) rotate(-45deg);
        width: .2564102564vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu {
        background: #f8fcfe;
        height: 100vh;
        position: absolute;
        top: 0;
        right: -100%;
        transition: .5s;
        width: 100%;
        z-index: 100
    }

    header .header__menu::before {
        background: url(../images/common/logo.png) no-repeat left top;
        background-size: 100%;
        content: "";
        height: 11.5384615385vw;
        position: absolute;
        top: 5.641025641vw;
        left: 50%;
        transform: translate(-50%, 0);
        width: 25.641025641vw
    }

    header .header__menu::after {
        content: "Contents Menu";
        font-family: "Montserrat", sans-serif;
        font-size: 2.5641025641vw;
        position: absolute;
        top: 17.9487179487vw;
        left: 50%;
        transform: translate(-50%, 0);
        text-align: center;
        width: 25.641025641vw
    }

    header .header__menu.active {
        right: 0
    }
}

header .header__menu_list {
    display: flex;
    position: absolute;
    top: 80px;
    right: 20px
}

@media screen and (max-width: 767px) {
    header .header__menu_list {
        display: block;
        top: 26.9230769231vw;
        right: auto;
        left: 50%;
        transform: translate(-50%, 0);
        width: 56.4102564103vw
    }
}

header .header__menu_list li {
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    position: relative
}

@media screen and (max-width: 1280px) {
    header .header__menu_list li {
        font-size: 1.09375vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_list li {
        font-size: 4.1025641026vw;
        margin-bottom: 5.3333333333vw
    }

    header .header__menu_list li:last-child {
        margin-bottom: 0
    }
}

header .header__menu_list li::before {
    color: #000;
    content: "|";
    margin: 0 10px
}

@media screen and (max-width: 1280px) {
    header .header__menu_list li::before {
        margin: 0 .78125vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_list li::before {
        display: none
    }
}

header .header__menu_list li:first-child::before {
    display: none
}

header .header__menu_list a {
    color: #000
}

header .header__menu_list a:hover {
    color: #ff9900;
    opacity: 1
}

header .header__menu_btn {
    display: flex;
    position: absolute;
    top: 0;
    right: 0
}

@media screen and (max-width: 767px) {
    header .header__menu_btn {
        display: block;
        top: 98.6666666667vw;
        right: auto;
        left: 50%;
        transform: translate(-50%, 0);
        width: 56.4102564103vw
    }
}

header .header__menu_btn li {
    border: solid #000 1px;
    border-top: none;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    margin-left: 2px;
    color: #000;
}

@media screen and (max-width: 1280px) {
    header .header__menu_btn li {
        font-size: 1.09375vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li {
        border: solid #ff9900 .5128205128vw;
        border-radius: 2.5641025641vw;
        font-size: 4.1025641026vw;
        margin-bottom: 3.8461538462vw;
        margin-left: 0;
        overflow: hidden;
        width: 100%
    }
}

header .header__menu_btn li a {
    align-items: center;
    background: #fff;
    display: flex;
    height: 44px;
    justify-content: center;
    width: 180px;
    color: #000;
}

@media screen and (max-width: 1280px) {
    header .header__menu_btn li a {
        height: 3.4375vw;
        width: 14.0625vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li a {
        height: 12.8205128205vw;
        width: 100%
    }
}

header .header__menu_btn li.application a {
    background: #FFE5BD;
    padding-left: 20px;
    position: relative;
    color: #000;
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li.application a {
        padding-left: 7.6923076923vw
    }
}

header .header__menu_btn li.application a::before {
    background: url(../images/common/icn_application.png) no-repeat left top;
    background-size: 100%;
    content: "";
    height: 20px;
    position: absolute;
    top: 12px;
    left: 24px;
    width: 20px
}

@media screen and (max-width: 1280px) {
    header .header__menu_btn li.application a::before {
        height: 1.5625vw;
        top: .9375vw;
        left: 1.875vw;
        width: 1.5625vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li.application a::before {
        height: 6.1538461538vw;
        top: 3.0769230769vw;
        left: 9.7435897436vw;
        width: 6.1538461538vw
    }
}

header .header__menu_btn li.contact a {
    padding-left: 20px;
    position: relative
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li.contact a {
        padding-left: 7.6923076923vw
    }
}

header .header__menu_btn li.contact a::before {
    background: url(../images/common/icn_contact.png) no-repeat left top;
    background-size: 100%;
    content: "";
    height: 18px;
    position: absolute;
    top: 14px;
    left: 28px;
    width: 18px
}

@media screen and (max-width: 1280px) {
    header .header__menu_btn li.contact a::before {
        height: 1.40625vw;
        top: 1.09375vw;
        left: 2.1875vw;
        width: 1.40625vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li.contact a::before {
        height: 6.1538461538vw;
        top: 3.5897435897vw;
        left: 9.7435897436vw;
        width: 6.1538461538vw
    }
}

header .header__menu_btn li.login a {
    padding-left: 20px;
    position: relative
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li.login a {
        padding-left: 7.6923076923vw
    }
}

header .header__menu_btn li.login a::before {
    background: url(../images/common/icn_mypage.png) no-repeat left top;
    background-size: 100%;
    content: "";
    height: 18px;
    position: absolute;
    top: 14px;
    left: 35px;
    width: 18px
}

@media screen and (max-width: 1280px) {
    header .header__menu_btn li.login a::before {
        height: 1.40625vw;
        top: 1.09375vw;
        left: 2.734375vw;
        width: 1.40625vw
    }
}

@media screen and (max-width: 767px) {
    header .header__menu_btn li.login a::before {
        height: 6.1538461538vw;
        top: 3.5897435897vw;
        left: 10.2564102564vw;
        width: 6.1538461538vw
    }
}

footer {
    padding: 80px 0
}

@media screen and (max-width: 767px) {
    footer {
        padding: 7.6923076923vw 0 5.1282051282vw
    }
}

footer .footer a {
    color: #000
}

footer .footer__logo {
    margin: 0 auto 30px;
    width: 160px
}

@media screen and (max-width: 767px) {
    footer .footer__logo {
        margin-bottom: 5.1282051282vw;
        width: 30.7692307692vw
    }
}

footer .footer__menu {
    border-top: solid #ccc 1px;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    padding-top: 30px;
    max-width: 1200px
}

@media screen and (max-width: 767px) {
    footer .footer__menu {
        display: block;
        padding: 7.6923076923vw 5.1282051282vw 0;
        width: 100%
    }
}

footer .footer__menu dl,
footer .footer__menu ul {
    margin: 0 auto;
    text-align: left
}

footer .footer__menu dl ul,
footer .footer__menu ul ul {
    margin: 0 auto
}

footer .footer__menu_head {
    font-size: 13px;
    font-weight: bold;
    margin-bottom: 10px
}

@media screen and (max-width: 767px) {
    footer .footer__menu_head {
        font-size: 3.3333333333vw;
        margin-bottom: 2.5641025641vw
    }
}

footer .footer__menu_list {
    font-size: 12px;
    margin-bottom: 5px
}

@media screen and (max-width: 767px) {
    footer .footer__menu_list {
        display: none
    }
}

footer .copyright {
    font-family: "Montserrat", sans-serif;
    font-size: 12px;
    margin-top: 50px
}

@media screen and (max-width: 767px) {
    footer .copyright {
        border-top: solid #ccc 1px;
        margin-top: 7.6923076923vw;
        padding-top: 5.1282051282vw
    }
}

@media screen and (max-width: 767px) {
    .fixed {
        overflow: hidden
    }
}

.pc_d {
    display: block
}

@media screen and (max-width: 767px) {
    .pc_d {
        display: none
    }
}

.sp_d {
    display: none
}

@media screen and (max-width: 767px) {
    .sp_d {
        display: block
    }
}

.left {
    text-align: left
}

.center {
    text-align: center
}

.right {
    text-align: right
}

.js-inview {
    opacity: 0;
    transition: all .4s ease-in
}

.js-inview.is-inview {
    opacity: 1;
    transition-delay: .2s
}

.mv {
    overflow: hidden;
    position: relative;
    width: 100%
}

@media screen and (max-width: 767px) {
    .mv {
        height: 64.1025641026vw
    }

    .mv img {
        height: 100%;
        object-fit: cover;
        width: 100%
    }
}

.ttl {
    background: rgba(255, 255, 255, .92);
    /* border-top: solid #052850 4px;
    border-bottom: solid #052850 4px; */
    color: #000;
    font-size: 42px;
    font-weight: 700;
    letter-spacing: 0;
    line-height: 1.2;
    padding: 10px 0;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(0, -50%);
    width: 100vw
}

@media screen and (max-width: 767px) {
    .ttl {
        font-size: 6.1538461538vw;
        padding: 2.5641025641vw 0
    }
}

.leadTxt {
    background: #FF9900;
    padding: 15px 0;
    width: 100%
}

@media screen and (max-width: 767px) {
    .leadTxt {
        padding: 3.8461538462vw
    }
}

.leadTxt h3{
    font-size: 24px;
    font-weight: bold;
    color: #fff;
    margin-bottom: 15px;
}

.leadTxt span{
    font-size: 16px;
    color: #fff;
    margin-right: 5px;
}

.leadTxt p {
    color: #fff
}

@media screen and (max-width: 767px) {
    .leadTxt p {
        font-size: 3.5897435897vw
    }
}

.cap {
    color: #ff9900;
    display: inline-block;
    font-family: "M PLUS 1p", sans-serif;
    font-size: 36px;
    letter-spacing: 0;
    line-height: 1;
    margin: 0 auto 40px;
    padding: 0 30px;
    position: relative
}

@media screen and (max-width: 767px) {
    .cap {
        font-size: 5.1282051282vw;
        line-height: 1.4;
        margin-bottom: 6.4102564103vw;
        overflow: hidden;
        padding: 0 6.4102564103vw
    }
}

.cap::before {
    border-right: solid #ff5700 4px;
    border-left: solid #ff5700 4px;
    content: "";
    display: block;
    height: 24px;
    position: absolute;
    top: 6px;
    left: 0;
    width: 4px
}

@media screen and (max-width: 767px) {
    .cap::before {
        height: 12.8205128205vw;
        top: 50%;
        transform: translate(0, -50%)
    }
}

.cap::after {
    border-right: solid #ff5700 4px;
    border-left: solid #ff5700 4px;
    content: "";
    display: block;
    height: 24px;
    position: absolute;
    top: 6px;
    right: 0;
    width: 4px
}

@media screen and (max-width: 767px) {
    .cap::after {
        height: 12.8205128205vw;
        top: 50%;
        transform: translate(0, -50%)
    }
}

.secondTop {
    margin: 0 auto;
    padding-bottom: 100px
}

@media screen and (max-width: 767px) {
    .secondTop {
        padding-bottom: 5.1282051282vw
    }
}

.secondTop__image {
    /* border: solid #000 1px; */
    display: block;
    margin: 80px auto 30px;
    max-width: 1000px
}

@media screen and (max-width: 767px) {
    .secondTop__image {
        height: 38.4615384615vw;
        margin: 10.2564102564vw 0 3.8461538462vw
    }

    .secondTop__image img {
        height: 100%;
        object-fit: cover;
        width: 100%
    }
}

.secondTop__image:hover {
    opacity: .7
}

.secondTop__cap {
    color: #FF9900;
    font-size: 24px;
    font-weight: 700;
    margin-bottom: 30px
}

@media screen and (max-width: 767px) {
    .secondTop__cap {
        font-size: 4.6153846154vw;
        margin-bottom: 3.8461538462vw
    }
}

.secondTop__btn {
    align-items: center;
    background: #FF9900;
    border: solid #FF9900 2px;
    border-radius: 6px;
    color: #fff;
    display: flex;
    font-family: "M PLUS 1p", sans-serif;
    height: 60px;
    justify-content: center;
    line-height: 1;
    margin: 0 auto 35px;
    position: relative;
    transition: all .2s ease-in;
    width: 300px
}

@media screen and (max-width: 767px) {
    .secondTop__btn {
        height: 12.8205128205vw;
        margin-bottom: 12.8205128205vw;
        width: 71.7948717949vw
    }
}

.secondTop__btn:hover {
    background: #fff;
    color: #FF9900;
    opacity: 1;
    text-decoration: none
}

.secondTop__btn:hover::before {
    border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #FF9900
}

.secondTop__btn::before {
    border-style: solid;
    border-width: 6px 0 6px 10.4px;
    border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #fff;
    content: "";
    height: 0;
    position: absolute;
    top: 23px;
    right: 10px;
    width: 0
}

@media screen and (max-width: 767px) {
    .secondTop__btn::before {
        top: 4.358974359vw
    }
}

.secondTop__btn::after {
    background: #666;
    border-radius: 6px;
    content: "";
    height: 60px;
    opacity: .4;
    position: absolute;
    right: -6px;
    bottom: -6px;
    width: 300px;
    z-index: -1
}

@media screen and (max-width: 767px) {
    .secondTop__btn::after {
        height: 12.8205128205vw;
        right: -1.5384615385vw;
        bottom: -1.5384615385vw;
        width: 71.7948717949vw
    }
}

.pageTop {
    background: #FF9900;
    border-radius: 60px;
    cursor: pointer;
    height: 60px;
    opacity: .8;
    position: fixed;
    right: 40px;
    bottom: 40px;
    width: 60px;
    transition: all .3s ease-in-out;
    z-index: 998
}

@media screen and (max-width: 767px) {
    .pageTop {
        border-radius: 10.2564102564vw;
        height: 10.2564102564vw;
        right: 2.5641025641vw;
        bottom: 5.1282051282vw;
        width: 10.2564102564vw
    }
}

.pageTop::before {
    border-color: rgba(0, 0, 0, 0) rgba(0, 0, 0, 0) #fff rgba(0, 0, 0, 0);
    border-style: solid;
    border-width: 0 10px 17.3px 10px;
    content: "";
    height: 0;
    pointer-events: none;
    position: absolute;
    top: 49%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 0
}

@media screen and (max-width: 767px) {
    .pageTop::before {
        border-width: 0 5px 8.3px 5px
    }
}

.pageTop:hover {
    opacity: .6
}

.red {
    color: red
}