/*! sanitize.css v5.0.0 | CC0 License | github.com/jonathantneal/sanitize.css */
*,
::after,
::before {
    background-repeat: no-repeat;
    box-sizing: inherit
}

::after,
::before {
    text-decoration: inherit;
    vertical-align: inherit
}

html {
    box-sizing: border-box;
    cursor: default;
    -ms-text-size-adjust: 100%;
    -webkit-text-size-adjust: 100%
}

article,
aside,
footer,
header,
nav,
section {
    display: block
}

body {
    margin: 0
}

h1 {
    font-size: 2em;
    margin: .67em 0
}

figcaption,
figure,
main {
    display: block
}

figure {
    margin: 1em 40px
}

hr {
    box-sizing: content-box;
    height: 0;
    overflow: visible
}

nav ol,
nav ul {
    list-style: none
}

pre {
    font-family: monospace, monospace;
    font-size: 1em
}

a {
    background-color: transparent;
    -webkit-text-decoration-skip: objects
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

b,
strong {
    font-weight: inherit
}

b,
strong {
    font-weight: bolder
}

code,
kbd,
samp {
    font-family: monospace, monospace;
    font-size: 1em
}

dfn {
    font-style: italic
}

mark {
    background-color: #ff0;
    color: #000
}

small {
    font-size: 80%
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

::-moz-selection {
    background-color: #b3d4fc;
    color: #000;
    text-shadow: none
}

::selection {
    background-color: #b3d4fc;
    color: #000;
    text-shadow: none
}

audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle
}

audio,
video {
    display: inline-block
}

audio:not([controls]) {
    display: none;
    height: 0
}

img {
    border-style: none
}

svg {
    fill: currentColor
}

svg:not(:root) {
    overflow: hidden
}

table {
    border-collapse: collapse
}

button,
input,
optgroup,
select,
textarea {
    margin: 0
}

button,
input,
select,
textarea {
    background-color: transparent;
    color: inherit;
    font-size: inherit;
    line-height: inherit
}

button,
input {
    overflow: visible
}

button,
select {
    text-transform: none
}

[type=reset],
[type=submit],
button,
html [type=button] {
    -webkit-appearance: button
}

[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner,
button::-moz-focus-inner {
    border-style: none;
    padding: 0
}

[type=button]:-moz-focusring,
[type=reset]:-moz-focusring,
[type=submit]:-moz-focusring,
button:-moz-focusring {
    outline: 1px dotted ButtonText
}

legend {
    box-sizing: border-box;
    color: inherit;
    display: table;
    max-width: 100%;
    padding: 0;
    white-space: normal
}

progress {
    display: inline-block;
    vertical-align: baseline
}

textarea {
    overflow: auto;
    resize: vertical
}

[type=checkbox],
[type=radio] {
    box-sizing: border-box;
    padding: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-cancel-button,
[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    font: inherit
}

details,
menu {
    display: block
}

summary {
    display: list-item
}

canvas {
    display: inline-block
}

template {
    display: none
}

[tabindex],
a,
area,
button,
input,
label,
select,
summary,
textarea {
    -ms-touch-action: manipulation;
    touch-action: manipulation
}

[hidden] {
    display: none
}

[aria-busy=true] {
    cursor: progress
}

[aria-controls] {
    cursor: pointer
}

[aria-hidden=false][hidden]:not(:focus) {
    clip: rect(0, 0, 0, 0);
    display: inherit;
    position: absolute
}

[aria-disabled] {
    cursor: default
}

body,
button,
input,
select,
textarea {
    font-family: 'Noto Sans JP', sans-serif;
    color: #000
}

a {
    text-decoration: none
}

html {
    font-size: 62.5%
}

h1,
h2,
h3 {
    margin: 0
}

ul {
    margin: 0;
    padding: 0;
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0;
    -webkit-margin-end: 0;
    -webkit-padding-start: 0;
    list-style: none
}

dl {
    margin: 0;
    -webkit-margin-before: 0;
    -webkit-margin-after: 0;
    -webkit-margin-start: 0;
    -webkit-margin-end: 0;
    -webkit-padding-start: 0
}

dl dd {
    margin: 0;
    -webkit-margin-start: 0
}

p {
    margin: 0
}

button {
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: 0;
    padding: 0;
    appearance: none
}

img {
    max-width: 100%
}

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

.slick-list {
    position: relative;
    display: block;
    overflow: hidden;
    margin: 0;
    padding: 0
}

.slick-list:focus {
    outline: 0
}

.slick-list.dragging {
    cursor: pointer;
    cursor: hand
}

.slick-slider .slick-list,
.slick-slider .slick-track {
    -webkit-transform: translate3d(0, 0, 0);
    -moz-transform: translate3d(0, 0, 0);
    -ms-transform: translate3d(0, 0, 0);
    -o-transform: translate3d(0, 0, 0);
    transform: translate3d(0, 0, 0)
}

.slick-track {
    position: relative;
    top: 0;
    left: 0;
    display: block;
    margin-left: auto;
    margin-right: auto
}

.slick-track:after,
.slick-track:before {
    display: table;
    content: ''
}

.slick-track:after {
    clear: both
}

.slick-loading .slick-track {
    visibility: hidden
}

.slick-slide {
    display: none;
    float: left;
    height: 100%;
    min-height: 1px
}

[dir=rtl] .slick-slide {
    float: right
}

.slick-slide img {
    display: block
}

.slick-slide.slick-loading img {
    display: none
}

.slick-slide.dragging img {
    pointer-events: none
}

.slick-initialized .slick-slide {
    display: block
}

.slick-loading .slick-slide {
    visibility: hidden
}

.slick-vertical .slick-slide {
    display: block;
    height: auto;
    border: 1px solid transparent
}

.slick-arrow.slick-hidden {
    display: none
}

@media screen and (max-width:834px) {
    .pc {
        display: none !important
    }
}

@media screen and (min-width:835px),
print {
    .sp {
        display: none !important
    }
}

@media screen and (min-width:835px),
print {
    .header_logo {
        width: 252px
    }
}

@media screen and (max-width:834px) {
    .header_logo {
        width: 257px
    }
}

@media screen and (min-width:835px),
print {
    .nav_txt_about {
        width: 172px
    }
}

@media screen and (max-width:834px) {
    .nav_txt_about {
        width: 129px
    }
}

@media screen and (min-width:835px),
print {
    .nav_txt_about {
        height: 19px
    }
}

@media screen and (max-width:834px) {
    .nav_txt_about {
        height: 15px
    }
}

@media screen and (min-width:835px),
print {

    body,
    html {
        min-width: 1023px
    }
}

body {
    min-width: 320px;
    line-height: 1.8
}

@media screen and (min-width:835px),
print {
    body {
        font-size: 1.4em
    }
}

@media screen and (max-width:834px) {
    body {
        font-size: 1.64em
    }
}

main {
    margin-right: auto;
    margin-left: auto;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    max-width: 1280px
}

main>.contents {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width:835px),
print {
    main>.contents {
        padding-bottom: 80px
    }
}

@media screen and (max-width:834px) {
    main>.contents {
        padding-bottom: 23.4px
    }
}

@media print {
    main>.contents {
        padding-bottom: 63.9px
    }
}

@media screen and (min-width:835px),
print {
    main>.contents .contents-body {
        padding-top: 40px
    }
}

@media screen and (max-width:834px) {
    main>.contents .contents-body {
        padding-top: 23.4px
    }
}

@media print {
    main>.contents .contents-body {
        padding-top: 32px
    }
}

@media screen and (min-width:835px),
print {
    main>.contents .contents-body {
        padding-bottom: 40px
    }
}

@media screen and (max-width:834px) {
    main>.contents .contents-body {
        padding-bottom: 23.4px
    }
}

@media print {
    main>.contents .contents-body {
        padding-bottom: 32px
    }
}

main>.contents .contents-wrap {
    width: 100%
}

@media screen and (min-width:835px),
print {
    main>.contents .contents-wrap {
        padding-left: 40px
    }
}

@media screen and (max-width:834px) {
    main>.contents .contents-wrap {
        padding-left: 3.1vw
    }
}

@media print {
    main>.contents .contents-wrap {
        padding-left: 32px
    }
}

@media screen and (min-width:835px),
print {
    main>.contents .contents-wrap {
        padding-right: 40px
    }
}

@media screen and (max-width:834px) {
    main>.contents .contents-wrap {
        padding-right: 3.1vw
    }
}

@media print {
    main>.contents .contents-wrap {
        padding-right: 32px
    }
}

main>.contents .contents-main {
    margin-right: auto;
    margin-left: auto;
    width: 100%;
    max-width: 1000px
}

@media screen and (min-width:835px),
print {
    main>.contents .contents-main {
        margin-top: 40px
    }
}

@media screen and (max-width:834px) {
    main>.contents .contents-main {
        margin-top: 23.4px
    }
}

@media print {
    main>.contents .contents-main {
        margin-top: 32px
    }
}

main>.contents h2.subpage {
    margin-right: auto;
    margin-left: auto;
    width: 100%;
    max-width: 1280px
}

@media screen and (min-width:835px),
print {
    #wrapper {
        height: auto !important
    }
}

body {
    visibility: hidden;
    opacity: 0
}

body.is-show {
    visibility: visible;
    opacity: 1;
    -webkit-transition: opacity 1s 0s ease;
    -o-transition: opacity 1s 0s ease;
    transition: opacity 1s 0s ease
}

.box-center {
    text-align: center
}

header {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 10001;
    width: 100%;
    height: auto
}

header .header-wrap {
    margin-right: auto;
    margin-left: auto;
    max-width: 1280px
}

header .header-init {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

header .siteinfo {
    position: relative;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: 100%
}

header .siteinfo .siteinfo-wrap {
    position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (min-width:835px),
print {
    header .siteinfo {
        height: 0
    }

    header .siteinfo .siteinfo-wrap {
        height: 0
    }
}

@media screen and (max-width:834px) {
    header .siteinfo {
        background-color: #fff
    }
}

header h1 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    line-height: 1
}

@media screen and (min-width:835px),
print {
    header h1 {
        margin-left: 20px
    }
}

@media screen and (max-width:834px) {
    header h1 {
        margin-left: 3.1vw
    }
}

@media print {
    header h1 {
        margin-left: 16px
    }
}

header h1>a {
    display: block
}

@media screen and (min-width:835px),
print {
    header h1>a:hover {
        opacity: .5;
        -webkit-transition: opacity .2s;
        -o-transition: opacity .2s;
        transition: opacity .2s
    }
}

header h1>a img {
    width: 100%;
    display: block
}

@media screen and (min-width:835px),
print {
    header h1 {
        position: absolute;
        top: 0;
        left: 0;
        width: 310px;
        height: 75px
    }
}

@media screen and (max-width:834px) {
    header h1 {
        width: 234.4px;
        height: 50px
    }
}

header nav {
    margin-left: auto;
    margin-right: auto;
    width: 100%
}

header nav .nav-child,
header nav .nav-parent {
    width: 100%;
    height: auto;
    padding-left: 0
}

header nav .nav-child>li:nth-child(n+2),
header nav .nav-parent>li:nth-child(n+2) {
    border-top: 1px solid #000
}

header nav .nav-child>li.nav-child-trigger>div,
header nav .nav-child>li>a,
header nav .nav-parent>li.nav-child-trigger>div,
header nav .nav-parent>li>a {
    margin: 0;
    display: block;
    color: inherit;
    text-align: left
}

@media screen and (min-width:835px),
print {

    header nav .nav-child>li.nav-child-trigger>div,
    header nav .nav-child>li>a,
    header nav .nav-parent>li.nav-child-trigger>div,
    header nav .nav-parent>li>a {
        font-size: 120%
    }
}

@media screen and (max-width:834px) {

    header nav .nav-child>li.nav-child-trigger>div,
    header nav .nav-child>li>a,
    header nav .nav-parent>li.nav-child-trigger>div,
    header nav .nav-parent>li>a {
        font-size: 100%
    }
}

header nav .nav-child>li>a,
header nav .nav-parent>li>a {
    -webkit-transition: color .2s 0s ease;
    -o-transition: color .2s 0s ease;
    transition: color .2s 0s ease
}

header nav .nav-child>li>a:hover,
header nav .nav-parent>li>a:hover {
    color: #4EC5C0
}

header nav .nav-child>li.nav-child-trigger>div,
header nav .nav-parent>li.nav-child-trigger>div {
    padding-right: 30px;
    padding-left: 30px;
    position: relative
}

header nav .nav-child>li.nav-child-trigger>div::before,
header nav .nav-parent>li.nav-child-trigger>div::before {
    position: absolute;
    right: 5px;
    top: 50%;
    width: 20px;
    height: 20px;
    line-height: 20px;
    text-align: center;
    display: block;
    content: "";
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%)
}

@media screen and (min-width:835px),
print {

    header nav .nav-child>li.sns,
    header nav .nav-parent>li.sns {
        padding-top: 20px
    }
}

@media screen and (max-width:834px) {

    header nav .nav-child>li.sns,
    header nav .nav-parent>li.sns {
        padding-top: 11.7px
    }
}

@media print {

    header nav .nav-child>li.sns,
    header nav .nav-parent>li.sns {
        padding-top: 16px
    }
}

header nav .nav-child>li.sns ul,
header nav .nav-parent>li.sns ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

header nav .nav-child>li.sns ul li,
header nav .nav-parent>li.sns ul li {
    padding-right: 5px;
    padding-left: 5px
}

header nav .nav-child>li.sns ul li a,
header nav .nav-parent>li.sns ul li a {
    display: block
}

@media screen and (min-width:835px),
print {

    header nav .nav-child>li.sns ul li a:hover,
    header nav .nav-parent>li.sns ul li a:hover {
        opacity: .5;
        -webkit-transition: opacity .2s;
        -o-transition: opacity .2s;
        transition: opacity .2s
    }
}

@media screen and (min-width:835px),
print {
    header nav .nav-parent {
        padding-left: 40px
    }
}

@media screen and (max-width:834px) {
    header nav .nav-parent {
        padding-left: 3.1vw
    }
}

@media print {
    header nav .nav-parent {
        padding-left: 32px
    }
}

@media screen and (min-width:835px),
print {
    header nav .nav-parent {
        padding-right: 0
    }
}

@media screen and (max-width:834px) {
    header nav .nav-parent {
        padding-right: 3.1vw
    }
}

@media print {
    header nav .nav-parent {
        padding-right: 0
    }
}

@media screen and (min-width:835px),
print {
    header nav .nav-parent {
        padding-bottom: 80px
    }
}

@media screen and (max-width:834px) {
    header nav .nav-parent {
        padding-bottom: 70.3px
    }
}

@media print {
    header nav .nav-parent {
        padding-bottom: 63.9px
    }
}

header nav .nav-parent>li>a {
    position: relative
}

header nav .nav-parent>li>a::before {
    margin-left: .5em;
    border-radius: 5px;
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 5px;
    height: 5px;
    background-color: #4EC5C0;
    content: ""
}

header nav .nav-parent>li.nav-child-trigger>div::before {
    color: #fff;
    background-color: #aaa
}

header nav .nav-parent>li.nav-child-trigger>div.is-open::before {
    content: '\002212'
}

header nav .nav-parent>li.nav-child-trigger>div.is-close::before {
    content: '\002b'
}

header nav .nav-child {
    display: none;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    background-color: #aaa
}

header nav .nav-child>li:last-child {
    border-bottom: none
}

@media screen and (min-width:835px),
print {

    header nav .nav-child,
    header nav .nav-parent {
        min-height: 100vh
    }

    header nav .nav-child>li.nav-child-trigger>div,
    header nav .nav-child>li>a,
    header nav .nav-parent>li.nav-child-trigger>div,
    header nav .nav-parent>li>a {
        padding: .5em 2.5em .5em 1.5em
    }
}

@media screen and (max-width:834px) {

    header nav .nav-child>li.nav-child-trigger>div,
    header nav .nav-child>li>a,
    header nav .nav-parent>li.nav-child-trigger>div,
    header nav .nav-parent>li>a {
        padding: .25em 1em .25em 1.5em;
    }
}

header button {
    position: fixed;
    top: 0;
    right: 0;
    background-color: #4EC5C0;
    font-size: 1rem
}

header button::before {
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    content: "";
    background: url(../img/common/head_btn_txt.png) 50% 50%/contain no-repeat
}

header button>div {
    display: block;
    width: 100%;
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

header button>div>p {
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -webkit-transition: background .3s 0s ease;
    -o-transition: background .3s 0s ease;
    transition: background .3s 0s ease;
    background: #fff
}

header button>div>p:after,
header button>div>p:before {
    content: "";
    display: block;
    width: 100%;
    height: inherit;
    background: #fff;
    position: absolute;
    -webkit-transition: all .3s 0s ease !important;
    -o-transition: all .3s 0s ease !important;
    transition: all .3s 0s ease !important
}

@media screen and (min-width:835px),
print {
    header button {
        width: 75px;
        height: 75px
    }

    header button::before {
        margin-bottom: 18px;
        width: 26px;
        height: 8px
    }

    header button>div>p {
        margin-top: -6px;
        width: 35%;
        height: 4px
    }
}

@media screen and (max-width:834px) {
    header button {
        width: 50px;
        height: 50px
    }

    header button::before {
        margin-bottom: 12px;
        width: 22px;
        height: 5px
    }

    header button>div>p {
        margin-top: -4px;
        width: 40%;
        height: 3px
    }
}

header nav {
    overflow-y: scroll;
    -webkit-overflow-scrolling: touch;
    over-scrolling: touch;
    -webkit-transform: translateZ(0);
    transform: translateZ(0)
}

header nav {
    right: 0;
    -webkit-transform: translateX(100%);
    -ms-transform: translateX(100%);
    transform: translateX(100%);
    height: 100vh
}

@media screen and (min-width:835px),
print {
    header nav {
        -webkit-transition: -webkit-transform .2s 0s ease;
        transition: -webkit-transform .2s 0s ease;
        -o-transition: transform .2s 0s ease;
        transition: transform .2s 0s ease;
        transition: transform .2s 0s ease, -webkit-transform .2s 0s ease
    }
}

@media screen and (min-width:835px),
print {
    header button>div>p:before {
        -webkit-transform: rotate(0) translateY(9px);
        -ms-transform: rotate(0) translateY(9px);
        transform: rotate(0) translateY(9px)
    }
}

@media screen and (max-width:834px) {
    header button>div>p:before {
        -webkit-transform: rotate(0) translateY(7px);
        -ms-transform: rotate(0) translateY(7px);
        transform: rotate(0) translateY(7px)
    }
}

@media screen and (min-width:835px),
print {
    header button>div>p:after {
        -webkit-transform: rotate(0) translateY(-9px);
        -ms-transform: rotate(0) translateY(-9px);
        transform: rotate(0) translateY(-9px)
    }
}

@media screen and (max-width:834px) {
    header button>div>p:after {
        -webkit-transform: rotate(0) translateY(-7px);
        -ms-transform: rotate(0) translateY(-7px);
        transform: rotate(0) translateY(-7px)
    }
}

header.is-open nav {
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0)
}

header.is-open button>div>p {
    background: 0 0
}

header.is-open button>div>p:before {
    -webkit-transform: rotate(45deg) translateY(0);
    -ms-transform: rotate(45deg) translateY(0);
    transform: rotate(45deg) translateY(0)
}

header.is-open button>div>p:after {
    -webkit-transform: rotate(-45deg) translateY(0);
    -ms-transform: rotate(-45deg) translateY(0);
    transform: rotate(-45deg) translateY(0)
}

body[data-css-header=accordion-all] header nav {
    position: absolute;
    top: 0;
    z-index: -1
}

@media screen and (min-width:835px),
print {
    body[data-css-header=accordion-all] header nav {
        width: auto
    }

    body[data-css-header=accordion-all] header nav .nav-parent {
        background-color: #fff
    }
}

body {
    position: relative
}

body::after {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 10000;
    width: 100%;
    height: 100%;
    opacity: 0;
    visibility: hidden;
    content: "";
    -webkit-transition: all 150ms 0s ease;
    -o-transition: all 150ms 0s ease;
    transition: all 150ms 0s ease
}

body.menu-open::after {
    opacity: .3;
    visibility: visible
}

@media screen and (min-width:835px),
print {
    body::after {
        background: #000
    }

    body.menu-open::after {
        opacity: .3
    }
}

@media screen and (max-width:834px) {
    body::after {
        background: #fff
    }

    body.menu-open::after {
        opacity: 1
    }
}

@media screen and (min-width:835px), print {
  body::before {
    position: fixed;
    top: 0;
    z-index: 9999;
    opacity: 0;
    -webkit-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    transform: translateY(-100%);
    -webkit-transition: opacity .2s, -webkit-transform .2s;
    transition: opacity .2s, -webkit-transform .2s;
    -o-transition: transform .2s, opacity .2s;
    transition: transform .2s, opacity .2s;
    transition: transform .2s, opacity .2s, -webkit-transform .2s;
    width: 100%;
    height: 75px;
    background-color: rgba(255, 255, 255, .8);
    content: ""
  }
  body.is-scroll::before {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0)
  }
}

footer {
  position: relative
}

@media screen and (min-width:835px), print {
  footer {
    margin-top: 40px
  }
}

@media screen and (max-width:834px) {
  footer {
    margin-top: 23.4px
  }
}

@media print {
  footer {
    margin-top: 32px
  }
}

@media screen and (min-width:835px), print {
  footer {
    min-width: 1023px
  }
}

@media screen and (min-width:835px), print {
  footer .footer-wrap {
    padding-top: 40px
  }
}

@media screen and (max-width:834px) {
  footer .footer-wrap {
    padding-top: 23.4px
  }
}

@media print {
  footer .footer-wrap {
    padding-top: 32px
  }
}

footer .footer-init {
  margin-right: auto;
  margin-left: auto;
  max-width: 1360px
}

@media screen and (min-width:835px), print {
  footer .footer-init {
    padding-left: 40px
  }
}

@media screen and (max-width:834px) {
  footer .footer-init {
    padding-left: 3.1vw
  }
}

@media print {
  footer .footer-init {
    padding-left: 32px
  }
}

@media screen and (min-width:835px), print {
  footer .footer-init {
    padding-right: 40px
  }
}

@media screen and (max-width:834px) {
  footer .footer-init {
    padding-right: 3.1vw
  }
}

@media print {
  footer .footer-init {
    padding-right: 32px
  }
}

@media screen and (min-width:835px), print {
  footer .info {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
}

footer .info h1 {
  line-height: 1
}

@media screen and (min-width:835px), print {
  footer .info h1 {
    padding-right: 40px
  }
}

@media screen and (max-width:834px) {
  footer .info h1 {
    padding-right: 0
  }
}

@media print {
  footer .info h1 {
    padding-right: 32px
  }
}

@media screen and (min-width:835px), print {
  footer .info h1>a:hover {
    opacity: .5;
    -webkit-transition: opacity .2s;
    -o-transition: opacity .2s;
    transition: opacity .2s
  }
}

footer .info h1>a img {
  display: block
}

@media screen and (min-width:835px), print {
  footer .info h1>a {
    display: block
  }
  footer .info h1>a img {
    width: 280px
  }
}

@media screen and (max-width:834px) {
  footer .info h1 {
    text-align: center
  }
  footer .info h1>a {
    display: inline-block
  }
  footer .info h1>a img {
    width: 164.1px
  }
}

footer .info dl {
  line-height: 1.4
}

@media screen and (min-width:835px), print {
  footer .info dl {
    margin-top: 0
  }
}

@media screen and (max-width:834px) {
  footer .info dl {
    margin-top: 11.7px
  }
}

@media print {
  footer .info dl {
    margin-top: 0
  }
}

footer .info dl dt {
  margin-left: auto;
  margin-right: auto;
  display: table
}

footer .info dl dt>div {
  padding: 0 1em;
  border-left: 1px solid #000;
  display: table-cell;
  vertical-align: middle
}

@media screen and (min-width:835px), print {
  footer .info dl dt>div.ttl {
    font-size: 10px
  }
}

@media screen and (max-width:834px) {
  footer .info dl dt>div.ttl {
    font-size: 80.62%
  }
}

@media screen and (min-width:835px), print {
  footer .info dl dt>div.txt {
    font-size: 55%
  }
}

@media screen and (max-width:834px) {
  footer .info dl dt>div.txt {
    font-size: 64.5%
  }
}

footer .info dl dd {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

@media screen and (min-width:835px), print {
  footer .info dl dd {
    margin-top: 0
  }
}

@media screen and (max-width:834px) {
  footer .info dl dd {
    margin-top: 5.9px
  }
}

@media print {
  footer .info dl dd {
    margin-top: 0
  }
}

footer .info dl dd>p {
  display: inline-block
}

@media screen and (min-width:835px), print {
  footer .info dl dd>p {
    font-size: 122.5%
  }
}

@media screen and (max-width:834px) {
  footer .info dl dd>p {
    font-size: 137%
  }
}

footer .info dl dd>a {
  color: inherit;
  display: inline-block
}

@media screen and (min-width:835px), print {
  footer .info dl dd>a {
    font-size: 175%
  }
}

@media screen and (max-width:834px) {
  footer .info dl dd>a {
    font-size: 190.3%
  }
}

@media screen and (min-width:835px), print {
  footer .info dl dd>a {
    color: inherit;
    pointer-events: none
  }
}

@media screen and (max-width:834px) {
  footer .info dl dt>div:last-child {
    border-right: 1px solid #000
  }
}

@media screen and (min-width:835px), print {
  footer nav {
    margin-top: 20px
  }
}

@media screen and (max-width:834px) {
  footer nav {
    margin-top: 11.7px
  }
}

@media print {
  footer nav {
    margin-top: 16px
  }
}

footer nav ul {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap
}

@media screen and (min-width:835px), print {
  footer nav ul {
    margin-bottom: -8px
  }
}

@media screen and (max-width:834px) {
  footer nav ul {
    margin-bottom: -9.4px
  }
}

@media print {
  footer nav ul {
    margin-bottom: -6.4px
  }
}

@media screen and (min-width:835px), print {
  footer nav ul {
    margin-right: -4px
  }
}

@media screen and (max-width:834px) {
  footer nav ul {
    margin-right: -1.3vw
  }
}

@media print {
  footer nav ul {
    margin-right: -3.2px
  }
}

@media screen and (min-width:835px), print {
  footer nav ul {
    margin-left: -4px
  }
}

@media screen and (max-width:834px) {
  footer nav ul {
    margin-left: -1.3vw
  }
}

@media print {
  footer nav ul {
    margin-left: -3.2px
  }
}

@media screen and (min-width:835px), print {
  footer nav ul:nth-child(n+2) {
    margin-left: 4px
  }
}

@media screen and (max-width:834px) {
  footer nav ul:nth-child(n+2) {
    margin-left: -1.3vw
  }
}

@media print {
  footer nav ul:nth-child(n+2) {
    margin-left: 3.2px
  }
}

@media screen and (min-width:835px), print {
  footer nav ul:nth-child(n+2) {
    margin-top: 0
  }
}

@media screen and (max-width:834px) {
  footer nav ul:nth-child(n+2) {
    margin-top: 11.7px
  }
}

@media print {
  footer nav ul:nth-child(n+2) {
    margin-top: 0
  }
}

@media screen and (min-width:835px), print {
  footer nav ul li {
    padding-bottom: 8px
  }
}

@media screen and (max-width:834px) {
  footer nav ul li {
    padding-bottom: 9.4px
  }
}

@media print {
  footer nav ul li {
    padding-bottom: 6.4px
  }
}

@media screen and (min-width:835px), print {
  footer nav ul li {
    padding-right: 4px
  }
}

@media screen and (max-width:834px) {
  footer nav ul li {
    padding-right: 1.3vw
  }
}

@media print {
  footer nav ul li {
    padding-right: 3.2px
  }
}

@media screen and (min-width:835px), print {
  footer nav ul li {
    padding-left: 4px
  }
}

@media screen and (max-width:834px) {
  footer nav ul li {
    padding-left: 1.3vw
  }
}

@media print {
  footer nav ul li {
    padding-left: 3.2px
  }
}

footer nav ul li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}

@media screen and (min-width:835px), print {
  footer nav ul li a:hover {
    opacity: .5;
    -webkit-transition: opacity .2s;
    -o-transition: opacity .2s;
    transition: opacity .2s
  }
}

footer nav ul.sns li a {
  height: 100%
}

footer nav ul.sns li a img {
  width: auto;
  height: 100%
}

footer nav ul.txt li a {
  padding: .5em;
  min-width: 150px;
  height: 100%;
  border-radius: 4px;
  color: #fff;
  background-color: #4EC5C0
}

footer nav ul.txt li a p {
  line-height: 1
}

@media screen and (min-width:835px), print {
  footer nav ul.txt li a p {
    font-size: 105%
  }
}

@media screen and (max-width:834px) {
  footer nav ul.txt li a p {
    font-size: 64.5%
  }
}

@media screen and (min-width:835px), print {
  footer nav {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
  }
}

@media screen and (max-width:834px) {
  footer nav ul.txt {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
  }
}

footer .copyright {
  padding: 1em;
  border-top: 1px solid #4EC5C0;
  text-align: center;
  color: #4EC5C0
}

@media screen and (min-width:835px), print {
  footer .copyright {
    margin-top: 40px
  }
}

@media screen and (max-width:834px) {
  footer .copyright {
    margin-top: 23.4px
  }
}

@media print {
  footer .copyright {
    margin-top: 32px
  }
}

@media screen and (min-width:835px), print {
  footer .copyright {
    font-size: 55%
  }
}

@media screen and (max-width:834px) {
  footer .copyright {
    font-size: 55%
  }
}

footer a#btnPagetop {
  position: fixed;
  right: 10px;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  -webkit-transition: opacity .3s ease, visibility .3s ease;
  -o-transition: opacity .3s ease, visibility .3s ease;
  transition: opacity .3s ease, visibility .3s ease;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #fff;
  background-color: #4EC5C0;
  font-size: 1rem
}

footer a#btnPagetop.is-clarity {
  opacity: 1;
  visibility: visible
}

