@charset "utf-8";
/* CSS Document */

@font-face {
    font-family: 'noto sans sc';
    src: url('fonts/NotoSansSC-Thin.otf') format("truetype");
    font-weight: 100;
    font-style: normal;
}

@font-face {
    font-family: 'noto sans sc';
    src: url('fonts/NotoSansSC-Light.otf') format("truetype");
    font-weight: 200;
    font-style: normal;
}

@font-face {
    font-family: 'noto sans sc';
    src: url('fonts/NotoSansSC-Regular.otf') format("truetype");
    font-weight: 300;
    font-style: normal;
}

@font-face {
    font-family: 'noto sans sc';
    src: url('fonts/NotoSansSC-Medium.otf') format("truetype");
    font-weight: 400;
    font-style: normal;
}

@font-face {
    font-family: 'noto sans sc';
    src: url('fonts/NotoSansSC-Bold.otf') format("truetype");
    font-weight: 600;
    font-style: normal;
}

@font-face {
    font-family: 'noto sans sc';
    src: url('fonts/NotoSansSC-Black.otf') format("truetype");
    font-weight: 700;
    font-style: normal;
}

@font-face {
    font-family: 'EB garamond';
    src: url('fonts/EBGaramond-VariableFont_wght.ttf') format("truetype");
    font-weight: 100;
    font-style: normal;
}

@font-face {
    font-family: 'roboto condensed';
    src: url('fonts/RobotoCondensed-Regular.ttf') format("opentype");
}



@media all and (-ms-high-contrast: none) {
    .flex_cnt img.load {
        display: none !important;
    }
}


.sns {
    display: flex;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    align-items: center;
    margin-top: 30px;
    position: absolute;
    left: 10px;
    top: -10px;
}

.sns img {
    max-width: 34px;
    height: 34px;
    flex-shrink: 0;
    margin: 0 7px;
}



/*vegas---------------------------------- */

#vegas {
    width: 100vw;
    height: 100vh;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
    pointer-events: none;
}

#vegas2 {
    width: 100vw;
    height: 100vh;
    position: absolute;
    z-index: 0;
    top: 0;
    left: 0;
}

.vegas-timer-progress {
    color: #000000;
    background-color: #000000;
}


/*loading---------------------------------- */

.loadingAnim {
    position: fixed;
    z-index: 100;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    text-align: center;
    pointer-events: none;
}

.anim1 {
    transition: .5s;
    width: 100%;
    height: 100%;
    bottom: 0;
    position: absolute;
    background-color: #fff;
    display: block;
    transition-timing-function: cubic-bezier(.785, .135, .15, .86) 0s;
    z-index: 100;
    filter: blur(0px);
}

.anim1.on {
    transition: .5s;
    width: 100%;
    height: 0%;
    position: absolute;
    background-color: #fff;
    display: block;
    transition-timing-function: cubic-bezier(.785, .135, .15, .86) 0s;
    bottom: 0;
    filter: blur(0px);
}


.anim2 {
    transition: .5s;
    width: 100%;
    height: 100%;
    bottom: 0;
    position: absolute;
    background-color: #006ab7;
    display: block;
    transition-timing-function: cubic-bezier(.785, .135, .15, .86) 0s;
    filter: blur(0px);
}

.anim2.on {
    transition: .5s;
    width: 100%;
    height: 0%;
    position: absolute;
    background-color: #006ab7;
    display: block;
    transition-timing-function: cubic-bezier(.785, .135, .15, .86) 0s;
    bottom: 0;
    z-index: 99;
    filter: blur(0px);
}

.anim3 {
    position: relative;
    height: 260px;
    width: 260px;
    display: block;
    margin-left: auto;
    margin-right: auto;
    z-index: 300;
    opacity: 0;
    transition: .3s;
}

.anim3.on {
    opacity: 1;
}

.anim3:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 1px;
    width: 1px;
    transition: .3s;
    background-color: #000;
}

.anim3.on:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 1px;
    width: 260px;
    transition: 1s;
    background-color: #000;
}

.anim3.on.black:before {
    background-color: #fff;
}

.anim3.on.on2:before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    height: 1px;
    width: 0px;
    transition: .3s;
}