@media screen and (min-width:835px), print {
  footer a#btnPagetop {
    bottom: 50px;
    width: 50px;
    height: 50px
  }
}

@media screen and (max-width:834px) {
  footer a#btnPagetop {
    bottom: 10px;
    width: 50px;
    height: 50px
  }
  footer a#btnPagetop.is-nofix {
    margin-top: -10px;
    position: absolute;
    top: 0;
    bottom: auto;
    -webkit-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    transform: translateY(-100%);
    position: absolute;
    background-color: #000
  }
}


#sidenav {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 10000;
    width: 100%;
    height: 0
}

@media screen and (min-width:835px),
print {
    #sidenav {
        margin-top: 120px
    }
}

@media screen and (max-width:834px) {
    #sidenav {
        margin-top: 70.3px
    }
}

@media print {
    #sidenav {
        margin-top: 95.9px
    }
}

@media screen and (max-width:834px) {
    #sidenav {
        display: none
    }
}

#sidenav nav {
    position: absolute;
    top: 0;
    right: 0
}

#sidenav ul li {
    text-align: right
}

#sidenav ul li .list-wrap {
    padding: 1em;
    border-top: 1px solid #4EC5C0;
    border-left: 1px solid #4EC5C0;
    border-bottom: 1px solid #4EC5C0;
    border-radius: 5px 0 0 5px;
    position: relative;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    min-width: 40px;
    background-color: #4EC5C0;
    -webkit-box-shadow: 4px 6px 8px 2px rgba(0, 0, 0, .25);
    box-shadow: 4px 6px 8px 2px rgba(0, 0, 0, .25)
}