.anim3:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    height: 1px;
    width: 1px;
    transition: .3s;
    background-color: #000;
}

.anim3.on:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    height: 1px;
    width: 260px;
    transition: 1s;
    background-color: #000;
}

.anim3.on.black:after {
    background-color: #fff;
}

.anim3.on.on2:after {
    content: "";
    position: absolute;
    right: 0;
    bottom: 0;
    height: 1px;
    width: 0px;
    transition: .3s;
}

.lds-logo {
    position: absolute;
    display: flex;
    width: 100%;
    max-width: 100px;
    height: 100%;
    z-index: 500;
    transition: .3s;
    opacity: 0;
    filter: blur(30px);
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    align-items: center;
    top: -20px;
}

.flex_cnt img.load {
    display: flex;
    justify-content: center;
    align-items: center;
    margin: 0 auto;
    width: 71px;
    height: 71px;
    position: relative;
    top: 140px;
    z-index: 500;
}

.lds-logo.on {
    opacity: 1;
    filter: blur(0px);
}

.cls-1 {
    fill: #fff;
}


.lds-logo.on.off {
    opacity: 0;
    filter: blur(0px);
}

.lds-logo img {
    /*width: 200px;
    height: auto;*/
    width: 100px;
    height: auto;
    -webkit-animation: lds-logo 1000ms linear both;
    animation: lds-logo 1000ms linear both;
    z-index: 200;
    color: black;
    flex-shrink: 0;
}

.loaded .lds-logo {
    opacity: 0;
    transition: 2.0s;
    color: white;
}


@keyframes lds-logo {
    0% {
        filter: blur(0px);
        -webkit-filter: blur(0px);
        opacity: 0;
        transform: translateY(0px);
        transition: ease-out;
    }

    100% {
        filter: blur(0px);
        -webkit-filter: blur(0px);
        opacity: 1;
        transform: translateY(0px);
        transition: ease-out;
    }
}

@-webkit-keyframes lds-rogo {
    0% {
        filter: blur(0px);
        -webkit-filter: blur(0px);
        opacity: 0;
        top: 100px;
    }

    100% {
        filter: blur(0px);
        -webkit-filter: blur(0px);
        opacity: 1;
        top: 0px;
    }
}

.lds-ellipsis {
    display: block;
    width: 80px;
    height: 80px;
    margin-left: auto;
    margin-right: auto;
    position: relative;
    top: 120px;
    transition: .3s;
    opacity: 1;
    z-index: 999;
    animation: lds 1000ms linear both;
}

@keyframes lds {
    0% {
        filter: blur(30px);
        opacity: 0;
        transform: translateY(-30px);
    }

    100% {
        filter: blur(0px);
        opacity: 1;
        transform: translateY(0px);
    }
}

.lds-ellipsis div {
    position: absolute;
    top: 33px;
    width: 10px;
    height: 10px;
    border-radius: 50%;
    background: #000;
    animation-timing-function: cubic-bezier(0, 1, 1, 0);
    transition: .3s;
}

.lds-ellipsis.on div {
    opacity: 0;
    filter: blur(30px);
}

.loaded .lds-ellipsis div {
    opacity: 0;
}

.lds-ellipsis div:nth-child(1) {
    left: 8px;
    animation: lds-ellipsis1 0.6s infinite;
}

.lds-ellipsis div:nth-child(2) {
    left: 8px;
    animation: lds-ellipsis2 0.6s infinite;
}

.lds-ellipsis div:nth-child(3) {
    left: 32px;
    animation: lds-ellipsis2 0.6s infinite;
}

.lds-ellipsis div:nth-child(4) {
    left: 56px;
    animation: lds-ellipsis3 0.6s infinite;
}

@keyframes lds-ellipsis1 {
    0% {
        transform: scale(0);
    }

    100% {
        transform: scale(1);
    }
}

@keyframes lds-ellipsis3 {
    0% {
        transform: scale(1);
    }

    100% {
        transform: scale(0);
    }
}

@keyframes lds-ellipsis2 {
    0% {
        transform: translate(0, 0);
    }

    100% {
        transform: translate(24px, 0);
    }
}


/*side_menu------------------------*/