#sidenav ul li .list-wrap::after,
#sidenav ul li .list-wrap::before {
    position: absolute;
    right: 0;
    width: 40px;
    background-position: 50% 50%;
    background-repeat: no-repeat;
    background-size: 100% 100%;
    content: ""
}

#sidenav ul li .list-wrap::before {
    height: 6px;
    top: 0;
    -webkit-transform: translateY(-100%);
    -ms-transform: translateY(-100%);
    transform: translateY(-100%);
    background-image: url(../img/common/side_nav_deco1.png)
}

#sidenav ul li .list-wrap::after {
    height: 23px;
    bottom: 0;
    -webkit-transform: translateY(100%);
    -ms-transform: translateY(100%);
    transform: translateY(100%);
    background-image: url(../img/common/side_nav_deco2.png)
}

#sidenav ul li .list-wrap .list-before {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    width: auto;
    visibility: visible;
    color: #fff
}

#sidenav ul li .list-wrap .list-before p {
    display: inline-block;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    white-space: nowrap;
    line-height: 1
}

@media screen and (min-width:835px),
print {
    #sidenav ul li .list-wrap .list-before p {
        font-size: 110%
    }
}

@media screen and (max-width:834px) {
    #sidenav ul li .list-wrap .list-before p {
        font-size: 110%
    }
}