.menu_btn {
    position: fixed;
    z-index: 3;
    display: flex;
    opacity: 0;
    pointer-events: none;
    top: 0px;
    left: 0px;
    flex-direction: column;
    transition: .3s ease-out;
    cursor: pointer;
}

.menu_btn.alt {
    top: 75px;
}

.menu_btn.show {
    position: fixed;
    z-index: 10;
    display: flex;
    top: 20px;
    left: 20px;
    flex-direction: column;
}

.menu_btn .block {
    width: 75px;
    height: 75px;
    background-color: #000;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    transition: .3s;
    transform: scale(100%);
}

.menu_btn.alt .block {
    background-color: white;
    color: black;
}

.menu_btn .block.hover_trigger.on {
    opacity: 0.6;
}

.menu_btn img {
    width: 19px;
    height: auto;
    transition: .1s;
}

.menu_btn .block span:last-child {
    margin-bottom: 0px;
}

.menu_btn span.txt {
    font-family: "lusitana";
    font-size: 13px;
    text-align: center;
    color: white;
    display: block;
    width: 100%;
    line-height: 1;
    margin-top: 10px;
    transition: .1s;
}

.menu_btn.alt span.txt {
    color: black;
}


nav.menu i.fas.fa-caret-right {
    font-size: 10px;
}


.fa-calendar-alt:before {
    content: "\f073";
    font-size: 25px;
    transition: .1s
}

.overlay {
    opacity: 0;
    background-color: black;
    width: 100%;
    position: fixed;
    z-index: 2;
    top: 0;
    left: 0;
    height: 100vh;
    transition: .3s;
    pointer-events: none;
}

.overlay.active {
    opacity: 0.95;
    background-color: #00204c;
    z-index: 4;
    pointer-events: auto;
}

/*parts------------------------*/


a.line2 {
    border: 1px solid #ccc;
    padding: 5px 20px;
    margin-top: 30px;
    display: inline-block;
    transition: .3s;
}

a.line2:hover {
    opacity: 0.7;
}

a.line2 .fa-caret-right {
    margin-right: 10px;
}

section.flex {
    display: flex;
    flex-direction: column;
}

section h2 {
    font-size: 2.4em;
    font-weight: 300;
    text-align: center;
    font-family: "roboto condensed", "noto sans sc";
}

section h2 span {
    display: block;
    font-size: 14px;
    margin-top: 15px;
}

h2.ct, h3.ct {
    text-align: center;
}

h2.ct {
    position: relative;
    font-size: 40px;
    line-height: 2;
    padding-top: 30px;
    display: inline-block;
}

h3.ct {
    position: relative;
    font-size: 30px;
    line-height: 2;
    padding-top: 30px;
    display: inline-block;
}

#cmn .box h4 {
    font-size: 16px;
    background-color: #f8f8f8;
    padding: 5px 20px;
}

#cmn .box p {
    margin-top: 30px;
}

#cmn .box span {
    flex: none;
}

#cmn .box ol {
    list-style-type: decimal;
    margin-top: 30px;
}

#cmn .box ol.br li {
    display: flex;
}

#cmn .box ol li {
    list-style-type: none;
    margin-top: 20px;
}

#cmn .box ol li div {
    display: flex;
}

#cmn .box ol li ol li {
    margin-top: 0px;
}

#cmn .box ol li::before {
    display: inline-block;
    width: 20px;
}

#cmn .box ol.br {}

#cmn .box ol.br li::before {
    display: inline-block;
    width: 40px;
}

#cmn .box ol li ol {
    margin-top: 10px;
    margin-bottom: 10px;
    margin-left: 20px;
}

h3.ct.alt {
    margin: 0 auto;
}

h2.ct:before,
h3.ct:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 50%;
    height: 1px;
    background-color: black;
}

h2.ct:after,
h3.ct:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    display: block;
    width: 50%;
    height: 1px;
    background-color: #d8d8d8;
}

h2.ct span,
h3.ct span {
    display: block;
}

h3.ct span {
    font-size: 15px;
}