#sidenav ul li .list-wrap .list-after {
    display: inline-block;
    width: 0;
    visibility: hidden;
    color: #000
}

#sidenav ul li .list-wrap .list-after .list-after-wrap {
    white-space: nowrap
}

#sidenav ul li .list-wrap.is-open .list-before {
    width: 0;
    visibility: hidden
}

#sidenav ul li .list-wrap.is-open .list-after {
    width: auto;
    visibility: visible
}

#sidenav ul li .list-wrap.is-open.open-pad-0 {
    padding: 0;
}

#sidenav ul li .list-wrap.is-passive a {
    pointer-events: none
}

@media screen and (min-width:835px),
print {
    #sidenav ul li:nth-child(n+2) {
        margin-top: 40px
    }
}

#sidenav .list-after-wrap.opencampus {
    line-height: 1
}

#sidenav .list-after-wrap.opencampus dl dt {
    color: #fff;
    letter-spacing: .1em;
    font-family: Montserrat, 'Noto Sans JP', sans-serif
}

@media screen and (min-width:835px),
print {
    #sidenav .list-after-wrap.opencampus dl dt {
        font-size: 125%
    }
}

@media screen and (max-width:834px) {
    #sidenav .list-after-wrap.opencampus dl dt {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    #sidenav .list-after-wrap.opencampus dl dd {
        margin-top: 8px
    }
}

@media screen and (max-width:834px) {
    #sidenav .list-after-wrap.opencampus dl dd {
        margin-top: 4.7px
    }
}

@media print {
    #sidenav .list-after-wrap.opencampus dl dd {
        margin-top: 6.4px
    }
}

@media screen and (min-width:835px),
print {
    #sidenav .list-after-wrap.opencampus dl dd>:nth-child(n+2) {
        margin-top: 4px;
        font-size: 85%
    }
}

@media screen and (max-width:834px) {
    #sidenav .list-after-wrap.opencampus dl dd>:nth-child(n+2) {
        margin-top: 2.3px
    }
}

@media print {
    #sidenav .list-after-wrap.opencampus dl dd>:nth-child(n+2) {
        margin-top: 3.2px
    }
}

#sidenav .list-after-wrap.opencampus .text {
    text-align: center;
    font-weight: 700
}

@media screen and (min-width:835px),
print {
    #sidenav .list-after-wrap.opencampus .text {
        font-size: 100%
    }
}

@media screen and (max-width:834px) {
    #sidenav .list-after-wrap.opencampus .text {
        font-size: 100%
    }
}

#sidenav .list-after-wrap.opencampus .date {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end;
    color: white;
    letter-spacing: .1em;
    font-family: Montserrat, 'Noto Sans JP', sans-serif
}

#sidenav .list-after-wrap.opencampus .date p:nth-child(1) {
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width:835px),
print {
    #sidenav .list-after-wrap.opencampus .date p:nth-child(1) {
        font-size: 313%
    }
}

@media screen and (max-width:834px) {
    #sidenav .list-after-wrap.opencampus .date p:nth-child(1) {
        font-size: 100%
    }
}

#sidenav .list-after-wrap.opencampus .date p:nth-child(1) span {
    margin-right: .1em;
    margin-left: .1em;
    font-size: 65%
}

#sidenav .list-after-wrap.opencampus .date p:nth-child(2) {
    padding-left: .1em;
    padding-bottom: .15em;
    display: inline-block
}

@media screen and (min-width:835px),
print {
    #sidenav .list-after-wrap.opencampus .date p:nth-child(2) {
        font-size: 169%
    }
}

@media screen and (max-width:834px) {
    #sidenav .list-after-wrap.opencampus .date p:nth-child(2) {
        font-size: 100%
    }
}