a.base_btn {
    position: relative;
    color: black;
    background-color: #dcdcdc;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center;
    z-index: 1;
    box-sizing: border-box;
    transition: .3s;
    width: 100%;
    max-width: 170px;
    font-family: "lusitana", "游明朝";
    margin-top: 50px;
}

.mv a.base_btn {
    max-width: 300px;
}

.mv a.base_btn {
    max-width: 300px;
    background-color: black;
}

.mv a.base_btn span {
    color: white;
    transition: .3s;
}

.mv a.base_btn:hover {
    background-color: white;
}

.mv a.base_btn:before {
    background-color: #fff;
}

.mv a.base_btn span:hover {
    color: black;
}

a.base_btn:hover {
    background-color: #fff;
    color: #000;
}

a.base_btn span {
    z-index: 2;
    padding: 7px;
    display: block;
    width: 100%;
    height: 100%;
    position: relative;
    color: black;
}

a.base_btn:before {
    content: "";
    top: 0px;
    left: 0px;
    width: 1px;
    height: 100%;
    background-color: #000;
    position: absolute;
    transition: .3s ease-out;
    z-index: 0;
    opacity: 0;
}

a.base_btn:after {
    content: "";
    top: 0px;
    right: 0px;
    width: 1px;
    height: 1px;
    background-color: #000;
    position: absolute;
    transition: .3s ease-out;
    opacity: 0;
}

a.base_btn:hover:before {
    width: 100%;
    opacity: 1;
}

a.base_btn:hover:after {
    height: 100%;
}

a.base_btn span:hover {
    color: white;
}

a.base_btn a.reserve_btn {
    font-size: 23px;
    text-align: center;
    background-color: #f1f1f1;
    transition: .3s;
    width: 100%;
    margin-top: 50px;
    padding: 30px;
    display: block;
    line-height: 1;
}

a.reserve_btn:hover {
    background-color: black;
    color: white;
}

/*header------------------------*/

header {
    width: 100%;
    padding-left: 0px;
    padding-right: 0px;
    display: flex;
    height: 100vh;
    max-width: 1920px;
    margin: 0 auto;
    position: relative;
    overflow: hidden;
    z-index: 0;
}

header .mv {
    /*background: url("../img/top/mv.jpg");*/
    background-size: cover;
    background-position: center center;
    width: 100%;
    position: relative;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    z-index: 0;
    transform: translate3d(0, 0, 0);
}

header .mv .sns_h {
    display: flex;
    margin-left: auto;
    margin-right: auto;
    justify-content: center;
    align-items: center;
    margin-top: 0;
    position: absolute;
    right: 15px;
    top: 20px;
    z-index: 1;
}

header .mv .sns_h a:link {
    transition: .3s;
    color: white;
    text-align: center;
}

.sns_h a img {
    max-width: 34px;
    height: 34px;
    flex-shrink: 0;
    margin: 0 7px;
}

header .mv .sns_h a:hover {
    opacity: 0.5;
}

header div.logo {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    position: relative;
    z-index: 1;
}

header div address {
    display: flex;
    position: absolute;
    top: 50px;
    left: 125px;
    color: white;
    font-size: 13px;
    font-family: "lusitana";
    z-index: 1;
    text-align: left;
    font-style: normal;
}

header div address p {
    text-align: left;
    margin-right: 25px;
    margin-top: 0px;
}

header div .lang {
    display: flex;
    flex-direction: column;
    position: absolute;
    top: 50px;
    right: 50px;
    z-index: 1;
}

header .fa-globe:before {
    content: "\f0ac";
}

header div .lang h2 {
    color: white;
    text-align: right;
    font-size: 13px;
}

header div .lang ul {
    display: flex;
}

header div .lang ul li {}

header div .lang li a:link {
    color: white;
    position: relative;
    padding-right: 20px;
    padding-left: 20px;
    border-right: 1px solid #818181;
    transition: .3s;
}

header div .lang li a:link:hover {
    opacity: 0.6;
}

header div h1 img {
    width: 99px;
    height: auto;
    vertical-align: middle;
}

header div p {
    color: white;
    text-align: center;
    margin-top: 30px;
    font-weight: 500;
}

header div p.open {
    font-size: 20px;
}

nav {
    position: fixed;
    z-index: 3;
    display: flex;
    width: 100%;
    left: 0px;
    top: 0px;
    padding-left: 0px;
    padding-top: 0px;
    transition: .3s;
    background-color: transparent;
}

nav a.contact:link {
    padding: 39px 25px;
    /* padding: 0px; */
    line-height: 1;
    font-family: 'roboto condensed';
    background-color: #006ab7;
    font-size: 15px;
    min-width: 140px;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: .3s;
}

nav a.contact:link:hover {
    background-color: white;
    color: #006ab7;
}

nav h1 {
    line-height: 1;
    justify-content: center;
    align-items: center;
    display: flex;
    margin-left: 50px;
}

nav ul {
    width: 100%;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    margin-left: 20px;
    transition: .3s;
}

nav li {
    transition: .3s;
    line-height: 1;
}

nav a:link, nav a:active, nav a:visited {
    color: white;
    padding: 10px 15px;
}

nav li a {
    transition: .3s;
    position: relative;
}

nav li a:after {
    content: "";
    position: absolute;
    width: 1px;
    height: 1px;
    opacity: 0;
    background-color: #006ab7;
    display: block;
    bottom: 0;
    left: 0;
    transition: .3s;
}

nav li.icon a:after {
    display: none;
}

nav li a:hover:after {
    opacity: 1;
    width: 100%;
}



nav .icon a:link {
    width: 30px;
    height: 30px;
    background-color: #006ab7;
    padding: 0px;
    border-radius: 1px;
    display: flex;
    text-align: center;
    justify-content: center;
    align-items: center;
    color: white;
    transition: .3s;
}

nav .icon a:link:hover {
    color: #006ab7;
    background-color: white;
}

nav li.icon {
    margin-right: 5px;
    margin-left: 5px;
}

header a.contact {
    font-family: "roboto condensed";
    font-size: 17px;
    position: absolute;
    right: 0;
}

header p.catch {
    font-family: "EB garamond";
    font-size: 70px;
    display: flex;
    flex-direction: column;
    position: absolute;
    z-index: 2;
    line-height: 1.2;
    text-align: left;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    width: 100%;
    max-width: 1280px;
    padding-left: 20px;
    padding-right: 20px;
}

header p.catch span {
    font-size: 17px;
    font-family: "roboto condensed";
}


/*news------------------------*/


section#news {
    position: relative;
    z-index: 2;
    background-color: white;
    width: 100%;
    margin: 0px;
    padding: 0px;
}

section#qr {
    padding: 0px;
    width: 300px;
    min-width: auto;
    margin: 0px;
    margin-left: 30px;
    /* background-color: #f9f9f9; */
    border-left: none;
    display: flex;
    flex-direction: row;
    font-family: "noto sans sc";
    justify-content: center;
    align-items: center;
    padding-left: 0px;
    padding-top: 0px;
}

section#qr span.title {
    font-size: 20px;
    margin-top: 0px;
    line-height: 1;
    font-family: "EB garamond";
}

section#qr span.tell {
    line-height: 1;
    font-weight: 200;
}

section#qr span.tell:nth-child(2) {
    margin-top: 10px;
}

section#qr div div {
    display: flex;
    flex-direction: column;
    margin-top: 30px;
    width: 200px;
}

section#qr img {
    max-width: 100px;
    width: 100%;
    height: auto;
    margin-top: 0px;
    vertical-align: bottom;
}

section#qr .fa-phone-square-alt:before {
    content: "\f87b";
    padding: 0px 5px;
    margin-left: 10px;
}

.main_cont {
    /* margin-top: -100px; */
    position: relative;
    top: -60px;
    z-index: 2;
    background-color: white;
    max-width: 1280px;
    /* padding-left: 30px; */
    /* padding-right: 30px; */
    /* padding-top: 10px; */
    /* padding-bottom: 10px; */
    padding: 0px;
    display: flex;
    margin: 0 auto;
    width: 100%;
    height: 60px;
}

.flex {
    display: flex;
}

section#news .flex {
    justify-content: space-between;
    align-items: center;
    display: flex;
    line-height: 0;
}

section#news ul {
    width: 85%;
    padding-left: 5%;
    padding-right: 75px;
    display: flex;
    flex-direction: column;
}