#sidenav .list-after-wrap.opencampus .here {
    position: relative;
    padding: .5em;
    text-align: center;
    color: #4EC5C0;
    background-color: #fff
}

#sidenav .list-after-wrap.opencampus .here::after {
    margin-right: .5em;
    position: absolute;
    top: 50%;
    right: 0;
    width: .75em;
    height: .75em;
    border-top: 1px solid #4EC5C0;
    border-right: 1px solid #4EC5C0;
    -webkit-transform: rotate(45deg) translateY(-50%);
    -ms-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    -webkit-transform-origin: top;
    -ms-transform-origin: top;
    transform-origin: top;
    content: ""
}

main#home section h3 {
    text-align: center;
    font-weight: 700;
    line-height: 1.4;
    letter-spacing: .1em;
    font-family: Montserrat, 'Noto Sans JP', sans-serif
}

main#home section h3 span {
    font-weight: 300;
    font-family: 'Noto Sans JP', sans-serif
}

main#home .css-btn {
    padding: .5em 1em;
    border: 2px solid #000;
    border-radius: 24px;
    display: -webkit-inline-box;
    display: -ms-inline-flexbox;
    display: inline-flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: #fff;
    color: #000;
    font-weight: 700;
    min-width: 160px;
    min-height: 48px;
    -webkit-transition: background-color .2s 0s ease;
    -o-transition: background-color .2s 0s ease;
    transition: background-color .2s 0s ease
}

main#home .css-btn p {
    display: inline-block;
    line-height: 1
}

main#home .css-btn::after {
    margin-left: .5em;
    display: inline-block;
    width: 14px;
    height: 14px;
    background: url(../img/common/icon_w_arrow_bk.svg) 50% 50%/contain no-repeat;
    content: ""
}

main#home .css-btn:hover {
    background-color: #e3e3e3
}

main#home .slide .contents-wrap {
    padding-left: 0;
    padding-right: 0
}

main#home .slide [data-js-slide] {
    position: relative
}

main#home .slide .slide-init>* {
    display: block
}

main#home .slide .slide-init>* img {
    display: block;
    width: 100%
}

main#home .slide .slide-init>a {
    overflow: hidden
}

main#home .slide .slide-init>a img {
    -webkit-transition: opacity .3s ease;
    -o-transition: opacity .3s ease;
    transition: opacity .3s ease
}

main#home .slide .slide-init>a:hover img {
    opacity: .7
}

main#home .slide button.slick-arrow {
    position: absolute;
    top: 50%;
    z-index: 1;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
    background-color: #fff
}

main#home .slide button.slick-arrow.slick-prev {
    left: 0
}

main#home .slide button.slick-arrow.slick-next {
    right: 0
}

main#home .slide ul.slick-dots {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: absolute;
    left: 0;
    bottom: 0
}

main#home .slide ul.slick-dots li {
    padding: 5px
}

main#home .slide ul.slick-dots li button {
    text-indent: 1000%;
    white-space: nowrap;
    overflow: hidden;
    width: 10px;
    height: 10px;
    background-color: #949494
}

main#home .slide ul.slick-dots li.slick-active button {
    background-color: #fff
}

@media screen and (min-width:835px),
print {
    main#home section#news {
        margin-top: 30px
    }
}

@media screen and (max-width:834px) {
    main#home section#news {
        margin-top: 17.6px
    }
}

@media print {
    main#home section#news {
        margin-top: 24px
    }
}

main#home section#news .contents-body {
    background: url(../img/page/home/common_bg_circle.jpg) 50% 50%/60px auto repeat
}

main#home section#message .contents-body {
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (min-width:835px),
print {
    main#home section#message .contents-body {
        min-height: 820px;
        background-image: url(../img/page/home/message_bg_pc.jpg)
    }
}

@media screen and (max-width:834px) {
    main#home section#message .contents-body {
        min-height: 480.5px;
        background-image: url(../img/page/home/message_bg_sp.jpg);
        background-color: #fee
    }
}

main#home section#nurse .contents-body {
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (min-width:835px),
print {
    main#home section#nurse .contents-body {
        min-height: 240px;
        background-image: url(../img/page/home/nurse_bg_pc.jpg)
    }
}

@media screen and (max-width:834px) {
    main#home section#nurse .contents-body {
        min-height: 140.6px;
        background-image: url(../img/page/home/nurse_bg_sp.jpg);
        background-color: #fee
    }
}

main#home section#nurse .contents-main {
    margin-top: 0
}

main#home section#nurse h3 {
    color: #fff;
    font-size: 100%
}

main#home section#nurse h3 .en {
    font-family: 'Noto Sans JP', sans-serif
}

@media screen and (min-width:835px),
print {
    main#home section#nurse h3 .ja {
        font-size: 300%
    }
}

@media screen and (max-width:834px) {
    main#home section#nurse h3 .ja {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#nurse .box-center {
        margin-top: 20px
    }
}

@media screen and (max-width:834px) {
    main#home section#nurse .box-center {
        margin-top: 11.7px
    }
}

@media print {
    main#home section#nurse .box-center {
        margin-top: 16px
    }
}

main#home section#nurse .box-center .css-btn {
    border: none
}

@media screen and (min-width:835px),
print {
    main#home section#study {
        margin-top: 20px
    }
}

@media screen and (max-width:834px) {
    main#home section#study {
        margin-top: 11.7px
    }
}

@media print {
    main#home section#study {
        margin-top: 16px
    }
}

main#home section#study .contents-body {
    background-position: 50% 50%;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (min-width:835px),
print {
    main#home section#study .contents-body {
        min-height: 850px;
        background-image: url(../img/page/home/study_bg_pc.jpg)
    }
}

@media screen and (max-width:834px) {
    main#home section#study .contents-body {
        min-height: 498px;
        background-image: url(../img/page/home/study_bg_sp.jpg);
        background-color: #fee
    }
}

main#home section#facility .contents-body {
    position: relative;
    background-position: 50% 0;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (min-width:835px),
print {
    main#home section#facility .contents-body {
        padding-top: 80px
    }
}

@media screen and (max-width:834px) {
    main#home section#facility .contents-body {
        padding-top: 46.9px
    }
}

@media print {
    main#home section#facility .contents-body {
        padding-top: 63.9px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#facility .contents-body {
        min-height: 240px;
        background-image: url(../img/page/home/facility_bg_pc.jpg)
    }
}

@media screen and (max-width:834px) {
    main#home section#facility .contents-body {
        min-height: 140.6px;
        background-image: url(../img/page/home/facility_bg_sp.jpg);
        background-color: #fee
    }
}

main#home section#facility .contents-main {
    margin-top: 0
}

main#home section#facility h3 {
    color: #fff;
    font-size: 100%
}

main#home section#facility h3 .en {
    line-height: 1
}

@media screen and (min-width:835px),
print {
    main#home section#facility h3 .en {
        font-size: 250%
    }
}

@media screen and (max-width:834px) {
    main#home section#facility h3 .en {
        font-size: 100%
    }
}

main#home section#facility h3 .ja {
    font-family: 'Noto Sans JP', sans-serif
}

@media screen and (min-width:835px),
print {
    main#home section#facility h3 .ja {
        margin-top: 5px
    }
}

@media screen and (max-width:834px) {
    main#home section#facility h3 .ja {
        margin-top: 2.9px
    }
}

@media print {
    main#home section#facility h3 .ja {
        margin-top: 4px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#facility h3 .ja {
        font-size: 110%
    }
}

@media screen and (max-width:834px) {
    main#home section#facility h3 .ja {
        font-size: 100%
    }
}