section#news ul li {
    display: flex;
    font-size: 13px;
    font-weight: 500;
    padding: 0px 0px;
    border-bottom: none;
    line-height: 1;
}

section#news ul li.pdf a {
    margin-left: 10px
}

section#news ul li.pdf a:link,
section#news ul li.pdf a:visited {
    color: #006ab7;
}

section#news ul li:first-child {
    padding-top: 0px;
}

section#news ul li span.date {
    line-height: 2;
    display: flex;
    align-items: center;
    justify-content: center;
}

section#news ul li span.cg {
    width: 130px;
    text-align: center;
    padding: 0px 20px;
    border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
    margin: 0px 20px;
    line-height: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 100px;
}

img.slide-arrow.prev-arrow.slick-arrow,
img.slide-arrow.next-arrow.slick-arrow {
    max-width: 15px;
}

img.slide-arrow.prev-arrow.slick-arrow {
    position: absolute;
    right: 45px;
}

img.slide-arrow.next-arrow.slick-arrow {
    position: absolute;
    right: 15px;
}

section#news ul li dl {
    display: flex;
}

section#news ul li dl dt {
    display: flex;
}

section#news ul li span.newstype {
    width: 130px;
    text-align: center;
    padding: 0px 20px;
    border-left: 1px solid #ccc;
    border-right: 1px solid #ccc;
    margin: 0px 20px;
    line-height: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    min-width: 100px;
}

section#news ul li {
    transition: .3s;
}

section#news ul li:hover {
    color: #006ab7;
}

section#news ul li a,
section#news ul li p {
    line-height: 1;
    transition: .3s;
}

section#news ul li a {
    line-height: 1;
    transition: .3s;
    position: absolute;
    height: 30px;
    width: 100%;
    top: 0;
}

section#news ul li p {
    line-height: 2;
}

section#news ul li a:hover {
    opacity: 0.7;
}

section#news h2 {
    font-size: 12px;
    font-weight: normal;
    text-align: center;
    font-family: "roboto condensed", "noto sans sc";
    line-height: 1;
    width: 15%;
    color: #006ab7;
}

section#news h2 span {
    display: block;
    font-size: 20px;
    margin: 0px;
    line-height: 1;
}

section#news a.more {
    font-family: "roboto condensed";
    font-size: 18px;
    display: flex;
    flex-direction: column;
    width: 10%;
    justify-content: center;
    align-items: center;
    color: #006ab7;
    padding: 30px 20px;
    background-color: #e8e8e8;
}

section#news a.more span {
    font-size: 12px;
    color: #006ab7;
    font-family: "noto sans sc";
}


/*other------------------------*/


.outer_bg {
    width: 100%;
    background: url("../img/top/bg_pattern.gif") repeat;
    display: block;
    margin-top: 100px;
    position: relative;
}

.outer_bg.alt2 {
    background: none;
}

.outer_bg.alt {
    padding-bottom: 100px;
    padding-top: 0px;
}

footer {
    width: 100%;
    margin-top: 0px;
    /* background: url(../img/top/bg_footer.jpg); */
    padding-top: 75px;
    padding-bottom: 0px;
    color: white;
    position: relative;
    background-color: #012b44;
    top: -100px;
}

/*footer------------------------*/

footer {
    width: 100%;
    margin-top: -60px;
    /* background: url(../img/top/bg_footer.jpg); */
    padding-top: 75px;
    padding-bottom: 0px;
    color: white;
    position: relative;
    background-color: #012b44;
    top: 0px;
}

footer address {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    font-style: normal;
    margin-top: 50px;
}

footer a:link, footer a:visited {
    transition: .3s;
    color: white;
    text-align: center;
}

footer a:hover {
    opacity: 0.5;
}

footer .outer {
    width: 100%;
    padding: 70px 0px;
    background-color: #f5f7f9;
}

#copy {
    font-family: "lusitana", "游明朝";
    display: flex;
    justify-content: center;
    flex-direction: column;
    margin-top: 0px;
    background-color: white;
    padding: 30px;
    margin: 0px;
    color: black;
}

#copy div {
    display: flex;
    justify-content: center;
}

#copy img {
    width: 260px;
    height: 41px;
    margin: 0 auto;
}

#copy .right {
    width: 65%;
    display: flex;
}

#copy p.link {
    text-align: right;
    margin-top: 50px;
}

#copy p.link a {
    border-right: 1px solid #ccc;
    padding-right: 12px;
    margin-right: 12px;
}

#copy p.link a .fa-angle-right {
    display: none;
}

#copy .inr {
    display: flex;
    justify-content: space-between;
    max-width: 1280px;
    width: 100%;
    padding-left: 0px;
    padding-right: 0px;
    margin: 0 auto;
    font-family: "Microsoft YaHei", "微软雅黑", "SimHei", sans-serif;
    font-weight: 500;
}

#copy .inr ul {
    display: flex;
    justify-content: center;
    align-items: baseline;
}

#copy .inr ul li {
    border-right: 1px solid #bbb;
    line-height: 1;
}

#copy .inr ul li:first-child {
    border-left: 1px solid #bbb;
}

#copy .inr ul a {
    padding: 0px 30px;
}

#copy .note {
    flex-direction: column;
}

#copy .copyright {
    font-family: "roboto condensed";
    margin-top: 0px;
    font-size: 14px;
    font-weight: normal;
    max-width: 1280px;
    /* padding-left: 50px; */
    /* padding-right: 50px; */
    line-height: 1;
    display: block;
    justify-content: center;
    /* align-items: baseline; */
    flex-direction: column;
    text-align: right;
    line-height: 2;
}

#copy a:link, #copy a:visited {
    color: #012b44;
}

.term {
    position: absolute;
    right: 0px;
    top: 10px;
}

.term a {
    margin-right: 20px;
    color: white;
}


a.goto {
    position: absolute;
    bottom: 30px;
    right: 30px;
    transition: .3s;
}

a.goto:hover {
    opacity: 0.8;
}

a.goto img {
    width: 100%;
    height: auto;
}

section#s_menu {
    margin-top: 0px;
    padding-bottom: 75px;
    max-width: 1280px;
    width: 100%;
    padding-left: 20px;
    padding-right: 20px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    font-size: 14px;
}

section#s_menu dl {
    display: flex;
    flex-direction: column;
}

section#s_menu dt {}

section#s_menu dd {}

section#s_menu ul.wrap {
    max-width: 1000px;
    display: flex;
}

section#s_menu li {
    display: flex;
    flex-direction: column;
    padding-left: 20px;
    padding-right: 20px;
    border-right: 1px solid #1a6592;
}

section#s_menu li.m1 {
    max-width: 470px;
    border-left: 1px solid #1a6592;
}

section#s_menu li.m2 {
    max-width: 170px;
}

section#s_menu li.m2 dd ul {
    display: flex;
    flex-wrap: wrap;
}

section#s_menu ul li ul {
    display: flex;
    flex-wrap: wrap;
}

section#s_menu i.fas.fa-caret-right {
    color: #1a6592;
    padding-right: 5px;
}

section#s_menu ul li ul li {
    font-size: 13px;
    padding: 0px;
    font-family: "roboto condensed";
    border: none;
    justify-content: flex-start;
    align-items: flex-start;
}

section#s_menu ul li.m1 ul li {
    width: 33%;
}

section#s_menu ul li ul li a {}

section#s_menu .note {
    max-width: 200px;
    font-size: 13px;
    text-align: right;
}

section#s_menu .note p:nth-child(2) {
    margin-top: 30px;
}

.slick-dotted.slick-slider {
    margin-bottom: 30px;
}

.top__slider {}

.wrap_top__slider {
    z-index: 1;
    left: 0;
    transform: translateY(180px);
    position: absolute;
    width: 100%;
    max-width: 1280px;
    margin-left: auto;
    margin-right: auto;
    display: flex;
    right: 0;
    padding-left: 20px;
}

.top__slider.slick-slider {
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    -webkit-tap-highlight-color: transparent;
}

.top__slider .slider__img img {
    width: 100%;
}

.top__slider .slider__img {
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.top__slider .slider__img {
    width: 220px;
}

.top__slider .slider__item a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    display: -ms-flex;
    display: -webkit-flex;
}