main#home section#facility .text {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    white-space: nowrap;
    color: #fff;
    line-height: 2.5em
}

@media screen and (min-width:835px),
print {
    main#home section#facility .text {
        margin-top: -10px
    }
}

@media screen and (max-width:834px) {
    main#home section#facility .text {
        margin-top: -5.9px
    }
}

@media print {
    main#home section#facility .text {
        margin-top: -8px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#facility .text {
        margin-left: 220px
    }
}

@media screen and (max-width:834px) {
    main#home section#facility .text {
        margin-left: 34.4vw
    }
}

@media print {
    main#home section#facility .text {
        margin-left: 175.8px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#facility .text {
        font-size: 130%
    }
}

@media screen and (max-width:834px) {
    main#home section#facility .text {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#facility .box-center {
        margin-top: 20px
    }
}

@media screen and (max-width:834px) {
    main#home section#facility .box-center {
        margin-top: 11.7px
    }
}

@media print {
    main#home section#facility .box-center {
        margin-top: 16px
    }
}

main#home section#facility .box-center .css-btn {
    border: none
}

main#home section#future .contents-body {
    position: relative;
    background-position: 50% 0;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (min-width:835px),
print {
    main#home section#future .contents-body {
        padding-top: 80px
    }
}

@media screen and (max-width:834px) {
    main#home section#future .contents-body {
        padding-top: 46.9px
    }
}

@media print {
    main#home section#future .contents-body {
        padding-top: 63.9px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#future .contents-body {
        min-height: 720px;
        background-image: url(../img/page/home/future_bg_pc.jpg)
    }
}

@media screen and (max-width:834px) {
    main#home section#future .contents-body {
        min-height: 421.9px;
        background-image: url(../img/page/home/future_bg_sp.jpg);
        background-color: #fee
    }
}

main#home section#future .primary .catch {
    font-weight: 700
}

@media screen and (min-width:835px),
print {
    main#home section#future .primary .catch {
        font-size: 180%
    }
}

@media screen and (max-width:834px) {
    main#home section#future .primary .catch {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#future .primary .desc {
        margin-top: 30px
    }
}

@media screen and (max-width:834px) {
    main#home section#future .primary .desc {
        margin-top: 17.6px
    }
}

@media print {
    main#home section#future .primary .desc {
        margin-top: 24px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#future .primary .box-center {
        margin-top: 30px
    }
}

@media screen and (max-width:834px) {
    main#home section#future .primary .box-center {
        margin-top: 17.6px
    }
}

@media print {
    main#home section#future .primary .box-center {
        margin-top: 24px
    }
}

main#home section#future .primary .box-center .css-btn {
    width: 100%
}

@media screen and (min-width:835px),
print {
    main#home section#future .primary {
        padding-left: 150px
    }

    main#home section#future .primary .primary-wrap {
        margin-left: 0;
        margin-right: auto;
        max-width: 260px
    }
}

main#home section#special .contents-body {
    background: url(../img/page/home/common_bg_circle.jpg) 50% 50%/60px auto repeat
}

main#home section#special ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (min-width:835px),
print {
    main#home section#special ul {
        margin-bottom: -30px
    }
}

@media screen and (max-width:834px) {
    main#home section#special ul {
        margin-bottom: -17.6px
    }
}

@media print {
    main#home section#special ul {
        margin-bottom: -24px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#special ul {
        margin-left: -15px
    }
}

@media screen and (max-width:834px) {
    main#home section#special ul {
        margin-left: -2.3vw
    }
}

@media print {
    main#home section#special ul {
        margin-left: -12px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#special ul {
        margin-right: -15px
    }
}

@media screen and (max-width:834px) {
    main#home section#special ul {
        margin-right: -2.3vw
    }
}

@media print {
    main#home section#special ul {
        margin-right: -12px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#special ul li {
        padding-bottom: 30px
    }
}

@media screen and (max-width:834px) {
    main#home section#special ul li {
        padding-bottom: 17.6px
    }
}

@media print {
    main#home section#special ul li {
        padding-bottom: 24px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#special ul li {
        padding-left: 15px
    }
}

@media screen and (max-width:834px) {
    main#home section#special ul li {
        padding-left: 2.3vw
    }
}

@media print {
    main#home section#special ul li {
        padding-left: 12px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#special ul li {
        padding-right: 15px
    }
}

@media screen and (max-width:834px) {
    main#home section#special ul li {
        padding-right: 2.3vw
    }
}

@media print {
    main#home section#special ul li {
        padding-right: 12px
    }
}

main#home section#special ul li a {
    border: 3px solid #fff;
    display: block;
    background-color: #fff
}

main#home section#special ul li a img {
    display: block
}

@media screen and (min-width:835px),
print {
    main#home section#special ul li a img:hover {
        opacity: .5;
        -webkit-transition: opacity .2s;
        -o-transition: opacity .2s;
        transition: opacity .2s
    }
}

@media screen and (min-width:835px),
print {
    main#home section#special ul li {
        width: 50%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#area {
        margin-top: 70px
    }
}

@media screen and (max-width:834px) {
    main#home section#area {
        margin-top: 41px
    }
}

@media print {
    main#home section#area {
        margin-top: 55.9px
    }
}

main#home section#area .contents-body {
    position: relative;
    background-position: 50% 0;
    background-size: cover;
    background-repeat: no-repeat
}

@media screen and (min-width:835px),
print {
    main#home section#area .contents-body {
        padding-top: 50px
    }
}

@media screen and (max-width:834px) {
    main#home section#area .contents-body {
        padding-top: 29.3px
    }
}

@media print {
    main#home section#area .contents-body {
        padding-top: 40px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#area .contents-body {
        padding-bottom: 60px
    }
}

@media screen and (max-width:834px) {
    main#home section#area .contents-body {
        padding-bottom: 35.2px
    }
}

@media print {
    main#home section#area .contents-body {
        padding-bottom: 48px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#area .contents-body {
        min-height: 330px;
        background-image: url(../img/page/home/area_bg_pc.jpg)
    }
}

@media screen and (max-width:834px) {
    main#home section#area .contents-body {
        min-height: 193.4px;
        background-image: url(../img/page/home/area_bg_sp.jpg);
        background-color: #fee
    }
}

main#home section#area h3 {
    position: relative;
    font-size: 100%
}

main#home section#area h3::before {
    border: 12px solid #fff;
    border-radius: 45px;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 0;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    display: block;
    width: 90px;
    height: 90px;
    content: ""
}

main#home section#area h3>* {
    position: relative;
    z-index: 1
}

main#home section#area h3 .en {
    line-height: 1
}

@media screen and (min-width:835px),
print {
    main#home section#area h3 .en {
        font-size: 250%
    }
}

@media screen and (max-width:834px) {
    main#home section#area h3 .en {
        font-size: 100%
    }
}

main#home section#area h3 .ja {
    font-family: 'Noto Sans JP', sans-serif
}

@media screen and (min-width:835px),
print {
    main#home section#area h3 .ja {
        margin-top: 5px
    }
}

@media screen and (max-width:834px) {
    main#home section#area h3 .ja {
        margin-top: 2.9px
    }
}

@media print {
    main#home section#area h3 .ja {
        margin-top: 4px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#area h3 .ja {
        font-size: 110%
    }
}

@media screen and (max-width:834px) {
    main#home section#area h3 .ja {
        font-size: 100%
    }
}

main#home section#area .text {
    text-align: center;
    font-weight: 700
}