.top__slider {
    margin-bottom: 45px;
    width: 535px;
}

.top__slider .slick-next {
    left: 200px;
    top: auto;
    bottom: -50px;
    z-index: 10;
}

.top__slider .slick-dots {
    position: absolute;
    bottom: -25px;
    list-style: none;
    display: block;
    text-align: center;
    padding: 0;
    margin: 0;
    width: 100%;
    bottom: -40px;
    width: 220px;
    left: 0;
}

.top__slider .slick-dots li {
    position: relative;
    display: inline-block;
    height: 20px;
    width: 20px;
    margin: 0 5px;
    padding: 0;
    cursor: pointer;
    width: 2px;
    margin: 0 8px;
}

.slick-dots li button {
    border: 0;
    background: transparent;
    display: block;
    height: 20px;
    width: 20px;
    outline: none;
    line-height: 0px;
    font-size: 0px;
    color: transparent;
    padding: 5px;
    cursor: pointer;
    width: 2px;
}

.top__slider .slick-dots li button::before {
    content: "";
    width: 2px;
    height: 20px;
    background: #fff;
    opacity: 1;
}

.slick-dots li button:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "•";
    width: 20px;
    height: 20px;
    font-family: "slick";
    font-size: 6px;
    line-height: 20px;
    text-align: center;
    color: #000;
    opacity: .25;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

.top__slider .slick-prev {
    left: -25px;
    bottom: 0;
    left: 175px;
    top: auto;
    bottom: -50px;
    z-index: 10;
}

.top__slider .slick-next::before {
    content: "";
    display: inline-block;
    width: 15px;
    height: 15px;
    border-right: 2px solid #fff;
    border-top: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 1;
}

.top__slider .slick-prev::before {
    content: "";
    display: inline-block;
    width: 15px;
    height: 15px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    opacity: 1;
}

.top__slider .slider__txt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    display: -ms-flex;
    display: -webkit-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0 25px;
    line-height: 1.57;
    font-size: 1.4rem;
    margin-top: 20px;
    text-align: left;
}

.top__slider .slick-dots li.slick-active button::before {
    background: #006ab7;
}

@media screen and (max-width: 559px) {
    .top__slider .slider__img {
        width: 100%;
    }

    .top__slider {
        width: 70%;
        margin-top: 60px;
    }

    .top__slider img {
        max-width: 100%;
    }

    .top__slider .slider__txt {
        margin-top: 10px;
        line-height: 1.63;
        font-size: 1.1rem;
        padding-left: 0;
        padding-right: 0;
    }

    .top__slider .slider__item a {
        width: 67.69%;
        flex-direction: column;
    }

    .top__slider .slick-dots {
        display: flex;
    }

    .top__slider.slick-dotted {
        margin-bottom: 50px;
        width: 54.92%;
    }

    .top__slider .slick-next {
        left: 60%;
    }

    .top__slider .slick-prev {
        left: 50%;
    }
}

.pickup {
    padding-top: 80px;
    background: #f3f3f3;
    margin-top: 0;
    padding-top: 80px;
    margin-top: -60px;
    padding-bottom: 80px;
}

.contents {
    margin: 0 auto;
    padding-bottom: 80px;
    width: 100%;
    max-width: 1280px;
}

.heading02, .wysiwyg h2 {
    margin-bottom: 25px;
    line-height: 1.6;
    font-size: 2.8rem;
    font-weight: bold;
    text-align: left;
}

.articleBox {
    display: flex;
    width: 100%;
    gap: 40px;
}

.articleBox a{
    display: flex;
    width: 50%;
    max-width: 400px;
    flex-direction: column;
    gap: 20px;
}

.articleBox a img{
    width: 100%;
    height: 220px;
    object-fit: cover;
}

.articleBox a .article__ttl{
    font-size: 1.7rem;
    line-height: 1.5;
    color: #006ab7;
}

@media screen and (max-width:590px) {
    .articleBox{
        flex-direction: column;
    }
    .articleBox a{
        width: 100%;
        max-width: unset;
    }
    .pickup{
        padding-top: 30px;
        padding-bottom: 50px;
    }
}