@media screen and (min-width:835px),
print {
    main#home section#area .text {
        font-size: 180%
    }
}

@media screen and (max-width:834px) {
    main#home section#area .text {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#area .box-center {
        margin-top: 20px
    }
}

@media screen and (max-width:834px) {
    main#home section#area .box-center {
        margin-top: 11.7px
    }
}

@media print {
    main#home section#area .box-center {
        margin-top: 16px
    }
}

main#home section#area .box-center .css-btn {
    border: none
}

@media screen and (min-width:835px),
print {
    main#home section#access {
        margin-top: 70px
    }
}

@media screen and (max-width:834px) {
    main#home section#access {
        margin-top: 41px
    }
}

@media print {
    main#home section#access {
        margin-top: 55.9px
    }
}

main#home section#access h3 {
    position: relative;
    font-size: 100%
}

main#home section#access h3::before {
    border: 12px solid #d8ebf2;
    border-radius: 45px;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 0;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    display: block;
    width: 90px;
    height: 90px;
    content: ""
}

main#home section#access h3>* {
    position: relative;
    z-index: 1
}

main#home section#access h3 .en {
    line-height: 1
}

@media screen and (min-width:835px),
print {
    main#home section#access h3 .en {
        font-size: 250%
    }
}

@media screen and (max-width:834px) {
    main#home section#access h3 .en {
        font-size: 100%
    }
}

main#home section#access h3 .ja {
    font-family: 'Noto Sans JP', sans-serif
}

@media screen and (min-width:835px),
print {
    main#home section#access h3 .ja {
        margin-top: 5px
    }
}

@media screen and (max-width:834px) {
    main#home section#access h3 .ja {
        margin-top: 2.9px
    }
}

@media print {
    main#home section#access h3 .ja {
        margin-top: 4px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access h3 .ja {
        font-size: 110%
    }
}

@media screen and (max-width:834px) {
    main#home section#access h3 .ja {
        font-size: 100%
    }
}

main#home section#access .primary .primary-wrap:nth-child(1) .catch {
    font-weight: 700;
    line-height: 1.5
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) .catch {
        margin-top: 60px
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) .catch {
        margin-top: 35.2px
    }
}

@media print {
    main#home section#access .primary .primary-wrap:nth-child(1) .catch {
        margin-top: 48px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) .catch {
        font-size: 200%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) .catch {
        font-size: 100%
    }
}

main#home section#access .primary .primary-wrap:nth-child(1) .map {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) .map {
        margin-top: 30px
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) .map {
        margin-top: 17.6px
    }
}

@media print {
    main#home section#access .primary .primary-wrap:nth-child(1) .map {
        margin-top: 24px
    }
}

main#home section#access .primary .primary-wrap:nth-child(1) .map .img {
    width: 210px
}

main#home section#access .primary .primary-wrap:nth-child(1) .map .txt {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) .map .txt {
        padding-left: 20px
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) .map .txt {
        padding-left: 3.1vw
    }
}

@media print {
    main#home section#access .primary .primary-wrap:nth-child(1) .map .txt {
        padding-left: 16px
    }
}

main#home section#access .primary .primary-wrap:nth-child(1) dl {
    line-height: 1.4
}

main#home section#access .primary .primary-wrap:nth-child(1) dl dt {
    text-align: left;
    font-weight: 700
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) dl dt {
        font-size: 140%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) dl dt {
        font-size: 100%
    }
}

main#home section#access .primary .primary-wrap:nth-child(1) dl dt div {
    padding-right: 1em;
    padding-top: .25em;
    padding-bottom: .25em;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
    display: inline-block
}

main#home section#access .primary .primary-wrap:nth-child(1) dl dd div:nth-child(1) {
    padding-top: .5em
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) dl dd div:nth-child(1) {
        font-size: 85%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) dl dd div:nth-child(1) {
        font-size: 100%
    }
}

main#home section#access .primary .primary-wrap:nth-child(1) dl dd div:nth-child(2) {
    padding-top: .5em
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary .primary-wrap:nth-child(1) dl dd div:nth-child(2) {
        font-size: 70%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .primary .primary-wrap:nth-child(1) dl dd div:nth-child(2) {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access .primary {
        margin-right: auto;
        margin-left: auto;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        max-width: 860px
    }

    main#home section#access .primary .primary-wrap:nth-child(1) {
        -webkit-box-flex: 1;
        -ms-flex-positive: 1;
        flex-grow: 1
    }

    main#home section#access .primary .primary-wrap:nth-child(2) {
        width: 450px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary {
        margin-top: 30px
    }
}

@media screen and (max-width:834px) {
    main#home section#access .secondary {
        margin-top: 17.6px
    }
}

@media print {
    main#home section#access .secondary {
        margin-top: 24px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary .secondary-wrap dl:nth-child(odd) {
        padding-right: 10px
    }
}

@media screen and (max-width:834px) {
    main#home section#access .secondary .secondary-wrap dl:nth-child(odd) {
        padding-right: 1.6vw
    }
}

@media print {
    main#home section#access .secondary .secondary-wrap dl:nth-child(odd) {
        padding-right: 8px
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary .secondary-wrap dl:nth-child(even) {
        padding-left: 10px
    }
}

@media screen and (max-width:834px) {
    main#home section#access .secondary .secondary-wrap dl:nth-child(even) {
        padding-left: 1.6vw
    }
}

@media print {
    main#home section#access .secondary .secondary-wrap dl:nth-child(even) {
        padding-left: 8px
    }
}

main#home section#access .secondary .secondary-wrap dl dt {
    padding: .5em .75em;
    border: 2px solid #e00012;
    text-align: center;
    line-height: 1.3;
    white-space: nowrap;
    font-weight: 700
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary .secondary-wrap dl dt {
        font-size: 108%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .secondary .secondary-wrap dl dt {
        font-size: 100%
    }
}

main#home section#access .secondary .secondary-wrap dl dt sup {
    margin-right: -1em;
    display: inline-block;
    -webkit-transform: translate(-.25em, -1em);
    -ms-transform: translate(-.25em, -1em);
    transform: translate(-.25em, -1em)
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary .secondary-wrap dl dt sup {
        font-size: 60%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .secondary .secondary-wrap dl dt sup {
        font-size: 100%
    }
}

main#home section#access .secondary .secondary-wrap dl dd {
    padding-left: .5em
}

main#home section#access .secondary .secondary-wrap ul li {
    padding-left: 1em;
    text-indent: -1em
}

main#home section#access .secondary .secondary-wrap ul.half {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

main#home section#access .secondary .secondary-wrap ul.half li {
    width: 50%
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary .note {
        font-size: 70%
    }
}

@media screen and (max-width:834px) {
    main#home section#access .secondary .note {
        font-size: 100%
    }
}

@media screen and (min-width:835px),
print {
    main#home section#access .secondary .secondary-wrap {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex
    }

    main#home section#access .secondary .secondary-wrap dl {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start;
        width: 50%
    }
}

main#home #map {
    position: relative;
    width: 100%
}

@media screen and (min-width:835px),
print {
    main#home #map {
        margin-top: 70px
    }
}

@media screen and (max-width:834px) {
    main#home #map {
        margin-top: 41px
    }
}

@media print {
    main#home #map {
        margin-top: 55.9px
    }
}

main#home #map>* {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media screen and (min-width:835px),
print {
    main#home #map {
        padding-top: 350px
    }
}

@media screen and (max-width:834px) {
    main#home #map {
        padding-top: 350px
    }
}