html {
    line-height: 1.15;
    -webkit-text-size-adjust: 100%;
}


body {
    margin: 0;
}


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

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

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


a {
    background-color: transparent;
}


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

b,
strong {
    font-weight: bolder;
}


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


small {
    font-size: 80%;
}


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

sub {
    bottom: -0.25em;
}

sup {
    top: -0.5em;
}


img {
    border-style: none;
}


button,
input,
optgroup,
select,
textarea {
    font-family: inherit;
    font-size: 100%;
    line-height: 1.15;
    margin: 0;
}


button,
input {
    overflow: visible;
}


button,
select {
    text-transform: none;
}


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


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


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


fieldset {
    padding: 0.35em 0.75em 0.625em;
}


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

progress {
    vertical-align: baseline;
}

textarea {
    overflow: auto;
}

[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;
    /* 1 */
    outline-offset: -2px;
    /* 2 */
}

[type="search"]::-webkit-search-decoration {
    -webkit-appearance: none;
}


::-webkit-file-upload-button {
    -webkit-appearance: button;
    /* 1 */
    font: inherit;
    /* 2 */
}


details {
    display: block;
}


summary {
    display: list-item;
}


template {
    display: none;
}


[hidden] {
    display: none;
}


*,
*:before,
*:after {
    box-sizing: inherit;
}

html {
    height: 100%;
    font-size: 62.5%;
    box-sizing: border-box;
}

body {
    font-size: 1.4rem;
    letter-spacing: 0.06em;
    line-height: 1.7;
    color: #333;
    font-family: "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "Sawarabi Mincho", "HG明朝E", Meiryo, serif;
    font-weight: 400;
    /* アンチエイリアスを指定する */
    -webkit-font-smoothing: subpixel-antialiased;
    -moz-osx-font-smoothing: auto;
    /* メトリクスカーニングを指定する */
    -webkit-font-kerning: normal;
    font-kerning: normal;
    height: 100%;
    background-color: #fff;
}

@media screen and (min-width: 768px) {
    body {
        font-size: 1.5rem;
    }
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-family: inherit;
    font-weight: 400;
    line-height: 1.4;
    color: inherit;
}

p {
    -webkit-margin-before: 0em;
    margin-block-start: 0em;
    -webkit-margin-after: 1em;
    margin-block-end: 1em;
}

ul,
ol {
    padding-left: 0em;
    list-style: none;
}


li>ul,
li>ol {
    margin-bottom: 0;
}

dd {
    margin-left: 0;
}

table {
    width: 100%;
}

th {
    text-align: left;
}

a {
    text-decoration: none;
    color: #333;
}

a:focus {
    outline: none;
}

img {
    vertical-align: bottom;
}


i,
cite,
em,
address,
dfn {
    font-style: normal;
}

code,
pre {
    font-family: Consolas, Menlo, Courier, monospace;
}

code {
    padding: 0.2em;
    border-radius: 3px;
    font-size: 0.8em;
    background-color: rgba(0, 0, 0, 0.06);
}

pre code {
    padding: 0;
    font-size: 0.8em;
    background-color: inherit;
}

h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
blockquote,
p,
address,
hr,
table,
fieldset,
figure,
pre {
    margin-top: 0;
    margin-bottom: 0;
    max-height: 99999px;
}


@media screen and (min-width: 600px) {
    .l-header {
        overflow: hidden;
        /* height: 220vh; */
        width: 100%;
        position: fixed;
        top: 0;
        background: #fff;
        z-index: 111;
        box-shadow: 0px 4px 4px 0px #D0D0D040;
    }
}

@media screen and (max-width: 599px) {
    .l-header {
        position: relative;
        /* height: 220vh; */
    }
}

.l-header-top {
    transition: 1.3s;
    position: relative;
    /* height: 100vh; */
    display: flex;
    justify-content: space-between;
    width: 100%;
}

.l-header-top .logo {
    margin-left: 5%;
    margin-top: 6px;
}

.l-header-top .logo>a {
    display: block;
}

.l-header-top .logo>a img {}

.l-header-bottom {
    transition: 1.3s;
    position: relative;
    height: 120vh;
}

.l-header__title {
    position: absolute;
    z-index: 6;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
    visibility: hidden;
    opacity: 0;
}

@media screen and (min-width: 600px) {
    .l-header__title {
        bottom: 0;
        width: 90px;
        height: 312px;
    }
}

@media screen and (max-width: 599px) {
    .l-header__title {
        bottom: 80px;
        width: calc(185px / 2);
        height: calc(640px / 2);
    }
}

.l-header__title-svg {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}

@media screen and (min-width: 600px) {
    .l-header__title-svg {
        width: 100%;
        height: 100%;
        fill: #fff;
    }
}

@media screen and (max-width: 599px) {
    .l-header__title-svg {
        width: 100%;
        height: 100%;
        fill: #fff;
    }
}

@media screen and (min-width: 600px) {
    .l-header__movie-button {
        display: block;
        position: fixed;
        z-index: 1;
        bottom: 30px;
        right: 30px;
    }
}

@media screen and (max-width: 599px) {
    .l-header__movie-button {
        display: none;
    }
}

@media screen and (min-width: 600px) {
    .l-header__movie-button-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .l-header__movie-button-sp {
        display: block;
        position: absolute;
        top: calc(60vh - 25px + 200px);
        left: 0;
        right: 0;
        margin: auto;
        padding-top: 12px;
        color: #fff;
        width: calc(400px / 2);
        height: calc(100px / 2);
        border: 1px solid #fff;
        border-radius: 10px;
        padding-left: 40px;
    }

    .l-header__movie-button-sp img {
        margin-left: 8px;
    }
}

.l-header__message {
    position: relative;
    z-index: 1;
    color: #fff;
    -webkit-writing-mode: vertical-rl !important;
    -ms-writing-mode: tb-rl !important;
    writing-mode: vertical-rl !important;
    text-orientation: mixed !important;
    text-align: left;
}

@media screen and (min-width: 600px) {
    .l-header__message {
        top: calc((100vh - 512px) / 2 + 120px);
        width: 520px;
        height: 512px;
        left: calc(50% - 260px);
    }
}

@media screen and (max-width: 599px) {
    .l-header__message {
        top: calc((100vh - 385px) / 2);
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .l-header__message-title {
        font-size: 2.5rem;
        letter-spacing: 0.15em;
        line-height: 1;
        margin-left: 40px;
        margin-right: 0px;
    }
}

@media screen and (max-width: 599px) {
    .l-header__message-title {
        font-size: 2.1rem;
        letter-spacing: 0.15em;
        line-height: 1;
        margin-right: 3%;
    }
}

@media screen and (min-width: 600px) {
    .l-header__message-text {
        font-size: 1.9rem;
        letter-spacing: 0.15em;
        line-height: 2.5;
    }
}

@media screen and (max-width: 599px) {
    .l-header__message-text {
        font-size: 1.5rem;
        letter-spacing: 0.15em;
        line-height: 7vw;
    }
}

.l-header__cursol,
.l-header__cursol--top {
    font-family: 'Lato', sans-serif;
    color: #fff;
    font-size: 1.0rem;
    position: absolute;
    z-index: 1;
    width: 42px;
    height: 15px;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
}

.l-header__cursol span,
.l-header__cursol--top span {
    position: relative;
    top: 0px;
    -webkit-animation: _l-header__cursol 5s ease forwards 0s infinite;
    animation: _l-header__cursol 5s ease forwards 0s infinite;
}

.l-header__cursol span::before,
.l-header__cursol--top span::before {
    content: "";
    bottom: -25px;
    left: 20px;
    display: inline-block;
    position: absolute;
    background-color: #fff;
    height: 1px;
    width: 18px;
    -webkit-transform: rotate(-42deg);
    transform: rotate(-42deg);
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
}

.l-header__cursol span::after,
.l-header__cursol--top span::after {
    content: "";
    position: absolute;
    bottom: -26px;
    left: 20px;
    display: inline-block;
    background-color: #fff;
    height: 1px;
    width: 18px;
    -webkit-transform: rotate(-138deg);
    transform: rotate(-138deg);
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
}

@media screen and (min-width: 600px) {

    .l-header__cursol,
    .l-header__cursol--top {
        bottom: 60px;
    }
}

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

    .l-header__cursol,
    .l-header__cursol--top {
        bottom: 40px;
    }
}

.l-header__cursol--top {
    position: fixed;
}

@-webkit-keyframes _l-header__cursol {
    0% {
        top: 0px;
        opacity: 0;
    }

    10% {
        top: 0px;
        opacity: 1;
    }

    80% {
        top: 0px;
        opacity: 1;
    }

    100% {
        top: 8px;
        opacity: 0;
    }
}

@keyframes _l-header__cursol {
    0% {
        top: 0px;
        opacity: 0;
    }

    10% {
        top: 0px;
        opacity: 1;
    }

    80% {
        top: 0px;
        opacity: 1;
    }

    100% {
        top: 8px;
        opacity: 0;
    }
}

.l-header--subpage {
    position: relative;
    overflow: hidden;
    height: 100vh;
    width: 100%;
}

.l-header__mainimage {
    height: 100vh;
    width: 100%;
    position: fixed;
}

@media screen and (min-width: 600px) {
    .l-header__mainimage img {
        position: fixed;
        z-index: 0;
        top: 0;
        left: -100%;
        right: -100%;
        bottom: 0;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
    }
}

@media screen and (max-width: 599px) {
    .l-header__mainimage img {
        display: none;
    }
}

@media screen and (min-width: 600px) {

    .l-header--blur .l-header-top,
    .l-header--blur .l-header-bottom,
    .l-header--blur .l-header__video-digest {
        -webkit-filter: blur(10px);
        filter: blur(10px);
        -webkit-transform: scale(1.02);
        transform: scale(1.02);
    }
}

@media screen and (min-width: 600px) {
    .l-header__scroll-hidden {
        overflow: hidden;
    }
}

.l-header__video-digest {
    transition: 1.3s;
}

@media screen and (min-width: 600px) {
    .l-header__video-digest {
        position: fixed;
        z-index: -1;
        top: 0;
        left: -1000%;
        right: -1000%;
        bottom: 0;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
    }
}

@media screen and (max-width: 599px) {
    .l-header__video-digest {
        display: none;
    }
}

.l-header__video-full {
    transition: 1.3s;
    opacity: 0;
    position: fixed;
    z-index: 4;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 80%;
    visibility: hidden;
}

.l-header__video-full--play {
    opacity: 1;
    visibility: visible;
}

.l-header__movie-close {
    transition: 0.5s;
    position: fixed;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
    z-index: 3;
    cursor: pointer;
    visibility: hidden;
    opacity: 0;
}

@media screen and (min-width: 600px) {
    .l-header__movie-close {
        background-color: black;
    }
}

@media screen and (max-width: 599px) {
    .l-header__movie-close {
        background-color: black;
    }
}

.l-header__movie-close--vislble {
    visibility: visible;
    opacity: 1;
}

.l-header__movie-close-button {
    height: 40px;
    width: 40px;
    position: absolute;
}

.l-header__movie-close-button span {
    background-color: #fff;
    position: absolute;
    left: 0;
    height: 1px;
}

.l-header__movie-close-button span:nth-of-type(1) {
    top: 5px;
    left: 5px;
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    width: 100%;
}

.l-header__movie-close-button span:nth-of-type(2) {
    bottom: 5px;
    left: 5px;
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    width: 100%;
}

@media screen and (min-width: 600px) {
    .l-header__movie-close-button {
        top: 50px;
        right: 50px;
    }
}

@media screen and (max-width: 599px) {
    .l-header__movie-close-button {
        top: 4.71014%;
        right: 4.71014%;
    }
}

/* #Footer
   -------------------------------------------------------------------------- */
/*doc
---
title: footer
name: footer
categories: [layout]
---

`<body>`タグ直下にある`<footer>`タグのスタイルです。
コピーライトやナビゲーションのレイアウトを含むことはできますが、
コンポーネント自体はobject/projectレイヤーで定義します。

*/
.l-footer {
    background-color: #FDFBF7;
    position: relative;
    z-index: 1;
    border-top: solid 1px #dadada;
}

@media screen and (min-width: 600px) {
    .l-footer {
        height: 300px;
        padding-top: 60px;
        padding-bottom: 50px;
    }
}

@media screen and (max-width: 599px) {
    .l-footer {
        padding-top: 10%;
        padding-bottom: 10%;
    }
}

@media screen and (min-width: 600px) {
    .l-footer-inner {
        width: 93.05556%;
        margin: 0 auto;
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
    }
}

@media screen and (max-width: 599px) {
    .l-footer-inner {
        position: relative;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        /* padding-top: 205px; */
    }
}

@media screen and (min-width: 600px) {
    .l-footer__section-nav {
        /* margin-right: auto; */
    }
}

.l-footer__nav {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    margin-top: 18px;
}

.l-footer__nav a {
    color: #333333;
    font-size: 1.5rem;
    font-weight: 500;
    letter-spacing: 0.75px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    .l-footer__nav {
        font-size: 1.2rem;
        letter-spacing: 0.1em;
        display: flex;
        flex-flow: row wrap;
    }
}

@media screen and (min-width: 600px) {
    .l-footer__nav-item:nth-last-of-type(n+2) {
        margin-right: 20px;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__nav-item {
        font-size: 1.2rem;
    }

    .l-footer__nav-item:nth-of-type(n+2) {
        margin-top: 20px;
    }
}

.l-footer__copyright {
    font-family: "Roboto", sans-serif !important;
    color: #333333;
    display: block;
}

@media screen and (min-width: 600px) {
    .l-footer__copyright {
        font-size: 1.2rem;
        letter-spacing: 0.05em;
        margin-top: 30px;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__copyright {
        text-align: center;
        margin-top: 5%;
    }
}

@media screen and (min-width: 600px) {
    .l-footer__section-address {
        /* margin-right: 90px; */
    }
}

@media screen and (max-width: 599px) {
    .l-footer__section-address {
        /* position: absolute; */
        /* top: 0px; */
    }
}

.l-footer__sns {
    font-family: "Open Sans", sans-serif !important;
    margin-top: 18px;
}

.l-footer__sns>li {
    margin-left: 10px;
}

@media screen and (min-width: 600px) {
    .l-footer__sns {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        width: 190px;
        font-size: 1.6rem;
        margin-left: auto;
        margin-right: 0;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__sns {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        width: 200px;
        font-size: 2.1rem;
        margin: 18px auto;
    }
}

.l-footer__address-phone {
    /* font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif; */
    font-weight: 500;
    line-height: 2;
    letter-spacing: 0.8999999761581421px;
    text-align: right;
}

@media screen and (min-width: 600px) {
    .l-footer__address-phone {
        margin-top: 25px;
        font-size: 1.4rem;
        line-height: 2;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__address-phone {
        margin-top: 30px;
        font-size: 1.3rem;
        text-align: center;
    }
}

@media screen and (min-width: 600px) {
    .l-footer__address {}

    .l-footer__address br {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__address {
        margin-bottom: 10px;
    }
}

.l-footer__other {
    text-align: right;
    margin-top: 20px;
}

.l-footer__other>a {
    font-size: 12px;
    font-weight: 400;
    line-height: 20.4px;
    letter-spacing: 0.6000000238418579px;
    text-align: right;
    margin-left: 20px;
}

.l-footer__logo {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}

.l-footer__logo>a {
    display: block;
}

@media screen and (min-width: 600px) {
    .l-footer__logo {}
}

@media screen and (max-width: 599px) {
    .l-footer__logo {
        /* position: absolute; */
        /* top: 65px; */
        /* right: 0; */
        /* width: 70px; */
        /* height: 243px; */
        /* fill: #000; */
    }

    .l-footer__logo>a {
        text-align: center;
    }
}

.l-footer__txt {
    margin-top: 5%;
}

.l-footer__txt p {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 28px;
    letter-spacing: 0.8999999761581421px;
    text-align: left;
}

@media screen and (min-width: 600px) {
    .l-footer__book {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__book {
        transition: 0.5s;
        display: block;
        height: 62px;
        background-color: #333;
        width: 100%;
        position: fixed;
        bottom: -62px;
        font-size: 1.6rem;
        color: #fff;
        text-align: center;
        padding-top: 18px;
    }

    .l-footer__txt p {
        text-align: center;
    }
}

.l-footer__book-text {
    position: relative;
    display: block;
}

.l-footer__book-cursol {
    position: absolute;
    right: 8.5vw;
}

.l-footer__book-cursol::before {
    content: "";
    height: 1px;
    position: absolute;
    top: 14px;
    left: -50px;
    background: #fff;
    width: 50px;
    -webkit-animation: _l-footer__book-cursol-before 5s ease forwards 0s infinite;
    animation: _l-footer__book-cursol-before 5s ease forwards 0s infinite;
}

.l-footer__book-cursol::after {
    content: "";
    width: 10px;
    height: 1px;
    position: absolute;
    top: 14px;
    background: #fff;
    -webkit-transform-origin: 0px 0.5px;
    transform-origin: 0px 0.5px;
    -webkit-transform: rotate(-150deg);
    transform: rotate(-150deg);
    left: 0px;
    -webkit-animation: _l-footer__book-cursol-after 5s ease forwards 0s infinite;
    animation: _l-footer__book-cursol-after 5s ease forwards 0s infinite;
}

@-webkit-keyframes _l-footer__book-cursol-before {
    0% {
        width: 50px;
    }

    79% {
        width: 50px;
        opacity: 1;
    }

    80% {
        width: 50px;
        opacity: 0;
    }

    81% {
        width: 0px;
    }

    100% {
        width: 50px;
        opacity: 1;
    }
}

@keyframes _l-footer__book-cursol-before {
    0% {
        width: 50px;
    }

    79% {
        width: 50px;
        opacity: 1;
    }

    80% {
        width: 50px;
        opacity: 0;
    }

    81% {
        width: 0px;
    }

    100% {
        width: 50px;
        opacity: 1;
    }
}

@-webkit-keyframes _l-footer__book-cursol-after {
    0% {
        left: 0px;
    }

    79% {
        left: 0px;
        opacity: 1;
    }

    80% {
        left: 0px;
        opacity: 0;
    }

    81% {
        left: -50px;
    }

    100% {
        left: 0px;
        opacity: 1;
    }
}

@keyframes _l-footer__book-cursol-after {
    0% {
        left: 0px;
    }

    79% {
        left: 0px;
        opacity: 1;
    }

    80% {
        left: 0px;
        opacity: 0;
    }

    81% {
        left: -50px;
    }

    100% {
        left: 0px;
        opacity: 1;
    }
}

/* #Content
   -------------------------------------------------------------------------- */
/*doc
---
title: content
name: content
categories: [layout]
---

`<article>`タグが使われるようなメインコンテンツのスタイルです。
ナビゲーションやバナーなどのレイアウトを含むことはできますが、
コンポーネント自体はobject/projectレイヤーで定義します。

```block
<body>
  <article class="l-content s-blog">
    <header class="l-content__lead"></header>
  </article>
</body>
```
*/
.l-content {
    position: relative;
    z-index: 1;
    background: url(../image/bg_pettern.png) left top repeat;
}

@media screen and (min-width: 600px) {
    .l-content {}
}

@media screen and (max-width: 599px) {
    .l-content {
        /* padding-top: 50px; */
    }
}

@media screen and (max-width: 599px) {
    .l-content__firstview {
        padding-bottom: 80px;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .l-content__overview {
        line-height: 2;
        text-align: center !important;
        width: 87.5%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (max-width: 599px) {
    .l-content__overview {
        line-height: 2;
        text-align: left;
        letter-spacing: 0.03em;
    }

    .l-content__overview br {
        display: none;
    }

    .l-content__overview span {
        display: block;
    }
}

.l-content--news {
    padding-bottom: 2%;
}

@media screen and (min-width: 600px) {

    .l-content--news,
    .l-content--column,
    .l-content--information,
    .l-content--privacy,
    .l-content--note,
    .l-content--contact {
        padding-top: 150px;
    }
}

@media screen and (min-width: 600px) {
    .l-section {
        margin-top: 110px;
    }
}

@media screen and (max-width: 599px) {
    .l-section:nth-of-type(n+2) {
        margin-top: 55px;
    }
}

.l-information {
    position: relative;
    background-color: #fff;
}

@media screen and (max-width: 599px) {
    .l-information {
        width: 100%;
    }
}

.l-information-top {
    /* background: url(../image/bg_pettern.png) left top repeat; */
}

@media screen and (min-width: 600px) {
    .l-information-top {
        padding-top: 120px;
    }
}

@media screen and (max-width: 599px) {
    .l-information-top {
        padding-top: 80px;
        /* padding-bottom: 65px; */
    }
}

@media screen and (min-width: 600px) {
    .l-information__title {
        margin-bottom: 60px;
    }
}

@media screen and (max-width: 599px) {
    .l-information__title {
        margin-bottom: 45px;
    }
}

.l-information-map {
    position: relative;
    height: 460px;
    overflow: hidden;
}

.l-information-img {
    position: absolute;
    right: 0;
    top: 0;
    width: 50%;
    height: 100%;
}

.l-information-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.l-information__googlemap {
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
}

@media screen and (min-width: 600px) {
    .l-information__googlemap {
        width: 100%;
    }
}

@media screen and (max-width: 599px) {
    .l-information__googlemap {
        width: 100%;
        /* height: 245px; */
    }
}

@media screen and (min-width: 600px) {
    .l-information__readmore {
        margin-left: auto;
        margin-right: auto;
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .l-information__readmore {
        margin-left: auto;
        margin-right: auto;
        margin-top: 35px;
    }
}

.l-information__banner {
    background-color: #fff;
}

@media screen and (min-width: 600px) {
    .l-information__banner {
        width: 88.88889%;
        margin: 0 auto;
        margin-top: 90px;
        padding-bottom: 40px;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
    }
}

@media screen and (max-width: 599px) {
    .l-information__banner {
        margin-top: 45px;
        width: 100%;
    }
}

@media screen and (min-width: 600px) {
    .l-information__banner-item {
        padding-left: 20px;
        padding-right: 20px;
    }

    .l-information__banner-item img {
        width: 100%;
        height: auto;
        cursor: pointer;
    }
}

@media screen and (max-width: 599px) {
    .l-information__banner-item {
        padding-left: 1.5vw;
        padding-right: 1.5vw;
    }

    .l-information__banner-item img {
        width: 100%;
        height: auto;
        cursor: pointer;
    }
}

/* =============================================================================
   #Object
   ========================================================================== */
/* -----------------------------------------------------------------------------
   #Component
   -------------------------------------------------------------------------- */
/* -----------------------------------------------------------------------------
   #Project
   -------------------------------------------------------------------------- */
/* #Animation
   -------------------------------------------------------------------------- */
/*doc
---
title: animation
name: animation
categories: [project]
---

animation_min.jsで使用するアニメーションです。
*/
.p-delay_1s {
    -webkit-animation-delay: 0.1s !important;
    animation-delay: 0.1s !important;
}

.p-delay_2s {
    -webkit-animation-delay: 0.2s !important;
    animation-delay: 0.2s !important;
}

.p-delay_3s {
    -webkit-animation-delay: 0.3s !important;
    animation-delay: 0.3s !important;
}

.p-delay_4s {
    -webkit-animation-delay: 0.4s !important;
    animation-delay: 0.4s !important;
}

.p-delay_5s {
    -webkit-animation-delay: 0.5s !important;
    animation-delay: 0.5s !important;
}

.p-delay_6s {
    -webkit-animation-delay: 0.6s !important;
    animation-delay: 0.6s !important;
}

.p-delay_7s {
    -webkit-animation-delay: 0.7s !important;
    animation-delay: 0.7s !important;
}

.p-delay_8s {
    -webkit-animation-delay: 0.8s !important;
    animation-delay: 0.8s !important;
}

.p-delay_9s {
    -webkit-animation-delay: 0.9s !important;
    animation-delay: 0.9s !important;
}

.p-delay_10s {
    -webkit-animation-delay: 1s !important;
    animation-delay: 1s !important;
}

.p-delay_11s {
    -webkit-animation-delay: 1.1s !important;
    animation-delay: 1.1s !important;
}

.p-delay_12s {
    -webkit-animation-delay: 1.2s !important;
    animation-delay: 1.2s !important;
}

.p-delay_13s {
    -webkit-animation-delay: 1.3s !important;
    animation-delay: 1.3s !important;
}

.p-delay_14s {
    -webkit-animation-delay: 1.4s !important;
    animation-delay: 1.4s !important;
}

.p-delay_15s {
    -webkit-animation-delay: 1.5s !important;
    animation-delay: 1.5s !important;
}

.p-delay_16s {
    -webkit-animation-delay: 1.6s !important;
    animation-delay: 1.6s !important;
}

.p-delay_17s {
    -webkit-animation-delay: 1.7s !important;
    animation-delay: 1.7s !important;
}

.p-delay_18s {
    -webkit-animation-delay: 1.8s !important;
    animation-delay: 1.8s !important;
}

.p-delay_19s {
    -webkit-animation-delay: 1.9s !important;
    animation-delay: 1.9s !important;
}

.p-delay_20s {
    -webkit-animation-delay: 2s !important;
    animation-delay: 2s !important;
}

.p-ani-fadeInUp {
    -webkit-animation: p-ani-fadeInUp 1.5s ease 0s both 1 normal;
    animation: p-ani-fadeInUp 1.5s ease 0s both 1 normal;
    visibility: visible !important;
}

.p-ani-fadeIn {
    -webkit-animation: p-ani-fadeIn 1.5s ease 0s both 1 normal;
    animation: p-ani-fadeIn 1.5s ease 0s both 1 normal;
    visibility: visible !important;
}

.p-ani-fadeInBlur {
    -webkit-animation: p-ani-fadeInBlur 2s ease 0s backwards 1 normal;
    animation: p-ani-fadeInBlur 2s ease 0s backwards 1 normal;
    visibility: visible !important;
}

.p-ani-fadeInScale {
    -webkit-animation: p-ani-fadeInScale 2s ease 0s backwards 1 normal;
    animation: p-ani-fadeInScale 2s ease 0s backwards 1 normal;
    visibility: visible !important;
}

.p-ani-fadeInLeft {
    -webkit-animation: p-ani-fadeInLeft 1.5s ease 0s backwards 1 normal;
    animation: p-ani-fadeInLeft 1.5s ease 0s backwards 1 normal;
    visibility: visible !important;
}

.p-ani-fadeOut {
    -webkit-animation: p-ani-fadeOut 1.5s ease 0s both 1 normal;
    animation: p-ani-fadeOut 1.5s ease 0s both 1 normal;
    visibility: hidden !important;
}

.p-ani-width {
    -webkit-animation-name: p-ani-width;
    animation-name: p-ani-width;
    -webkit-animation-duration: 1s;
    animation-duration: 1s;
    -webkit-animation-timing-function: ease;
    animation-timing-function: ease;
    -webkit-animation-delay: 0s;
    animation-delay: 0s;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-direction: normal;
    animation-direction: normal;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-play-state: running;
    animation-play-state: running;
    visibility: visible !important;
}

.p-ani-height {
    -webkit-animation: p-ani-height 1s ease 0s both 1 normal;
    animation: p-ani-height 1s ease 0s both 1 normal;
    visibility: visible !important;
}

.p-animation__dummybox-gray {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    background-color: #eee;
    width: 100%;
    height: 100%;
}

.p-animation__dummybox-white {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    background-color: #fff;
    width: 100%;
    height: 100%;
}

.p-ani-slide-scaleUp {
    -webkit-animation-name: p-ani-slide-scaleUp;
    animation-name: p-ani-slide-scaleUp;
    -webkit-animation-duration: 15s;
    animation-duration: 15s;
    -webkit-animation-timing-function: linear;
    animation-timing-function: linear;
    -webkit-animation-delay: 0s;
    animation-delay: 0s;
    -webkit-animation-iteration-count: 1;
    animation-iteration-count: 1;
    -webkit-animation-direction: normal;
    animation-direction: normal;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
    -webkit-animation-play-state: running;
    animation-play-state: running;
}

@-webkit-keyframes p-ani-fadeIn {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@keyframes p-ani-fadeIn {
    0% {
        opacity: 0;
    }

    100% {
        opacity: 1;
    }
}

@-webkit-keyframes p-ani-fadeOut {
    0% {
        opacity: 1;
    }

    100% {
        display: none;
        opacity: 0.5;
    }
}

@keyframes p-ani-fadeOut {
    0% {
        opacity: 1;
    }

    100% {
        display: none;
        opacity: 0.5;
    }
}

@-webkit-keyframes p-ani-fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translateY(20px);
        transform: translateY(20px);
    }

    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@keyframes p-ani-fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translateY(20px);
        transform: translateY(20px);
    }

    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@-webkit-keyframes p-ani-fadeInBlur {
    0% {
        opacity: 0;
        -webkit-filter: blur(5px);
        filter: blur(5px);
        -webkit-transform: scale(1.03);
        transform: scale(1.03);
    }

    100% {
        opacity: 1;
        -webkit-filter: none;
        filter: none;
        -webkit-transform: none;
        transform: none;
    }
}

@keyframes p-ani-fadeInBlur {
    0% {
        opacity: 0;
        -webkit-filter: blur(5px);
        filter: blur(5px);
        -webkit-transform: scale(1.03);
        transform: scale(1.03);
    }

    100% {
        opacity: 1;
        -webkit-filter: none;
        filter: none;
        -webkit-transform: none;
        transform: none;
    }
}

@-webkit-keyframes p-ani-fadeInScale {
    0% {
        opacity: 0;
        -webkit-transform: scale(1.04);
        transform: scale(1.04);
    }

    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@keyframes p-ani-fadeInScale {
    0% {
        opacity: 0;
        -webkit-transform: scale(1.04);
        transform: scale(1.04);
    }

    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@-webkit-keyframes p-ani-fadeInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-20px);
        transform: translateX(-20px);
    }

    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@keyframes p-ani-fadeInLeft {
    0% {
        opacity: 0;
        -webkit-transform: translateX(-20px);
        transform: translateX(-20px);
    }

    100% {
        opacity: 1;
        -webkit-transform: none;
        transform: none;
    }
}

@-webkit-keyframes p-ani-width {
    0% {
        width: 0%;
    }

    100% {
        width: 100%;
    }
}

@keyframes p-ani-width {
    0% {
        width: 0%;
    }

    100% {
        width: 100%;
    }
}

@-webkit-keyframes p-ani-height {
    0% {
        height: 0%;
    }

    100% {
        height: 100%;
    }
}

@keyframes p-ani-height {
    0% {
        height: 0%;
    }

    100% {
        height: 100%;
    }
}

@-webkit-keyframes p-ani-slide-scaleUp {
    0% {}

    100% {
        -webkit-transform: scaleX(1.2) scaleY(1.2);
        transform: scaleX(1.2) scaleY(1.2);
    }
}

@keyframes p-ani-slide-scaleUp {
    0% {}

    100% {
        -webkit-transform: scaleX(1.2) scaleY(1.2);
        transform: scaleX(1.2) scaleY(1.2);
    }
}

/* #Loader
   -------------------------------------------------------------------------- */
/*doc
---
title: loader
name: loader
categories: [component]
---

ローディング用のオブジェクトです。モーダル白背景のみ表示させています。

*/
.p-loader {
    position: fixed;
    z-index: 5;
    top: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    background: black;
}

.is-loaded .p-loader {
    -webkit-animation: loader_fadeOut 1.5s cubic-bezier(0, 0, 0.58, 1) forwards 0.6s;
    animation: loader_fadeOut 1.5s cubic-bezier(0, 0, 0.58, 1) forwards 0.6s;
}

.p-loader__top {
    position: fixed;
    z-index: 5;
    top: 0;
    right: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 100%;
    background: black;
}

.is-loaded .p-loader__top {
    -webkit-animation: loader_fadeOut 1.5s cubic-bezier(0, 0, 0.58, 1) forwards 2.5s;
    animation: loader_fadeOut 1.5s cubic-bezier(0, 0, 0.58, 1) forwards 2.5s;
}

.is-loaded .p-loader__logo {
    -webkit-animation: loader_fadeIn 1.5s cubic-bezier(0.42, 0, 1, 1) forwards 0.5s, reset_zindex 0s cubic-bezier(0.42, 0, 1, 1) forwards 4.5s;
    animation: loader_fadeIn 1.5s cubic-bezier(0.42, 0, 1, 1) forwards 0.5s, reset_zindex 0s cubic-bezier(0.42, 0, 1, 1) forwards 4.5s;
}

.p-progress {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
    width: 200px;
    height: 1px;
    background: #333333;
}

@media screen and (min-width: 600px) {
    .p-progress {
        min-width: 272px;
        width: 18.88889%;
    }
}

@media screen and (max-width: 599px) {
    .p-progress {
        width: 32.85024%;
    }
}

.is-loaded .p-progress {
    -webkit-animation: loader_fadeOut 0.5s cubic-bezier(0, 0, 0.58, 1) forwards 0.3s;
    animation: loader_fadeOut 0.5s cubic-bezier(0, 0, 0.58, 1) forwards 0.3s;
}

.p-progress__inner {
    position: relative;
    width: 100%;
    height: 100%;
}

.p-progress__bar {
    width: 100%;
    height: 100%;
    background: #ffffff;
    -webkit-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: 0 50%;
    transform-origin: 0 50%;
    transition: all 10s cubic-bezier(0, 0, 0.58, 1);
}

@-webkit-keyframes loader_fadeIn {
    from {
        opacity: 0;
        visibility: visible;
        -webkit-filter: blur(5px);
        filter: blur(5px);
    }

    to {
        opacity: 1;
        -webkit-filter: none;
        filter: none;
        visibility: visible;
    }
}

@keyframes loader_fadeIn {
    from {
        opacity: 0;
        visibility: visible;
        -webkit-filter: blur(5px);
        filter: blur(5px);
    }

    to {
        opacity: 1;
        -webkit-filter: none;
        filter: none;
        visibility: visible;
    }
}

@-webkit-keyframes loader_fadeOut {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
        visibility: hidden;
    }
}

@keyframes loader_fadeOut {
    from {
        opacity: 1;
    }

    to {
        opacity: 0;
        visibility: hidden;
    }
}

@-webkit-keyframes reset_zindex {
    from {}

    to {
        z-index: 1;
    }
}

@keyframes reset_zindex {
    from {}

    to {
        z-index: 1;
    }
}

/* #Slider
   -------------------------------------------------------------------------- */
/*doc
---
title: slider
name: slider
categories: [project]
---

メインフェード画像のオブジェクトです。

*/
@media screen and (min-width: 600px) {
    .p-slider {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .p-slider li {
        position: fixed;
        background: top center / cover no-repeat;
        height: 100%;
        width: 100%;
    }

    .p-slider li:nth-of-type(1) {
        background-image: url(../image/bg-image_1_sp.jpg);
    }

    .p-slider li:nth-of-type(2) {
        background-image: url(../image/bg-image_2_sp.jpg);
    }

    .p-slider li:nth-of-type(3) {
        background-image: url(../image/bg-image_3_sp.jpg);
    }

    .p-slider li:nth-of-type(4) {
        background-image: url(../image/bg-image_4_sp.jpg);
    }

    .p-slider li:nth-of-type(5) {
        background-image: url(../image/bg-image_5_sp.jpg);
    }

    .p-slider li:nth-of-type(6) {
        background-image: url(../image/bg-image_6_sp.jpg);
    }

    .p-slider li:nth-of-type(7) {
        background-image: url(../image/bg-image_7_sp.jpg);
    }

    .p-slider li:nth-of-type(8) {
        background-image: url(../image/bg-image_8_sp.jpg);
    }

    .p-slider li:nth-of-type(9) {
        background-image: url(../image/bg-image_9_sp.jpg);
    }

    .p-slider li:nth-of-type(10) {
        background-image: url(../image/bg-image_10_sp.jpg);
    }
}

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

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

.slick-list:focus {
    outline: none;
}

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

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

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

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

.slick-track:after {
    clear: both;
}

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

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

[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;
}

/***** カスタムセッティング *****/
.p-slick__cursol {
    z-index: 1;
    position: absolute;
    cursor: pointer;
    transition: all 0.3s;
}

.p-slick__cursol span {
    position: absolute;
    top: 0;
    left: 0;
    display: inline-block;
    background-color: #333;
}

@media screen and (min-width: 600px) {
    .p-slick__cursol {
        width: 15px;
        height: 30px;
    }

    .p-slick__cursol span {
        height: 1px;
        width: 20px;
    }
}

@media screen and (max-width: 599px) {
    .p-slick__cursol {
        width: 15px;
        height: 30px;
    }

    .p-slick__cursol span {
        height: 1px;
        width: 20px;
    }
}

.p-slick__cursol--prev span:nth-of-type(1) {
    top: 14px;
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

.p-slick__cursol--prev span:nth-of-type(2) {
    top: 14px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
}

@media screen and (min-width: 600px) {
    .p-slick__cursol--prev {
        left: -30px;
        top: calc(50% - 15px - 20px);
    }
}

@media screen and (max-width: 599px) {
    .p-slick__cursol--prev {
        left: 1.5vw;
        top: 0;
        bottom: 0;
        margin: auto;
    }
}

.p-slick__cursol--next span:nth-of-type(1) {
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

.p-slick__cursol--next span:nth-of-type(2) {
    top: 28px;
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
}

@media screen and (min-width: 600px) {
    .p-slick__cursol--next {
        right: -30px;
        top: calc(50% - 15px - 20px);
    }
}

@media screen and (max-width: 599px) {
    .p-slick__cursol--next {
        right: 1.5vw;
        top: 0;
        bottom: 0;
        margin: auto;
    }
}

.slick-dots {
    position: absolute;
    list-style: none;
    display: block;
    padding: 0;
    margin: 0;
    width: 100%;
    height: 20px;
}

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

.slick-dots li button {
    border: 0;
    background: transparent;
    display: block;
    height: 10px;
    width: 10px;
    border-radius: 50%;
    background-color: #dadada;
    outline: none;
    line-height: 0px;
    color: transparent;
    padding: 0px;
    cursor: pointer;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
}

.slick-dots li button:hover,
.slick-dots li button:focus {
    outline: none;
    background-color: #b9af96;
}

.slick-dots li.slick-active button {
    background-color: #b9af96;
}

@media screen and (min-width: 600px) {
    .l-information__banner .slick-dots {
        bottom: 0px;
        text-align: center;
    }
}

@media screen and (max-width: 599px) {
    .l-information__banner .slick-dots {
        bottom: -35px;
        text-align: center;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction .slick-dots {
        top: -32px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction .slick-dots {
        top: 0px;
        right: -8px;
        text-align: right;
    }
}

@media screen and (min-width: 600px) {
    .p-slick-facilities-dots--left .slick-dots {
        left: -8px;
        text-align: left;
    }
}

@media screen and (min-width: 600px) {
    .p-slick-facilities-dots--right .slick-dots {
        right: -8px;
        text-align: right;
    }
}

/* #Nav
   -------------------------------------------------------------------------- */
/*doc
---
title: nav
name: nav
categories: [project]
---

ナビゲーションのコンポーネントです。

*/
.p-nav {
    transition: 0.3s;
}

@media screen and (min-width: 600px) {
    .p-nav {
        /* position: fixed; */
        /* z-index: 2; */
        /* left: 0px; */
        /* top: 0px; */
        width: 70%;
        max-width: 1000px;
    }
}

@media screen and (max-width: 599px) {
    .p-nav {
        display: none;
    }
}

.p-nav__menu-trigger {
    cursor: pointer;
    position: fixed;
    height: 40px;
    width: 40px;
    z-index: 12;
    display: none;
}

.p-nav__menu-trigger span {
    background-color: #333;
    transition: 0.5s;
    position: absolute;
    left: 0;
    height: 1px;
}

.p-nav__menu-trigger span:nth-of-type(1) {
    top: 14px;
    width: 100%;
}

.p-nav__menu-trigger span:nth-of-type(2) {
    bottom: 14px;
    width: 75%;
}

.p-nav__menu-trigger p {
    font-family: 'Lato', sans-serif;
    font-size: 1.2rem;
    color: #7f7f7f;
    transition: 0.5s;
    opacity: 0;
    visibility: hidden;
}

@media screen and (min-width: 600px) {
    .p-nav__menu-trigger {
        top: 16px;
        left: 50px;
    }

    .p-nav__menu-trigger p {
        margin-left: 50px;
        margin-top: 10px;
    }
}

@media screen and (max-width: 599px) {
    .p-nav__menu-trigger {
        top: 10px;
        right: 20px;
        display: block;
    }

    .p-nav__menu-trigger p {
        margin-left: -50px;
        margin-top: 10px;
    }
}

@-webkit-keyframes _p-nav__menu-trigger_1 {
    0% {
        width: 100%;
    }

    50% {
        width: 0%;
    }

    100% {
        width: 100%;
    }
}

@keyframes _p-nav__menu-trigger_1 {
    0% {
        width: 100%;
    }

    50% {
        width: 0%;
    }

    100% {
        width: 100%;
    }
}

@-webkit-keyframes _p-nav__menu-trigger_2 {
    0% {
        width: 0;
    }

    100% {
        width: 75%;
    }
}

@keyframes _p-nav__menu-trigger_2 {
    0% {
        width: 0;
    }

    100% {
        width: 75%;
    }
}

.p-nav__menu-trigger--close span {
    background-color: #7f7f7f;
}

.p-nav__menu-trigger--close span:nth-of-type(1) {
    top: 5px;
    left: 5px;
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    width: 100%;
}

.p-nav__menu-trigger--close span:nth-of-type(2) {
    bottom: 5px;
    left: 5px;
    -webkit-transform-origin: 0px 0px;
    transform-origin: 0px 0px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    width: 100%;
}

.p-nav__menu-trigger--close p {
    opacity: 1;
    visibility: visible;
}

@media screen and (min-width: 600px) {
    .p-nav__menu {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        /* position: absolute; */
        /* top: 30px; */
        /* left: 130px; */
        padding-right: 150px;
    }
}

@media screen and (max-width: 1150px) {
    .p-nav__menu {
        display: none;
    }
}

.p-nav__menu-item {
    transition: 0.3s;
}

@media screen and (min-width: 600px) {
    .p-nav__menu-item {
        margin-right: 20px;
        position: relative;
        font-size: 1.5rem;
        letter-spacing: 0.05em;
        line-height: 1;
    }

    .p-nav__menu-item a {
        color: #333333;
        display: block;
        position: relative;
        line-height: 70px;
    }
}

@media screen and (max-width: 599px) {
    .p-nav__menu-item {
        position: relative;
        font-size: 1.3rem;
        letter-spacing: 0.2em;
        line-height: 1;
    }

    .p-nav__menu-item a {
        display: block;
        padding-left: 12px;
    }

    .p-nav__menu-item:nth-of-type(2) {
        margin-right: 15px;
    }

    .p-nav__menu-item:nth-of-type(n + 2)::before {
        content: "";
        top: 0;
        left: 0;
        display: inline-block;
        position: absolute;
        background-color: #333;
        height: 1px;
        width: 7px;
        -webkit-transform: translateY(4px) rotate(35deg);
        transform: translateY(4px) rotate(35deg);
    }

    .p-nav__menu-item:nth-of-type(n + 2)::after {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        display: inline-block;
        background-color: #333;
        height: 1px;
        width: 7px;
        -webkit-transform: translateY(8px) rotate(-35deg);
        transform: translateY(8px) rotate(-35deg);
    }
}

.p-nav__language {
    transition: 0.3s;
}

@media screen and (min-width: 600px) {
    .p-nav__language {
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
        position: absolute;
        top: 28px;
        right: 155px;
        width: 100px;
    }
}

@media screen and (min-width: 600px) {
    .p-nav__language-item {
        font-family: 'Lato', sans-serif;
        font-size: 1.2rem;
        letter-spacing: 0.1em;
    }

    .p-nav__language-item a {
        color: #fff;
    }
}

.p-nav__book a {
    display: block;
    transition: 0.3s;
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    color: #fff;
    background-color: #85A446;
}

@media screen and (min-width: 600px) {
    .p-nav__book a {
        text-align: center;
        font-size: 1.5rem;
        letter-spacing: 0.1em;
        position: absolute;
        width: 130px;
        height: 70px;
        padding-top: 25px;
        right: 0px;
        top: 0px;
    }

    .p-nav__book a:hover {
        opacity: 0.6;
    }
}

.p-nav-modal {
    visibility: hidden;
    opacity: 0;
    transition: 0.8s;
    position: fixed;
    z-index: 11;
    top: 0;
    left: 0;
    background: url(../image/bg_pettern.png) left top repeat;
}

@media screen and (min-width: 600px) {
    .p-nav-modal {
        width: 100%;
        height: 100%;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal {
        width: 100%;
        height: 100vh;
        overflow-y: scroll;
        -webkit-overflow-scrolling: touch;
    }
}

.p-nav-modal--active {
    visibility: visible;
    opacity: 1;
}

@media screen and (max-width: 599px) {
    .p-nav-modal__inner {
        position: relative;
        padding-left: 4.71014%;
        padding-right: 4.71014%;
        padding-bottom: 180px;
        padding-top: 8%;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__lang-sns {
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
        position: absolute;
        right: 40px;
        top: 29px;
        width: 215px;
    }
}

.p-nav-modal__lang {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
    width: 100px;
}

.p-nav-modal__lang a {
    color: #a5a5a5;
}

@media screen and (max-width: 599px) {
    .p-nav-modal__lang {
        margin-top: 30px;
        margin-left: 20px;
    }
}

.p-nav-modal__sns {
    display: flex;
    flex-flow: row wrap;
    justify-content: space-between;
}

@media screen and (min-width: 600px) {
    .p-nav-modal__sns {
        width: 85px;
    }

    .p-nav-modal__sns a {
        color: #7f7f7f;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__sns {
        position: absolute;
        left: 0;
        right: 0;
        margin: auto;
        width: 135px;
        bottom: 120px;
    }

    .p-nav-modal__sns a {
        color: #7f7f7f;
    }
}

.p-nav-modal__lang-item {
    font-family: 'Lato', sans-serif;
    font-size: 1.2rem;
    letter-spacing: 0.1em;
    line-height: 1;
}

@media screen and (min-width: 600px) {
    .p-nav-modal__lang-item {
        margin-top: 3px;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__sns-item {
        font-size: 1.6rem;
        line-height: 1;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__sns-item {
        font-size: 2.1rem;
        line-height: 1;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__logo-menu {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        margin-top: 23vh;
        max-width: 960px;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__title {
        width: 345px;
        padding-left: 95px;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__title {
        width: calc(530px / 2);
        margin-left: auto;
        margin-right: auto;
        margin-top: 70px;
        margin-bottom: 50px;
    }
}

.p-nav-modal__title-svg {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}

@media screen and (min-width: 600px) {
    .p-nav-modal__title-svg {
        width: 80px;
        height: 279px;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__title-svg {
        display: none;
    }
}

.p-nav-modal__title-svg-sp {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}

@media screen and (min-width: 600px) {
    .p-nav-modal__title-svg-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__title-svg-sp {
        width: calc(530px / 2);
        height: calc(100px / 2);
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__menu:nth-of-type(1) {
        width: 365px;
    }

    .p-nav-modal__menu:nth-of-type(2) {
        width: 250px;
    }
}

.p-nav-modal__menu-item span {
    font-family: 'Lato', sans-serif;
    display: block;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .p-nav-modal__menu-item {
        font-size: 2.6rem;
        line-height: 1.2;
    }

    .p-nav-modal__menu-item span {
        font-size: 1.4rem;
    }

    .p-nav-modal__menu-item:nth-of-type(n+2) {
        margin-top: 55px;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__menu-item {
        text-align: left;
    }

    .p-nav-modal__menu:nth-of-type(1) .p-nav-modal__menu-item,
    .p-nav-modal__menu:nth-of-type(2) .p-nav-modal__menu-item:nth-of-type(1) {
        margin-top: 35px;
        font-size: 2.0rem;
        line-height: 1.2;
        letter-spacing: 0.03em;
    }

    .p-nav-modal__menu:nth-of-type(1) .p-nav-modal__menu-item span,
    .p-nav-modal__menu:nth-of-type(2) .p-nav-modal__menu-item:nth-of-type(1) span {
        font-size: 1.2rem;
        letter-spacing: 0.03em;
    }

    .p-nav-modal__menu:nth-of-type(2) .p-nav-modal__menu-item:nth-of-type(n+2) a {
        font-size: 1.4rem;
        line-height: 1.2;
        padding-top: 10px;
        padding-bottom: 9px;
        display: block;
        min-height: 50px;
        letter-spacing: 0.02em;
        border: 1px solid #7f7f7f;
    }

    .p-nav-modal__menu:nth-of-type(2) .p-nav-modal__menu-item:nth-of-type(n+2) span {
        font-size: 1.1rem;
    }

    .p-nav-modal__menu:nth-of-type(2) .p-nav-modal__menu-item:nth-of-type(2) {
        width: 100%;
        margin-top: 75px;
    }

    .p-nav-modal__menu:nth-of-type(2) .p-nav-modal__menu-item:nth-of-type(n+3) {
        width: 100%;
        margin-top: 4%;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__block-bottom {
        display: flex;
        flex-flow: row nowrap;
        padding-left: 95px;
        padding-right: 50px;
        position: absolute;
        bottom: 20px;
        width: 100%;
    }
}

@media screen and (max-width: 599px) {
    .p-nav-modal__block-bottom {
        display: none;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__link {
        font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
        font-size: 1.2rem;
    }

    .p-nav-modal__link:nth-of-type(1) {
        width: 240px;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__link-title {
        font-weight: bold;
        margin-bottom: 10px;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__sub-menu {
        margin-top: 35px;
        width: 240px;
        margin-left: auto;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        flex-direction: row-reverse;
    }
}

@media screen and (min-width: 600px) {
    .p-nav-modal__sub-menu-item {
        font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
        font-size: 1.4rem;
    }
}

@media all and (-ms-high-contrast: none) {
    /* IE10 */
}

/* #scloll-change
   -------------------------------------------------------------------------- */
/*doc
---
title: scloll-change
name: lscloll-change
categories: [project]
---

スクロールでナビの色や位置を変更するオブジェクトです。

*/
@media screen and (min-width: 600px) {

    .p-scroll-change--active .p-nav,
    .p-scroll-change .p-nav {
        background-color: #fff;
    }
}

@media screen and (min-width: 600px) {

    .p-scroll-change--active .p-nav__menu-item a,
    .p-scroll-change .p-nav__menu-item a {
        color: #333;
    }
}

@media screen and (min-width: 600px) {

    .p-scroll-change--active .p-nav__language a,
    .p-scroll-change .p-nav__language a {
        color: #a5a5a5;
    }
}

@media screen and (min-width: 600px) {

    .p-scroll-change--active .p-nav__menu-trigger span,
    .p-scroll-change .p-nav__menu-trigger span {
        background-color: #333;
    }
}

@media screen and (min-width: 600px) {

    .p-scroll-change--active .u-over-line-nav::before,
    .p-scroll-change .u-over-line-nav::before {
        background-color: #333;
    }
}

@media screen and (min-width: 600px) {

    .p-scroll-change--active .u-over-line-lang::before,
    .p-scroll-change .u-over-line-lang::before {
        background-color: #333;
    }

    .p-scroll-change--active .u-over-line-lang:hover,
    .p-scroll-change .u-over-line-lang:hover {
        color: #333;
    }
}

@media screen and (min-width: 600px) {

    .p-scroll-change--active .u-over-line-lang--active,
    .p-scroll-change .u-over-line-lang--active {
        color: #333 !important;
    }
}

@media screen and (max-width: 599px) {
    .p-scroll-change--sp-nav-visible .p-nav__menu-trigger span {
        background-color: #333;
    }
}

.p-scroll-change .p-nav__menu-trigger span {
    background-color: #333;
}

@media screen and (max-width: 599px) {
    .p-scroll-change .l-footer__book {
        bottom: 0px;
    }
}

/* #Title
-------------------------------------------------------------------------- */
/*doc
---
title: Title
name: Title
categories: [project]
---

タイトルのオブジェクトです。

*/
@media screen and (min-width: 600px) {
    .p-title--horizontal {
        text-align: center;
    }
}

@media screen and (max-width: 599px) {
    .p-title--horizontal {
        text-align: center;
    }
}

.p-title--horizontal-jp-22 {
    display: block;
}

@media screen and (min-width: 600px) {
    .p-title--horizontal-jp-22 {
        font-size: 2.2rem;
        letter-spacing: 0.1em;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .p-title--horizontal-jp-22 {
        font-size: 1.8rem;
        letter-spacing: 0.1em;
        line-height: 1.3;
    }
}

.p-title--horizontal-jp-24 {
    display: block;
}

@media screen and (min-width: 600px) {
    .p-title--horizontal-jp-24 {
        font-size: 2.4rem;
        letter-spacing: 0.1em;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .p-title--horizontal-jp-24 {
        font-size: 1.8rem;
        letter-spacing: 0.1em;
        line-height: 1.5;
    }
}

.p-title--horizontal-jp-26 {
    display: block;
}

@media screen and (min-width: 600px) {
    .p-title--horizontal-jp-26 {
        font-size: 2.6rem;
        letter-spacing: 0.1em;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .p-title--horizontal-jp-26 {
        font-size: 2.0rem;
        letter-spacing: 0.1em;
        line-height: 1.5;
    }
}

.p-title--horizontal-en {
    display: block;
    font-family: 'EB Garamond', serif;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .p-title--horizontal-en {
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        line-height: 1;
    }
}

@media screen and (max-width: 599px) {
    .p-title--horizontal-en {
        font-size: 1.3rem;
        letter-spacing: 0.05em;
        line-height: 1;
    }
}

.p-title--vertical {
    position: relative;
    text-align: left;
    margin-left: auto;
    margin-right: auto;
}

@media screen and (min-width: 600px) {
    .p-title--vertical {
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        text-orientation: mixed;
    }
}

@media screen and (max-width: 599px) {
    .p-title--vertical {
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        text-orientation: mixed;
    }
}

.p-title--vertical-jp {
    display: block;
}

@media screen and (min-width: 600px) {
    .p-title--vertical-jp {
        font-size: 3rem;
        letter-spacing: 0.1em;
    }
}

@media screen and (max-width: 599px) {
    .p-title--vertical-jp {
        font-size: 2.2rem;
        letter-spacing: 0.1em;
    }
}

.p-title--vertical-en {
    display: block;
    font-family: 'EB Garamond', serif;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .p-title--vertical-en {
        font-size: 1.6rem;
        letter-spacing: 0.1em;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .p-title--vertical-en {
        font-size: 1.3rem;
        letter-spacing: 0.1em;
        line-height: 1;
    }
}

.p-title--subpage-vertical {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    margin: auto;
}

@media screen and (min-width: 600px) {
    .p-title--subpage-vertical {
        bottom: 0;
    }
}

@media screen and (max-width: 599px) {
    .p-title--subpage-vertical {
        bottom: 45px;
    }
}

.p-title--subpage-vertical-jp {
    display: block;
    color: #fff;
}

@media screen and (min-width: 600px) {
    .p-title--subpage-vertical-jp {
        font-size: 2.6rem;
        letter-spacing: 0.1em;
    }
}

@media screen and (max-width: 599px) {
    .p-title--subpage-vertical-jp {
        font-size: 2rem;
        letter-spacing: 0.1em;
    }
}

.p-title--subpage-vertical-en {
    display: block;
    font-family: 'EB Garamond', serif;
    color: #fff;
    opacity: 0.5;
}

@media screen and (min-width: 600px) {
    .p-title--subpage-vertical-en {
        font-size: 1.6rem;
        letter-spacing: 0.1em;
        line-height: 1;
        margin-left: 7px;
    }
}

@media screen and (max-width: 599px) {
    .p-title--subpage-vertical-en {
        font-size: 1.4rem;
        letter-spacing: 0.1em;
        line-height: 1;
        margin-left: 2px;
    }
}

.p-title--fullimage-outer {
    overflow: hidden;
}

.p-title--fullimage {
    position: relative;
}

@media screen and (min-width: 600px) {
    .p-title--fullimage {
        width: 100%;
        height: 100vh;
        overflow: hidden;
    }
}

@media screen and (max-width: 599px) {
    .p-title--fullimage {
        width: 100%;
        height: 100vh;
        overflow: hidden;
    }
}

@media screen and (min-width: 600px) {

    .p-title--fullimage img,
    .p-title--fullimage video {
        position: absolute;
        top: 0;
        left: -100%;
        right: -100%;
        bottom: 0;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
        z-index: -1;
    }
}

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

    .p-title--fullimage img,
    .p-title--fullimage video {
        display: none;
    }
}

.p-title--fullimage-title {
    color: #fff;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: auto;
}

@media screen and (min-width: 600px) {
    .p-title--fullimage-title {
        text-align: center;
    }
}

@media screen and (max-width: 599px) {
    .p-title--fullimage-title {
        -webkit-writing-mode: vertical-rl;
        -ms-writing-mode: tb-rl;
        writing-mode: vertical-rl;
        text-orientation: mixed;
        text-align: left;
    }
}

.p-title--fullimage-title-jp {
    display: block;
}

@media screen and (min-width: 600px) {
    .p-title--fullimage-title-jp {
        font-size: 2.6rem;
        letter-spacing: 0.08em;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .p-title--fullimage-title-jp {
        font-size: 2rem;
        letter-spacing: 0.08em;
        line-height: 1;
    }
}

.p-title--fullimage-title-en {
    display: block;
    font-family: 'EB Garamond', serif;
    opacity: 0.4;
}

@media screen and (min-width: 600px) {
    .p-title--fullimage-title-en {
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        line-height: 1;
    }
}

@media screen and (max-width: 599px) {
    .p-title--fullimage-title-en {
        font-size: 1.4rem;
        letter-spacing: 0.05em;
        line-height: 1;
        position: absolute;
        right: -20px;
    }
}

/* #Readmore
-------------------------------------------------------------------------- */
/*doc
---
title: Readmore
name: Readmore
categories: [project]
---

readmoreボタンのオブジェクトです。

*/
.p-readmore {
    font-family: 'EB Garamond', serif;
    display: block;
    position: relative;
}

@media screen and (min-width: 600px) {
    .p-readmore {
        text-align: right;
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        line-height: 1;
    }
}

@media screen and (max-width: 599px) {
    .p-readmore {
        text-align: right;
        font-size: 1.5rem;
        letter-spacing: 0.05em;
        line-height: 1;
    }
}

@media screen and (min-width: 600px) {
    .p-readmore span::before {
        content: "";
        height: 1px;
        position: absolute;
        top: 12px;
        left: 0px;
        background: #333;
    }

    .p-readmore span::after {
        content: "";
        width: 12px;
        height: 1px;
        position: absolute;
        top: 12px;
        background: #333;
        -webkit-transform-origin: 0px 0.5px;
        transform-origin: 0px 0.5px;
        -webkit-transform: rotate(-150deg);
        transform: rotate(-150deg);
    }
}

@media screen and (max-width: 599px) {
    .p-readmore span::before {
        content: "";
        height: 1px;
        position: absolute;
        top: 12px;
        left: 0px;
        background: #333;
    }

    .p-readmore span::after {
        content: "";
        width: 10px;
        height: 1px;
        position: absolute;
        top: 12px;
        background: #333;
        -webkit-transform-origin: 0px 0.5px;
        transform-origin: 0px 0.5px;
        -webkit-transform: rotate(-150deg);
        transform: rotate(-150deg);
    }
}

@media screen and (min-width: 600px) {
    .p-readmore--long {
        width: 270px;
    }

    .p-readmore--long:hover span::before {
        -webkit-animation: _p-readmore--long-before 0.8s ease forwards 0s;
        animation: _p-readmore--long-before 0.8s ease forwards 0s;
    }

    .p-readmore--long:hover span::after {
        -webkit-animation: _p-readmore--long-after 0.8s ease forwards 0s;
        animation: _p-readmore--long-after 0.8s ease forwards 0s;
    }
}

@media screen and (max-width: 599px) {
    .p-readmore--long {
        width: 175px;
    }
}

.p-readmore--long-motion span::before {
    -webkit-animation: _p-readmore--long-before 0.8s ease forwards 0s;
    animation: _p-readmore--long-before 0.8s ease forwards 0s;
}

.p-readmore--long-motion span::after {
    -webkit-animation: _p-readmore--long-after 0.8s ease forwards 0s;
    animation: _p-readmore--long-after 0.8s ease forwards 0s;
}

@media screen and (min-width: 600px) {
    .p-readmore--long span::before {
        width: 170px;
    }

    .p-readmore--long span::after {
        left: 170px;
    }
}

@media screen and (max-width: 599px) {
    .p-readmore--long span::before {
        width: 95px;
    }

    .p-readmore--long span::after {
        left: 95px;
    }
}

@media screen and (min-width: 600px) {
    .p-readmore--short {
        width: 145px;
    }

    .p-readmore--short:hover span::before {
        -webkit-animation: _p-readmore--short-before 0.7s ease forwards 0s;
        animation: _p-readmore--short-before 0.7s ease forwards 0s;
    }

    .p-readmore--short:hover span::after {
        -webkit-animation: _p-readmore--short-after 0.7s ease forwards 0s;
        animation: _p-readmore--short-after 0.7s ease forwards 0s;
    }
}

@media screen and (max-width: 599px) {
    .p-readmore--short {
        width: 125px;
    }
}

@media screen and (min-width: 600px) {
    .p-readmore--short span::before {
        width: 60px;
    }

    .p-readmore--short span::after {
        left: 60px;
    }
}

@media screen and (max-width: 599px) {
    .p-readmore--short span::before {
        width: 47px;
    }

    .p-readmore--short span::after {
        left: 47px;
    }
}

@-webkit-keyframes _p-readmore--long-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 170px;
        opacity: 1;
    }
}

@keyframes _p-readmore--long-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 170px;
        opacity: 1;
    }
}

@-webkit-keyframes _p-readmore--long-after {
    from {
        left: 0;
        opacity: 0;
    }

    to {
        left: 170px;
        opacity: 1;
    }
}

@keyframes _p-readmore--long-after {
    from {
        left: 0;
        opacity: 0;
    }

    to {
        left: 170px;
        opacity: 1;
    }
}

@-webkit-keyframes _p-readmore--short-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 60px;
        opacity: 1;
    }
}

@keyframes _p-readmore--short-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 60px;
        opacity: 1;
    }
}

@-webkit-keyframes _p-readmore--short-after {
    from {
        left: 0;
        opacity: 0;
    }

    to {
        left: 60px;
        opacity: 1;
    }
}

@keyframes _p-readmore--short-after {
    from {
        left: 0;
        opacity: 0;
    }

    to {
        left: 60px;
        opacity: 1;
    }
}

/* #Pagenav
-------------------------------------------------------------------------- */
/*doc
---
title: Pagenav
name: Pagenav
categories: [project]
---

ページ内スクロールのオブジェクトです。

*/
@media screen and (min-width: 600px) {
    .p-pagenav {
        font-size: 1.4rem;
        line-height: 1;
        display: flex;
        flex-flow: row nowrap;
        justify-content: center;
        margin-top: 130px;
    }
}

@media screen and (max-width: 599px) {
    .p-pagenav {
        font-size: 1.4rem;
        line-height: 1;
        width: 100%;
        margin-top: 70px;
    }
}

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

    .p-pagenav-item:nth-of-type(n+2),
    .p-pagenav-item--two:nth-of-type(n+2),
    .p-pagenav-item--three:nth-of-type(n+2),
    .p-pagenav-item--four:nth-of-type(n+2) {
        margin-top: 45px;
        letter-spacing: 0.03em;
        line-height: 1.6;
    }
}

@media screen and (min-width: 600px) {
    .p-pagenav-item--two:nth-of-type(n+2) {
        margin-left: 6%;
    }
}

@media screen and (min-width: 600px) {
    .p-pagenav-item--three:nth-of-type(n+2) {
        margin-left: 4%;
    }
}

@media screen and (min-width: 600px) {
    .p-pagenav-item--four:nth-of-type(n+2) {
        margin-left: 2%;
    }
}

.p-pagenav-item a,
.p-pagenav-item--two a,
.p-pagenav-item--three a,
.p-pagenav-item--four a {
    display: block;
    position: relative;
}

@media screen and (min-width: 600px) {

    .p-pagenav-item a,
    .p-pagenav-item--two a,
    .p-pagenav-item--three a,
    .p-pagenav-item--four a {
        display: flex;
        flex-flow: row nowrap;
        padding-bottom: 20px;
        line-height: 1.4;
        padding-left: 15px;
        padding-right: 15px;
    }

    .p-pagenav-item a::before,
    .p-pagenav-item--two a::before,
    .p-pagenav-item--three a::before,
    .p-pagenav-item--four a::before {
        transition: 0.5s;
        width: 0%;
        content: "";
        height: 1px;
        position: absolute;
        bottom: 0px;
        left: 0px;
        background-color: #a5a5a5;
    }
}

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

    .p-pagenav-item a,
    .p-pagenav-item--two a,
    .p-pagenav-item--three a,
    .p-pagenav-item--four a {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        padding-bottom: 15px;
        padding-right: 4.71014%;
        padding-left: 4.71014%;
    }

    .p-pagenav-item a::before,
    .p-pagenav-item--two a::before,
    .p-pagenav-item--three a::before,
    .p-pagenav-item--four a::before {
        width: 100%;
        content: "";
        height: 1px;
        position: absolute;
        bottom: 0px;
        left: 0px;
        background-color: #a5a5a5;
    }
}

@media screen and (min-width: 600px) {

    .p-pagenav-item a:hover::before,
    .p-pagenav-item--two a:hover::before,
    .p-pagenav-item--three a:hover::before,
    .p-pagenav-item--four a:hover::before {
        width: 100%;
    }
}

.p-pagenav-item-cursol {
    position: relative;
    width: 40px;
    margin-left: 30px;
}

.p-pagenav-item-cursol::before {
    width: 100%;
    content: "";
    height: 1px;
    position: absolute;
    top: 10px;
    left: 0px;
    background-color: #a5a5a5;
}

.p-pagenav-item-cursol::after {
    content: "";
    width: 12px;
    height: 1px;
    position: absolute;
    top: 10px;
    left: 100%;
    background-color: #a5a5a5;
    -webkit-transform-origin: 0px 0.5px;
    transform-origin: 0px 0.5px;
    -webkit-transform: rotate(-150deg);
    transform: rotate(-150deg);
}

/* #Column-list
-------------------------------------------------------------------------- */
/*doc
---
title: Column-list
name: Column-list
categories: [project]
---

城崎綴り一覧リストのオブジェクトです。

*/
@media screen and (min-width: 600px) {
    .p-column-list {
        width: 86.11111%;
        margin: 0 auto;
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
    }
}

.p-column-list-item {
    background: #fff;
    padding: 1% 1.5%;
}

.p-column-list-item img {
    width: 100%;
    height: auto;
    transition: 0.8s;
}

@media screen and (min-width: 600px) {
    .p-column-list-item {
        width: 48.3871%;
    }

    .p-column-list-item:nth-of-type(n+3) {
        margin-top: 6vw;
    }
}

@media screen and (max-width: 599px) {
    .p-column-list-item:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .p-column-list__link {
        display: block;
        overflow: hidden;
        position: relative;
    }

    .p-column-list__link:hover img {
        opacity: 0.5;
        -webkit-filter: blur(4px);
        filter: blur(4px);
        -webkit-transform: scale(1.02);
        transform: scale(1.02);
    }

    .p-column-list__link:hover .p-column-list__text {
        visibility: visible;
        opacity: 1;
    }
}

@media screen and (min-width: 600px) {
    .p-column-list__text {
        color: #333333;
        font-size: 2.4rem;
        /* position: absolute; */
        /* left: 0px; */
        /* right: 0px; */
        /* bottom: 8%; */
        /* margin: auto; */
        width: 88%;
        line-height: 1.5;
        transition: 0.8s;
        text-align: center;
        margin: 4% 0 2% 0;
        font-weight: 600;
        line-height: 36px;
        letter-spacing: 2.4000000953674316px;
        text-align: center;
    }
}

@media screen and (max-width: 599px) {
    .p-column-list__text {
        font-size: 1.4rem;
        margin-top: 15px;
        text-align: center;
    }
}

.p-column-list__date {
    font-family: 'EB Garamond', serif;
    font-weight: 600;
    line-height: 36px;
    letter-spacing: 2.4000000953674316px;
    text-align: center;
    margin-top: 2%;
    color: #0E0E0E;
}

@media screen and (min-width: 600px) {
    .p-column-list__date {
        font-size: 1.6rem;
    }
}

@media screen and (max-width: 599px) {
    .p-column-list__date {
        font-size: 1.2rem;
        color: #7f7f7f;
        margin-top: 0;
    }
}

.p-column-list__readmore {
    margin-top: 4%;
}

@media screen and (min-width: 600px) {
    .p-column-list__readmore {
        margin-right: 0;
        margin-left: auto;
        margin-top: 4%;
    }
}

@media screen and (max-width: 599px) {
    .p-column-list__readmore {
        margin-left: auto;
        margin-right: 0;
        margin-top: 8%;
    }
}

/* #Datecat
-------------------------------------------------------------------------- */
/*doc
---
title: Datecat
name: Datecat
categories: [project]
---

一覧リストの日付・カテゴリーのオブジェクトです。

*/
.p-datecat {
    color: #7f7f7f;
}

.p-datecat__date {
    font-family: 'EB Garamond', serif;
}

@media screen and (min-width: 600px) {
    .p-datecat__date {
        font-size: 1.6rem;
    }
}

@media screen and (max-width: 599px) {
    .p-datecat__date {
        font-size: 1.4rem;
    }
}

.p-datecat__category {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

@media screen and (min-width: 600px) {
    .p-datecat__category {
        font-size: 1.4rem;
    }
}

@media screen and (max-width: 599px) {
    .p-datecat__category {
        font-size: 1.3rem;
    }
}

/* #News-list
-------------------------------------------------------------------------- */
/*doc
---
title: News-list
name: News-list
categories: [project]
---

お知らせ一覧リストのオブジェクトです。

*/
.p-news-list {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

@media screen and (min-width: 600px) {
    .p-news-list {
        display: flex;
        flex-flow: row wrap;
        width: 86.11111%;
        margin-left: auto;
        margin-right: auto;
        font-size: 1.4rem;
        letter-spacing: 0.05em;
    }
}

@media screen and (max-width: 599px) {
    .p-news-list {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .p-news-list__item {
        width: 30%;
        margin-right: 5%;
    }

    .p-news-list__item:nth-of-type(3n) {
        margin-right: 0;
    }

    .p-news-list__item:nth-of-type(n+4) {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .p-news-list__item:nth-of-type(n+2) {
        margin-top: 20px;
    }

    .p-news-list--top .p-news-list__item:nth-of-type(n+4) {
        display: none;
    }
}

.p-news-list__anker {
    display: block;
    /* display: flex; */
    /* flex-flow: row nowrap; */
    /* justify-content: space-between; */
    padding: 3%;
    background: #fff;
}

@media screen and (min-width: 600px) {
    .p-news-list__anker {
        transition: 0.5s;
    }

    .p-news-list__anker:hover img {
        -webkit-transform: scale(1.1);
        transform: scale(1.1);
    }

    .p-news-list__anker:hover .p-news-list__text {
        opacity: 0.6;
    }
}

.p-news-list__image {
    transition: .p-news-list__image _duration-slow;
}

@media screen and (min-width: 600px) {
    .p-news-list__image {
        overflow: hidden;
    }

    .p-news-list__image img {
        width: 100%;
        height: auto;
    }
}

@media screen and (max-width: 599px) {
    .p-news-list__image {}

    .p-news-list__image img {
        width: 100%;
        height: auto;
    }
}

.p-news-list__text {
    transition: 0.5s;
    margin-top: 4%;
}

@media screen and (min-width: 600px) {
    .p-news-list__text {
        width: 100%;
        letter-spacing: 0.02em;
    }
}

@media screen and (max-width: 599px) {
    .p-news-list__text {
        width: 100%;
    }
}

.p-news-list__tit {
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 26px;
    letter-spacing: 0.2800000011920929px;
    text-align: left;
    min-height: 52px;
    color: #333333;
}

.p-news-list__date-category {
    color: #7f7f7f;
}

@media screen and (min-width: 600px) {
    .p-news-list__date-category {
        margin-bottom: 10px;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .p-news-list__date-category {
        font-size: 1.3rem;
    }
}

/* #Paging
-------------------------------------------------------------------------- */
/*doc
---
title: Paging
name: Paging
categories: [project]
---

戻る/次へボタンのコンポーネント

*/
@media screen and (min-width: 600px) {
    .p-paging__next-prev {
        width: 69.44444%;
        min-width: 1000px;
        margin-left: auto;
        margin-right: auto;
        margin-top: 45px;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
    }
}

@media screen and (max-width: 599px) {
    .p-paging__next-prev {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        margin-top: 40px;
    }
}

.p-paging__next-prev-item a {
    position: relative;
    color: #7f7f7f;
}

@media screen and (min-width: 600px) {
    .p-paging__next-prev-item {
        font-size: 1.4rem;
    }

    .p-paging__next-prev-item:nth-of-type(1),
    .p-paging__next-prev-item:nth-of-type(3) {
        font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
        width: 400px;
    }

    .p-paging__next-prev-item:nth-of-type(1) a,
    .p-paging__next-prev-item:nth-of-type(3) a {
        display: block;
        transition: 0.5s;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
    }

    .p-paging__next-prev-item:nth-of-type(1) a:hover,
    .p-paging__next-prev-item:nth-of-type(3) a:hover {
        color: #333;
    }

    .p-paging__next-prev-item:nth-of-type(1) a:hover .p-paging__cursol-prev::before,
    .p-paging__next-prev-item:nth-of-type(1) a:hover .p-paging__cursol-next::before {
        -webkit-animation: _p-paging__cursol-prev-before 0.6s ease forwards 0s;
        animation: _p-paging__cursol-prev-before 0.6s ease forwards 0s;
    }

    .p-paging__next-prev-item:nth-of-type(1) a:hover .p-paging__cursol-prev::after,
    .p-paging__next-prev-item:nth-of-type(1) a:hover .p-paging__cursol-next::after {
        -webkit-animation: _p-paging__cursol-prev-after 0.6s ease forwards 0s;
        animation: _p-paging__cursol-prev-after 0.6s ease forwards 0s;
    }

    .p-paging__next-prev-item:nth-of-type(2) {
        font-family: 'Open Sans', serif;
    }

    .p-paging__next-prev-item:nth-of-type(3) a:hover .p-paging__cursol-next::before {
        -webkit-animation: _p-paging__cursol-next-before 0.6s ease forwards 0s;
        animation: _p-paging__cursol-next-before 0.6s ease forwards 0s;
    }

    .p-paging__next-prev-item:nth-of-type(3) a:hover .p-paging__cursol-next::after {
        -webkit-animation: _p-paging__cursol-next-after 0.6s ease forwards 0s;
        animation: _p-paging__cursol-next-after 0.6s ease forwards 0s;
    }
}

@media screen and (max-width: 599px) {
    .p-paging__next-prev-item {
        font-family: 'Open Sans', serif;
    }

    .p-paging__next-prev-item:nth-of-type(1),
    .p-paging__next-prev-item:nth-of-type(3) {
        width: 47px;
    }
}

.p-paging__cursol-prev,
.p-paging__cursol-next {
    display: block;
    position: relative;
}

@media screen and (min-width: 600px) {

    .p-paging__cursol-prev,
    .p-paging__cursol-next {
        width: 60px;
    }

    .p-paging__cursol-prev::before,
    .p-paging__cursol-next::before {
        width: 60px;
        content: "";
        height: 1px;
        position: absolute;
        top: 12px;
        right: 0px;
        background: #7f7f7f;
    }

    .p-paging__cursol-prev::after,
    .p-paging__cursol-next::after {
        left: 0px;
        content: "";
        width: 12px;
        height: 1px;
        position: absolute;
        top: 12px;
        background: #7f7f7f;
        -webkit-transform-origin: 0px 0.5px;
        transform-origin: 0px 0.5px;
        -webkit-transform: rotate(-30deg);
        transform: rotate(-30deg);
    }
}

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

    .p-paging__cursol-prev,
    .p-paging__cursol-next {
        width: 47px;
        height: 20px;
    }

    .p-paging__cursol-prev::before,
    .p-paging__cursol-next::before {
        width: 47px;
        content: "";
        height: 1px;
        position: absolute;
        top: 12px;
        left: 0px;
        background: #7f7f7f;
    }

    .p-paging__cursol-prev::after,
    .p-paging__cursol-next::after {
        left: 0px;
        content: "";
        width: 10px;
        height: 1px;
        position: absolute;
        top: 12px;
        background: #7f7f7f;
        -webkit-transform-origin: 0px 0.5px;
        transform-origin: 0px 0.5px;
        -webkit-transform: rotate(-30deg);
        transform: rotate(-30deg);
    }
}

@media screen and (min-width: 600px) {
    .p-paging__cursol-next::before {
        left: 0px;
        right: auto;
    }

    .p-paging__cursol-next::after {
        left: 60px;
        -webkit-transform: rotate(-150deg);
        transform: rotate(-150deg);
    }
}

@media screen and (max-width: 599px) {
    .p-paging__cursol-next::before {
        left: 0px;
        right: auto;
    }

    .p-paging__cursol-next::after {
        left: 47px;
        -webkit-transform: rotate(-150deg);
        transform: rotate(-150deg);
    }
}

@media screen and (min-width: 600px) {
    .p-paging__title {
        display: block;
        width: 300px;
    }
}

@media screen and (max-width: 599px) {
    .p-paging__title {
        display: none;
    }
}

@-webkit-keyframes _p-paging__cursol-prev-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 60px;
        opacity: 1;
    }
}

@keyframes _p-paging__cursol-prev-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 60px;
        opacity: 1;
    }
}

@-webkit-keyframes _p-paging__cursol-prev-after {
    from {
        left: 60px;
        opacity: 0;
    }

    to {
        left: 0px;
        opacity: 1;
    }
}

@keyframes _p-paging__cursol-prev-after {
    from {
        left: 60px;
        opacity: 0;
    }

    to {
        left: 0px;
        opacity: 1;
    }
}

@-webkit-keyframes _p-paging__cursol-next-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 60px;
        opacity: 1;
    }
}

@keyframes _p-paging__cursol-next-before {
    from {
        width: 0;
        opacity: 0;
    }

    to {
        width: 60px;
        opacity: 1;
    }
}

@-webkit-keyframes _p-paging__cursol-next-after {
    from {
        left: 0px;
        opacity: 0;
    }

    to {
        left: 60px;
        opacity: 1;
    }
}

@keyframes _p-paging__cursol-next-after {
    from {
        left: 0px;
        opacity: 0;
    }

    to {
        left: 60px;
        opacity: 1;
    }
}

/* #Pagination
-------------------------------------------------------------------------- */
/*doc
---
title: Pagination
name: Pagination
categories: [project]
---

ページ番号付きページネーションのコンポーネント

*/
.pagination {
    font-family: 'Open Sans', serif;
    position: relative;
}

@media screen and (min-width: 600px) {
    .pagination {
        margin-top: 80px;
    }
}

@media screen and (max-width: 599px) {
    .pagination {
        margin-top: 60px;
    }
}

.pagination-box {
    display: inline-block;
    display: flex;
    flex-flow: row nowrap;
    justify-content: center;
}

.pagination span,
.pagination a {
    display: block;
    text-decoration: none;
    width: auto;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {

    .pagination span,
    .pagination a {
        padding: 10px 20px 10px 20px;
    }
}

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

    .pagination span,
    .pagination a {
        padding: 8px 12px 8px 12px;
    }
}

.pagination .page-of {
    display: none !important;
}

@media screen and (min-width: 600px) {

    .pagination .inactive,
    .pagination .current,
    .pagination .page-num-current {
        font-size: 1.6rem;
        line-height: 1.4;
    }
}

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

    .pagination .inactive,
    .pagination .current,
    .pagination .page-num-current {
        font-size: 1.4rem;
        line-height: 1.6;
    }
}

@media screen and (min-width: 600px) {
    .pagination .cursol {
        font-size: 2rem;
        line-height: 1;
    }
}

@media screen and (max-width: 599px) {
    .pagination .cursol {
        font-size: 1.8rem;
        line-height: 1;
    }
}

.pagination a:hover,
.pagination .current,
.pagination .page-num-current {
    color: #333;
}

.s-top-news {
    margin-top: 5%;
}

@media screen and (min-width: 600px) {
    .s-top-news {
        padding-bottom: 150px;
        width: 100%;
    }
}

@media screen and (max-width: 599px) {
    .s-top-news {
        padding-bottom: 80px;
        width: 100%;
        margin-top: 13%;
    }
}

@media screen and (min-width: 600px) {
    .s-top-news__title {
        margin-bottom: 60px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-news__title {
        margin-bottom: 30px;
    }
}

.s-top-concept {
    background-color: #fff;
    position: relative;
}

.s-top-concept__bg {
    position: absolute;
    top: 42%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.s-top-concept__bg>img {}

@media screen and (min-width: 600px) {
    .s-top-concept {
        padding-top: 120px;
        padding-bottom: 130px;
        width: 100%;
    }
}

@media screen and (max-width: 599px) {
    .s-top-concept {
        padding-top: 80px;
        padding-bottom: 80px;
        width: 100%;
    }
}

.s-top-concept__title {
    position: relative;
    z-index: 1;
}

@media screen and (min-width: 600px) {
    .s-top-concept__title {
        margin-bottom: 45px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-concept__title {
        margin-bottom: 30px;
    }
}

.s-top-concept__overview {
    position: relative;
    z-index: 1;
}

@media screen and (min-width: 600px) {
    .s-top-concept__overview {
        text-align: center;
        font-size: 1.6rem;
        letter-spacing: 0.08em;
        line-height: 2.6;
        width: 87.5%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-top-concept__overview {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        text-align: center;
        letter-spacing: 0.04em;
        line-height: 2;
        margin-bottom: 35px;
    }

    .s-top-concept__overview br {
        display: none;
    }

    .s-top-concept__overview span {
        display: block;
    }
}

@media screen and (min-width: 600px) {
    .s-top-concept__readmore {
        margin: 0 auto;
    }
}

@media screen and (max-width: 599px) {
    .s-top-concept__readmore {
        margin: 0 auto;
    }
}

@media screen and (min-width: 600px) {
    .s-top-facilities {
        position: relative;
        padding-top: 83px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-facilities {
        padding-top: 80px;
        position: relative;
    }
}

@media screen and (min-width: 600px) {

    .s-top-facilities__title,
    .s-top-cuisine__title {
        position: absolute;
        right: 6.94444%;
        top: 105px;
        z-index: 1;
    }
}

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

    .s-top-facilities__title,
    .s-top-cuisine__title {
        position: absolute;
        right: 4.71014%;
        top: 80px;
        z-index: 1;
    }
}

.s-top-facilities__title-jp span {
    color: #fff;
}

@media screen and (min-width: 600px) {

    .s-top-facilities__image-block,
    .s-top-cuisine__image-block {
        position: relative;
        width: 87.5%;
        height: 660px;
        overflow: hidden;
        margin-right: 0;
        margin-left: auto;
        margin-top: 152px;
    }

    .s-top-facilities__image-block img,
    .s-top-cuisine__image-block img {
        top: 0;
        left: -100%;
        right: -100%;
        bottom: 0;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
    }
}

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

    .s-top-facilities__image-block,
    .s-top-cuisine__image-block {
        position: relative;
        width: 100%;
        overflow: hidden;
        margin-top: 95px;
    }

    .s-top-facilities__image-block img,
    .s-top-cuisine__image-block img {
        width: 100%;
        height: auto;
    }
}

.s-top-facilities__text-box,
.s-top-cuisine__text-box {
    position: relative;
    z-index: 1;
}

@media screen and (min-width: 600px) {

    .s-top-facilities__text-box,
    .s-top-cuisine__text-box {
        margin-top: -210px;
        width: 470px;
        height: 260px;
        padding: 65px 65px 0px;
    }

    .s-top-facilities__text-box p,
    .s-top-cuisine__text-box p {
        margin-bottom: 30px;
    }
}

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

    .s-top-facilities__text-box,
    .s-top-cuisine__text-box {
        background-color: #fff;
        margin-top: -30px;
        width: 90.57971%;
        padding: 35px;
    }

    .s-top-facilities__text-box p,
    .s-top-cuisine__text-box p {
        margin-bottom: 15px;
        line-height: 1.8;
    }
}

.s-top-cuisine {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-top-cuisine {
        padding-top: 83px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-cuisine {
        padding-top: 80px;
        position: relative;
    }
}

@media screen and (min-width: 600px) {

    .s-top-facilities__title,
    .s-top-cuisine__title {
        position: absolute;
        right: 6.94444%;
        top: 105px;
        z-index: 1;
    }
}

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

    .s-top-facilities__title,
    .s-top-cuisine__title {
        position: absolute;
        right: 4.71014%;
        top: 80px;
        z-index: 1;
    }
}

@media screen and (min-width: 600px) {
    .s-top-cuisine__title {
        right: auto;
        left: 6.94444%;
    }
}

@media screen and (max-width: 599px) {
    .s-top-cuisine__title {
        right: auto;
        left: 9.05797%;
    }
}

.s-top-cuisine__title-jp span {
    color: #fff;
}

@media screen and (min-width: 600px) {
    .s-top-cuisine__image-block {
        margin-left: 0;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-top-cuisine__text-box {
        margin-left: auto;
        margin-right: 0;
        padding: 50px 70px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-cuisine__text-box {
        margin-left: auto;
        margin-right: 0;
    }
}

.s-top-column {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-top-column {
        padding-top: 150px;
        padding-bottom: 55px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-column {
        padding-top: 8%;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-top-column__title {
        margin-bottom: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-column__title {
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-top-column__overview {
        text-align: center;
        padding-left: 5%;
        padding-right: 5%;
        margin-bottom: 70px;
    }
}

@media screen and (max-width: 599px) {
    .s-top-column__overview {
        margin-bottom: 40px;
    }
}

/* #Concept
   -------------------------------------------------------------------------- */
/*doc
---
title: Concept
name: Concept
categories: [scope]
---

西村屋の想い（concept）用のコンポーネントです。

*/
@media screen and (max-width: 599px) {
    .s-concept__mainimage {
        background: url(../image/main_sp.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__maintitle {
        width: 75px;
        height: 180px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__maintitle {
        width: calc(115px / 2);
        height: calc(270px / 2);
    }
}

@media screen and (max-width: 599px) {
    .s-concept__bg-about-nishimuraya {
        background: url(../image/image-1_sp.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__title-aboout-nishimuraya {
        width: 280px;
        height: 65px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__title-aboout-nishimuraya {
        width: calc(50px / 2);
        height: calc(415px / 2);
    }
}

@media screen and (max-width: 599px) {
    .s-concept__bg-about-concept {
        background: url(../image/image-2_sp.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__title-about-concept {
        width: 500px;
        height: 65px;
    }

    .s-concept__title-about-concept br {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__title-about-concept {
        width: calc(110px / 2);
        height: calc(540px / 2);
    }

    .s-concept__title-about-concept .p-title--fullimage-title-jp {
        line-height: 1.3;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head {
        display: flex;
        flex-flow: row wrap;
        align-items: flex-start;
        position: relative;
        margin-top: 95px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head {
        display: flex;
        flex-flow: row wrap;
        align-items: flex-start;
        position: relative;
        margin-top: 60px;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--a {
        width: 86.11111%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {

    .s-concept__head--b,
    .s-concept__head--c,
    .s-concept__head--d {
        width: 80.55556%;
        margin-left: 6.94444%;
        margin-right: auto;
    }
}

.s-concept__head-title {
    position: relative;
    z-index: 1;
}

.s-concept__head-title-h {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-orientation: mixed;
    text-align: left;
}

@media screen and (min-width: 600px) {
    .s-concept__head-title-h {
        font-size: 2.4rem;
        letter-spacing: 0.1em;
        line-height: 1.6;
        padding-top: 40px;
        margin-left: 0;
        margin-right: auto;
        padding-left: 28px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head-title-h {
        font-size: 1.7rem;
        letter-spacing: 0.1em;
        line-height: 1.6;
        padding-top: 22px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--a-title {
        width: 135px;
        height: 400px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--a-title {
        width: calc(170px / 2);
        height: calc(550px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--b-title {
        width: 135px;
        height: 400px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--b-title {
        width: calc(170px / 2);
        height: calc(545px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--c-title {
        width: 135px;
        height: 345px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--c-title {
        width: calc(170px / 2);
        height: calc(460px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--d-title {
        width: 135px;
        height: 430px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--d-title {
        width: calc(170px / 2);
        height: calc(590px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head-image {
        height: 500px;
        margin-top: 40px;
        position: relative;
        overflow: hidden;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head-image {
        height: 300px;
        width: 100%;
        margin-top: 40px;
        position: relative;
        overflow: hidden;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--a-image {
        width: calc(100% - 135px + 60px);
        margin-left: -60px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--a-image {
        margin-left: calc(-170px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--b-image {
        width: calc(100% - 135px + 60px);
        margin-right: -60px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--b-image {
        margin-right: calc(-170px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--c-image {
        width: calc(100% - 135px + 40px);
        margin-left: -40px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--c-image {
        margin-left: calc(-170px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head--d-image {
        width: calc(100% - 135px + 60px);
        margin-right: -60px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head--d-image {
        margin-right: calc(-170px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-concept__head-image img {
        position: absolute;
        top: 0;
        left: -100%;
        right: -100%;
        bottom: 0;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head-image img {
        position: absolute;
        top: 0;
        left: -100%;
        right: -100%;
        bottom: 0;
        margin: auto;
        width: 100vw;
        height: 72vw;
        min-width: 138vw;
        min-height: 100vw;
    }
}

.s-concept__head-caption {
    font-size: 1.2rem;
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    line-height: 1;
    color: #7f7f7f;
    letter-spacing: 0.05em;
}

@media screen and (min-width: 600px) {
    .s-concept__head-caption {
        margin-top: 15px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__head-caption {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        text-align: right;
        margin-top: 10px;
    }
}

@media screen and (min-width: 600px) {

    .s-concept__head--a-caption,
    .s-concept__head--c-caption {
        margin-left: auto;
        margin-right: 0;
    }
}

@media screen and (min-width: 600px) {

    .s-concept__head--b-caption,
    .s-concept__head--d-caption {
        margin-left: 0;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__content {
        /* width: 75%; */
        margin-left: auto;
        margin-right: auto;
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
        background: #fff;
        padding: 2%;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__content {
        width: 100%;
        margin-left: auto;
        margin-right: auto;
        /* margin-top: 35px; */
        margin-bottom: 10%;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__content-image {
        width: 42.2963%;
    }

    .s-concept__content-image img {
        width: 100%;
        height: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__content-image img {
        width: 100%;
        height: auto;
    }
}

.s-concept__content__caption {
    font-size: 1.2rem;
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    line-height: 1;
    color: #7f7f7f;
    letter-spacing: 0.05em;
}

@media screen and (min-width: 600px) {
    .s-concept__content__caption {
        margin-top: 20px;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__content__caption {
        font-size: 1.2rem;
        margin-top: 10px;
    }
}

@media screen and (min-width: 600px) {
    .s-concept__content-text {
        width: 54.2963%;
        line-height: 1.8;
    }
}

@media screen and (max-width: 599px) {
    .s-concept__content-text {
        line-height: 1.9;
        margin-top: 30px;
    }
}

/* #Facilities
   -------------------------------------------------------------------------- */
/*doc
---
title: Facilities
name: Facilities
categories: [scope]
---

施設のご案内（facilities）用のコンポーネントです。

*/
@media screen and (max-width: 599px) {
    .s-facilities__mainimage {
        background: url(../image/main_sp1.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__maintitle {
        width: 75px;
        height: 180px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__maintitle {
        width: calc(115px / 2);
        height: calc(280px / 2);
    }
}

.s-facilities__map {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-facilities__map {
        width: 75%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__map-scroll {
        width: 100%;
        overflow-x: scroll;
        padding-left: 20px;
        padding-right: 20px;
        padding-bottom: 30px;
    }

    .s-facilities__map-scroll::-webkit-scrollbar {
        background-color: #dadada;
        height: 5px;
    }

    .s-facilities__map-scroll::-webkit-scrollbar-thumb {
        background-color: #b9af96;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__map-image {
        margin-top: 30px;
        max-width: 100%;
        height: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__map-image {
        width: 600px;
        height: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__map-text-box {
        width: 64.81481%;
        position: absolute;
        top: 0;
        right: 0;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__map-text-box {
        margin-top: 50px;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__map-text {
        line-height: 1.9;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__map-text {
        line-height: 1.9;
    }

    .s-facilities__map-text span {
        display: block;
    }
}

.s-facilities__map-link {
    font-size: 1.4rem;
    letter-spacing: 0.03em;
    line-height: 1;
}

@media screen and (min-width: 600px) {
    .s-facilities__map-link {
        text-align: right;
        margin-top: 20px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__map-link {
        text-align: left;
        margin-top: 35px;
    }

    .s-facilities__map-link a {
        display: inline-block;
        padding-bottom: 4px;
        border-bottom: 1px solid #333;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction {
        margin-top: 30px;
        padding-top: 80px;
        width: 86.11111%;
        margin-left: auto;
        margin-right: auto;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: center;
    }

    .s-facilities__introduction:nth-of-type(2n+2) {
        flex-direction: row-reverse;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }

    .s-facilities__introduction:nth-of-type(n+2) {
        margin-top: 50px;
    }
}

.s-facilities__introduction-image {
    position: relative;
}

.s-facilities__introduction-image img {
    width: 100%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction-image {
        width: 56.45161%;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction-image {
        padding-top: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction-text-block {
        width: 38.70968%;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction-text-block {
        margin-top: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction-title {
        font-size: 2.4rem;
        padding-bottom: 22px;
        border-bottom: 1px solid #a5a5a5;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction-title {
        font-size: 1.7rem;
        padding-bottom: 15px;
        border-bottom: 1px solid #a5a5a5;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction-text {
        padding-top: 22px;
        line-height: 1.8;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction-text {
        font-size: 1.4rem;
        padding-top: 22px;
        line-height: 1.8;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction-hours {
        margin-top: 30px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction-hours {
        margin-top: 30px;
    }
}

.s-facilities__introduction-hours-item {
    color: #7f7f7f;
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    letter-spacing: 0.04em;
}

@media screen and (min-width: 600px) {
    .s-facilities__introduction-hours-item {
        font-size: 1.4rem;
        line-height: 1.6;
    }

    .s-facilities__introduction-hours-item br {
        display: none;
    }

    .s-facilities__introduction-hours-item:nth-of-type(n+2) {
        margin-top: 5px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__introduction-hours-item {
        font-size: 1.3rem;
        line-height: 1.6;
    }

    .s-facilities__introduction-hours-item:nth-of-type(n+2) {
        margin-top: 10px;
    }
}

.s-facilities__mind {
    text-align: center;
    background-color: #fff;
}

@media screen and (min-width: 600px) {
    .s-facilities__mind {
        margin-top: 150px;
        padding-top: 80px;
        padding-bottom: 80px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__mind {
        margin-top: 60px;
        padding-left: 4.71014%;
        padding-right: 4.71014%;
        padding-top: 60px;
        padding-bottom: 60px;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__mind-inner {
        max-width: 860px;
        padding-left: 30px;
        margin-right: 30px;
        margin-left: auto;
        margin-right: auto;
    }
}

.s-facilities__mind-title {
    display: block;
    text-align: center;
}

@media screen and (min-width: 600px) {
    .s-facilities__mind-title {
        font-size: 2.4rem;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__mind-title {
        font-size: 1.7rem;
    }
}

.s-facilities__mind-hr {
    border: none;
    border-bottom: 1px solid #7f7f7f;
    width: 50px;
    margin-left: auto;
    margin-right: auto;
}

@media screen and (min-width: 600px) {
    .s-facilities__mind-hr {
        margin-top: 40px;
        margin-bottom: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__mind-hr {
        margin-top: 30px;
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__mind-text {
        line-height: 2;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__mind-text {
        line-height: 2;
    }

    .s-facilities__mind-text br {
        display: none;
    }
}

@media screen and (min-width: 600px) {
    .s-facilities__mind-profile-text {
        font-size: 1.3rem;
        margin-top: 45px;
        line-height: 2;
    }
}

@media screen and (max-width: 599px) {
    .s-facilities__mind-profile-text {
        font-size: 1.2rem;
        margin-top: 30px;
        font-size: 1.2rem;
        line-height: 2;
        letter-spacing: 0.02em;
    }

    .s-facilities__mind-profile-text br {
        display: none;
    }

    .s-facilities__mind-profile-text span {
        display: block;
    }
}

/* #Cuisine
   -------------------------------------------------------------------------- */
/*doc
---
title: Cuisine
name: Cuisine
categories: [scope]
---

季節のお料理（cuisine）用のコンポーネントです。

*/
@media screen and (max-width: 599px) {
    .s-cuisine__mainimage {
        background: url(../image/main_sp2.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__maintitle {
        width: 75px;
        height: 180px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__maintitle {
        width: calc(115px / 2);
        height: calc(270px / 2);
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__bg-fullcourse {
        background: url(../image/image-1_sp1.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__title-fullcourse {
        width: 240px;
        height: 60px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__title-fullcourse {
        width: calc(45px / 2);
        height: calc(310px / 2);
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__bg-lunch {
        background: url(../image/image-2_sp1.jpg) center center/cover no-repeat scroll;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__title-lunch {
        width: 240px;
        height: 60px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__title-lunch {
        width: calc(55px / 2);
        height: calc(320px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu {
        margin-top: 140px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu {
        margin-top: 40px;
    }
}

.s-cuisine__menu-item {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-item {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: center;
        width: 75%;
        margin-left: auto;
        margin-right: auto;
        height: 335px;
    }

    .s-cuisine__menu-item:nth-of-type(n+2) {
        margin-top: 60px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-item {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }

    .s-cuisine__menu-item:nth-of-type(n+2) {
        margin-top: 30px;
    }
}

.s-cuisine__menu-image {
    position: relative;
    overflow: hidden;
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-image {
        width: 50%;
        height: 335px;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-image img {
        position: absolute;
        top: 0;
        left: -100%;
        right: -100%;
        bottom: 0;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-image img {
        width: 100%;
        height: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-text-box {
        width: 50%;
        padding-left: 3.7037%;
        padding-right: 3.7037%;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-text-box {
        padding: 25px 20px;
    }
}

.s-cuisine__menu-title-box {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-title {
        font-size: 2.0rem;
        letter-spacing: 0.05em;
    }

    .s-cuisine__menu-title span {
        font-size: 1.2rem;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-title {
        font-size: 1.7rem;
        letter-spacing: 0.05em;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-sub-title {
        font-size: 1.3rem;
        letter-spacing: 0.05em;
        position: absolute;
        right: 0;
        top: -10px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-sub-title {
        font-size: 1.3rem;
        letter-spacing: 0.03em;
        line-height: 1.4;
        margin-top: 10px;
    }

    .s-cuisine__menu-sub-title br {
        display: none;
    }
}

.s-cuisine__menu-line {
    border: none;
    background-color: #dadada;
    height: 1px;
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-line {
        margin-top: 15px;
        margin-bottom: 15px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-line {
        margin-top: 15px;
        margin-bottom: 15px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-description {
        line-height: 1.8;
    }
}

.s-cuisine__menu-category {
    font-size: 1.2rem;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-category {
        margin-top: 10px;
        margin-bottom: 18px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-category {
        font-size: 1.2rem;
        color: #a5a5a5;
        margin-top: 8px;
        margin-bottom: 20px;
    }
}

.s-cuisine__menu-period {
    font-size: 1.2rem;
}

@media screen and (min-width: 600px) {
    .s-cuisine__menu-period {
        margin-top: 38px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__menu-period {
        margin-top: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__sup {
        width: 75%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 50px;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__sup {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 25px;
    }
}

@media screen and (min-width: 600px) {
    .s-cuisine__sup-item {
        font-size: 1.4rem;
        margin-left: 1.1em !important;
        text-indent: -1.1em !important;
    }
}

@media screen and (max-width: 599px) {
    .s-cuisine__sup-item {
        font-size: 1.3rem;
        line-height: 2;
        margin-left: 1.1em !important;
        text-indent: -1.1em !important;
    }
}

/* #News
   -------------------------------------------------------------------------- */
/*doc
---
title: News
name: News
categories: [scope]
---

お知らせトップページ（news）用のコンポーネントです。

*/
@media screen and (min-width: 600px) {
    .s-news__category {
        max-width: 62.5%;
        min-width: 900px;
        margin-left: auto;
        margin-right: auto;
        display: flex;
        flex-flow: row wrap;
        justify-content: center;
        margin-top: 55px;
    }
}

@media screen and (max-width: 599px) {
    .s-news__category {
        width: 100%;
        margin-left: auto;
        margin-right: auto;
        display: flex;
        flex-flow: row wrap;
        justify-content: center;
        margin-top: 25px;
    }
}

.s-news__category-item {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    position: relative;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
}

.s-news__category-item:nth-last-of-type(n+2)::before {
    content: "";
    position: absolute;
    display: inline-block;
    top: 10%;
    right: 0px;
    height: 80%;
    width: 1px;
    background: radial-gradient(#a5a5a5, rgba(165, 165, 165, 0));
}

@media screen and (min-width: 600px) {
    .s-news__category-item {
        margin-bottom: 15px;
        padding-left: 30px;
        padding-right: 30px;
        line-height: 3.5;
    }
}

@media screen and (max-width: 599px) {
    .s-news__category-item {
        padding-left: 20px;
        padding-right: 20px;
        line-height: 3;
    }
}

.s-news__category-item a {
    transition: 0.3s;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .s-news__category-item a::before {
        transition: 0.3s;
        width: 0%;
        content: "";
        height: 1px;
        position: absolute;
        bottom: 0px;
        left: 0px;
        right: 0px;
        margin: auto;
        background-color: #333;
    }

    .s-news__category-item a:hover {
        color: #333;
    }

    .s-news__category-item a:hover::before {
        width: calc(80% - 60px);
    }
}

.s-news__category-item--active a {
    color: #333;
}

@media screen and (min-width: 600px) {
    .s-news__category-item--active a::before {
        width: calc(80% - 60px);
    }
}

@media screen and (min-width: 600px) {
    .s-news__list {
        width: 47.22222%;
        min-width: 680px;
        margin-left: auto;
        margin-right: auto;
        margin-top: 70px;
    }
}

@media screen and (max-width: 599px) {
    .s-news__list {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .s-news__list-item:nth-of-type(n+2) {
        margin-top: 105px;
    }
}

@media screen and (max-width: 599px) {
    .s-news__list-item:nth-of-type(n+2) {
        margin-top: 50px;
    }
}

@media screen and (min-width: 600px) {
    .s-news__list-link {
        display: block;
    }
}

@media screen and (min-width: 600px) {
    .s-news__list-title {
        font-size: 2.4rem;
        margin-top: 5px;
        margin-bottom: 35px;
    }
}

@media screen and (max-width: 599px) {
    .s-news__list-title {
        font-size: 1.7rem;
        margin-top: 10px;
        margin-bottom: 20px;
    }
}

.s-news__list-image-outer {
    position: relative;
    overflow: hidden;
}

@media screen and (min-width: 600px) {
    .s-news__list-image-outer {
        margin-bottom: 35px;
    }
}

@media screen and (max-width: 599px) {
    .s-news__list-image-outer {
        margin-bottom: 25px;
    }
}

.s-news__list-image {
    width: 100%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-news__list-text {
        letter-spacing: 0.02em;
    }
}

@media screen and (max-width: 599px) {
    .s-news__list-text {
        line-height: 1.9;
    }
}

@media screen and (min-width: 600px) {
    .s-news__readmore {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-news__readmore {
        margin-top: 20px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail {
        width: 69.44444%;
        min-width: 1000px;
        margin-left: auto;
        margin-right: auto;
        background-color: #fff;
        padding-left: 160px;
        padding-right: 160px;
        padding-top: 100px;
        padding-bottom: 100px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail {
        background-color: #fff;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        padding-left: 4.71014%;
        padding-right: 4.71014%;
        padding-top: 30px;
        padding-bottom: 50px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__head {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        margin-bottom: 25px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__head {
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: center;
        margin-bottom: 25px;
    }
}

.s-news-detail__pagename {
    color: #7f7f7f;
}

@media screen and (min-width: 600px) {
    .s-news-detail__pagename {
        font-size: 1.7rem;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__pagename {
        font-size: 1.6rem;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__sns {
        width: 110px;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: center;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__sns {
        width: 60px;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: center;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__sns-item:nth-of-type(1) {
        display: none;
    }
}

.s-news-detail__sns-item,
.s-news-detail__sns-item a {
    font-family: 'Lato', sans-serif;
    color: #7f7f7f;
}

@media screen and (min-width: 600px) {

    .s-news-detail__sns-item:nth-of-type(1),
    .s-news-detail__sns-item a:nth-of-type(1) {
        font-size: 1.2rem;
    }

    .s-news-detail__sns-item:nth-of-type(n+2),
    .s-news-detail__sns-item a:nth-of-type(n+2) {
        font-size: 1.5rem;
    }

    .s-news-detail__sns-item:nth-last-of-type(1),
    .s-news-detail__sns-item a:nth-last-of-type(1) {
        font-size: 1.7rem;
    }
}

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

    .s-news-detail__sns-item:nth-of-type(n+2),
    .s-news-detail__sns-item a:nth-of-type(n+2) {
        font-size: 1.9rem;
    }

    .s-news-detail__sns-item:nth-last-of-type(1),
    .s-news-detail__sns-item a:nth-last-of-type(1) {
        font-size: 2.3rem;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__title {
        font-size: 2.8rem;
        margin-bottom: 10px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__title {
        font-size: 2.0rem;
        margin-bottom: 10px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__text {
        margin-top: 45px;
        line-height: 2;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__text {
        margin-top: 30px;
        line-height: 2;
    }
}

.s-news-detail__line,
.s-news-detail__text hr {
    border-top: 1px solid #dadada;
    border-bottom: none;
}

@media screen and (min-width: 600px) {

    .s-news-detail__line,
    .s-news-detail__text hr {
        margin-top: 50px;
        margin-bottom: 50px;
    }
}

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

    .s-news-detail__line,
    .s-news-detail__text hr {
        margin-top: 30px;
        margin-bottom: 40px;
    }
}

.s-news-detail__image {
    width: 100%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-news-detail__image:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__image:nth-of-type(n+2) {
        margin-top: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__text p:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__text p:nth-of-type(n+2) {
        margin-top: 25px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__list {
        margin-top: 100px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__list {
        margin-top: 65px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__list-title {
        width: 86.11111%;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__list-title {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-news-detail__list-title-jp {
        font-size: 2.0rem;
        letter-spacing: 0.05em;
        line-height: 1.5;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__list-title-jp {
        font-size: 1.8rem;
        letter-spacing: 0.05em;
        line-height: 1.5;
    }
}

.s-news-detail__list-title-en {
    font-family: 'EB Garamond', serif;
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .s-news-detail__list-title-en {
        font-size: 1.6rem;
        letter-spacing: 0.05em;
        line-height: 1;
        padding-left: 15px;
    }
}

@media screen and (max-width: 599px) {
    .s-news-detail__list-title-en {
        font-size: 1.3rem;
        letter-spacing: 0.05em;
        line-height: 1;
        padding-left: 10px;
    }
}

/* #Column
   -------------------------------------------------------------------------- */
/*doc
---
title: Column
name: Column
categories: [scope]
---

城崎綴りトップページ（column）用のコンポーネントです。

*/
@media screen and (min-width: 600px) {
    .s-column__overview {
        width: 87.5%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 50px;
        line-height: 2;
        text-align: center;
    }
}

@media screen and (max-width: 599px) {
    .s-column__overview {
        width: 89.49881%;
        margin-left: auto;
        margin-right: auto;
        line-height: 2;
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide {
        margin-top: 70px;
        margin-bottom: 115px;
    }
}

@media screen and (max-width: 599px) {
    .s-column__list-wide {
        margin-top: 35px;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-item {
        width: 100%;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        align-items: flex-end;
        position: relative;
    }

    .s-column__list-wide-item:nth-of-type(2n+1) {
        flex-flow: row-reverse;
    }

    .s-column__list-wide-item:nth-of-type(n+2) {
        margin-top: 80px;
    }
}

@media screen and (max-width: 599px) {
    .s-column__list-wide-item:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-text-block {
        position: relative;
        width: 32.63889%;
        min-width: 470px;
        background-color: #fff;
        z-index: 1;
        padding: 70px;
        overflow: hidden;
    }
}

@media screen and (max-width: 599px) {
    .s-column__list-wide-text-block {
        position: relative;
        z-index: 1;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        background-color: #fff;
        padding: 35px 40px;
        margin-top: -30px;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-text-block--left {
        margin-right: -32.63889%;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-text-block--right {
        margin-left: -32.63889%;
    }
}

.s-column__list-wide-title {
    font-weight: normal;
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-title {
        font-size: 2.0rem;
        line-height: 1.8;
    }
}

@media screen and (max-width: 599px) {
    .s-column__list-wide-title {
        font-size: 1.7rem;
        line-height: 1.8;
    }
}

.s-column__list-wide-date {
    font-family: 'EB Garamond', serif;
    color: #7f7f7f;
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-date {
        font-size: 1.6rem;
    }
}

@media screen and (min-width: 600px) {
    .s-column__readmore {
        margin-top: 45px;
    }
}

@media screen and (max-width: 599px) {
    .s-column__readmore {
        margin-top: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-image-block {
        position: relative;
        width: 87.5%;
        height: 500px;
        overflow: hidden;
        margin-bottom: 45px;
    }
}

@media screen and (min-width: 600px) {
    .s-column__list-wide-image-block img {
        position: absolute;
        top: -100%;
        left: -100%;
        right: -100%;
        bottom: -100%;
        margin: auto;
        width: auto;
        height: auto;
        min-width: 100%;
        min-height: 100%;
    }
}

@media screen and (max-width: 599px) {
    .s-column__list-wide-image-block img {
        width: 100%;
        height: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-column__list {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        margin-top: 80px;
    }
}

/* #Column-detail
   -------------------------------------------------------------------------- */
/*doc
---
title: Column-detail
name: Column-detail
categories: [scope]
---

城崎綴り記事ページ（column）用のコンポーネントです。

*/
@media screen and (min-width: 600px) {
    .s-column-detail {
        width: 69.44444%;
        min-width: 1000px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-column-detail__head {
        text-align: center;
        margin-bottom: 55px;
    }
}

@media screen and (min-width: 600px) {
    .s-column-detail__pagename {
        color: #7f7f7f;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__pagename {
        color: #7f7f7f;
        text-align: center;
    }
}

@media screen and (min-width: 600px) {
    .s-column-detail__title {
        font-size: 2.6rem;
        margin-bottom: 10px;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__title {
        font-size: 2.0rem;
        text-align: center;
        margin-top: 10px;
        margin-bottom: 10px;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__datecat {
        text-align: center;
    }
}

.s-column-detail__text {
    background-color: #fff;
}

@media screen and (min-width: 600px) {
    .s-column-detail__text {
        padding: 50px 70px;
        line-height: 2;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__text {
        line-height: 2;
        margin-top: 40px;
        padding-top: 30px;
        padding-bottom: 30px;
        padding-left: 5.2%;
        padding-right: 5.2%;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__photos {
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .s-column-detail__photos-item {
        margin-top: 60px;
        text-align: center;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__photos-item:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .s-column-detail__photos-item img {
        width: 100%;
        height: auto;
    }
}

@media screen and (max-width: 599px) {
    .s-column-detail__photos-item img {
        width: 100%;
        height: auto;
    }
}

/* #Information
   -------------------------------------------------------------------------- */
/*doc
---
title: Information
name: Information
categories: [scope]
---

店舗情報・交通案内（information）用のコンポーネントです。

*/
@media screen and (min-width: 600px) {
    .s-information__googlemap {
        margin-top: 70px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__googlemap {
        margin-top: 30px;
    }
}

.s-information__googlemap-iframe {
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
}

@media screen and (min-width: 600px) {
    .s-information__googlemap-iframe {
        width: 100%;
        height: 460px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__googlemap-iframe {
        width: 100%;
        height: calc(490px / 2);
    }
}

@media screen and (min-width: 600px) {
    .s-information__list {
        max-width: 1160px;
        padding-left: 40px;
        padding-right: 40px;
        margin-left: auto;
        margin-right: auto;
        margin-top: 80px;
    }

    .s-information__list tr {
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
    }
}

@media screen and (max-width: 599px) {
    .s-information__list {
        margin-top: 30px;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
    }

    .s-information__list tr {
        display: flex;
        flex-flow: row wrap;
    }
}

@media screen and (min-width: 600px) {

    .s-information__list-title,
    .s-information__list-content {
        padding-top: 45px;
        padding-bottom: 45px;
    }

    .s-information__list-title:nth-last-of-type(n+2),
    .s-information__list-content:nth-last-of-type(n+2) {
        border-bottom: 1px solid #dadada;
    }
}

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

    .s-information__list-title:nth-of-type(2),
    .s-information__list-title:nth-of-type(4),
    .s-information__list-title:nth-of-type(5),
    .s-information__list-content:nth-of-type(2),
    .s-information__list-content:nth-of-type(4),
    .s-information__list-content:nth-of-type(5) {
        padding-top: 20px;
        padding-bottom: 30px;
        border-top: 1px solid #dadada;
        width: 100%;
    }
}

@media screen and (min-width: 600px) {
    .s-information__list-title {
        width: 18.51852%;
    }
}

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

    /*.s-information__list-title:nth-of-type(2),
    .s-information__list-title:nth-of-type(4),
    .s-information__list-title:nth-of-type(5) {
        width: 26.66667%;
    }

    .s-information__list-title:nth-of-type(3) {
        width: 100%;
        padding-top: 30px;
        padding-bottom: 20px;
        border-top: 1px solid #dadada;
    }*/
}

@media screen and (min-width: 600px) {
    .s-information__list-content {
        width: 81.48148%;
        border-bottom: 1px solid #dadada;
    }

    .s-information__list-content:nth-of-type(3),
    .s-information__list tr:nth-of-type(3) .s-information__list-content {
        display: flex;
        flex-flow: row wrap;
    }
}

@media screen and (max-width: 599px) {
    /*.s-information__list-content:nth-of-type(1) {
        margin-top: 20px;
        margin-bottom: 30px;
    }*/

    /*.s-information__list-content:nth-of-type(2),
    .s-information__list-content:nth-of-type(4),
    .s-information__list-content:nth-of-type(5) {
        width: 73.33333%;
    }*/

    .s-information__list-content:nth-of-type(3),
    .s-information__list tr:nth-of-type(3) .s-information__list-content {
        width: 100%;
        padding-bottom: 30px;
    }
}

.s-information__list-byfoot {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-weight: 600;
}

@media screen and (min-width: 600px) {
    .s-information__list-byfoot {
        font-size: 1.4rem;
        margin-top: 10px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__list-byfoot {
        margin-top: 15px;
    }
}

.s-information__list-google {
    text-decoration: underline;
}

@media screen and (min-width: 600px) {
    .s-information__list-google {
        font-size: 1.4rem;
        letter-spacing: 0.04em;
        display: inline-block;
        margin-left: 20px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__list-google {
        letter-spacing: 0.04em;
        display: block;
        margin-top: 15px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__hours:nth-of-type(1) {
        margin-right: 70px;
        width: 320px;
    }

    .s-information__hours:nth-of-type(2) {
        width: 320px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__hours:nth-of-type(1) .s-information__hours-time li:nth-of-type(1) {
        margin-right: 20px;
    }

    .s-information__hours:nth-of-type(2) .s-information__hours-time:nth-of-type(1) li:nth-of-type(1) {
        margin-right: 30px;
    }

    .s-information__hours:nth-of-type(2) .s-information__hours-time:nth-of-type(2) li:nth-of-type(1) {
        margin-right: 45px;
    }
}

.s-information__point {
    position: relative;
}

.s-information__hours>li {
    margin-bottom: 10px;
}

.s-information__point::before,
.s-information__hours>li p:first-child:before {
    content: "";
    background-color: #7f7f7f;
    width: 4px;
    height: 16px;
    display: inline-block;
    position: relative;
    top: 2px;
    margin-right: 5px;
}

.s-information__hours>li p {
    display: inline-block;
    width: 160px;
}

@media screen and (min-width: 600px) {
    .s-information__hours-time {
        display: flex;
        flex-flow: row wrap;
        justify-content: space-between;
    }
}

@media screen and (max-width: 599px) {
    .s-information__hours-time {
        display: flex;
        flex-flow: row wrap;
    }
}

.s-information__case {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-information__case {
        max-width: 1080px;
        margin-left: auto;
        margin-right: auto;
        padding: 70px 100px;
    }

    .s-information__case:nth-of-type(2) {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__case {
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        padding: 35px 20px;
    }

    .s-information__case:nth-of-type(1) {
        margin-top: 45px;
    }

    .s-information__case:nth-of-type(2) {
        margin-top: 40px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__case-title {
        font-size: 2.2rem;
        margin-bottom: 35px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__case-title {
        font-size: 1.7rem;
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__case-text {
        line-height: 2;
    }

    .s-information__case-text:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__case-text {
        line-height: 1.9;
    }

    .s-information__case-text:nth-of-type(n+2) {
        margin-top: 20px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__case .u-text-caption {
        display: block;
        line-height: 1.8;
    }
}

@media screen and (min-width: 600px) {
    .s-information__leave {
        margin-top: 40px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__leave {
        margin-top: 30px;
    }
}

.s-information__leave-maintitle {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-size: 1.6rem;
}

@media screen and (min-width: 600px) {
    .s-information__leave-inner {
        display: flex;
        flex-flow: row wrap;
        margin-top: 20px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__leave-item:nth-of-type(1) {
        margin-right: 65px;
    }
}

.s-information__leave-title,
.s-information__leave-time {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

@media screen and (min-width: 600px) {

    .s-information__leave-title,
    .s-information__leave-time {
        font-size: 1.4rem;
    }
}

@media screen and (max-width: 599px) {
    .s-information__leave-title {
        margin-top: 20px;
        margin-bottom: 5px;
    }
}

.s-information__leave-time {
    font-weight: bold;
}

@media screen and (min-width: 600px) {
    .s-information__leave-time {
        margin-top: 5px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__case-caption {
        margin-top: 20px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__case-caption {
        margin-top: 20px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__access {
        max-width: 1080px;
        margin-top: 120px;
        margin-left: auto;
        margin-right: auto;
        position: relative;
        padding-bottom: 120px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__access {
        margin-top: 80px;
        padding-bottom: 80px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__access-title {
        font-size: 2.2rem;
    }

    .s-information__access-title span {
        border-bottom: 1px solid #333;
        padding-bottom: 4px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__access-title {
        font-size: 1.7rem;
        letter-spacing: 0.02em;
        margin-left: 4.71014%;
        margin-right: 4.71014%;
    }

    .s-information__access-title span {
        border-bottom: 1px solid #333;
        padding-bottom: 4px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__map {
        margin-top: 90px;
        position: relative;
    }
}

@media screen and (max-width: 599px) {
    .s-information__map {
        display: none;
    }
}

@media screen and (min-width: 600px) {
    .s-information__map--kansai {
        width: 969px;
        margin-left: auto;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-information__map--others {
        width: 883px;
        margin-left: 30px;
        margin-right: auto;
    }
}

@media screen and (min-width: 600px) {
    .s-information__map-button-item a {
        position: absolute;
        display: block;
        width: 240px;
        height: 50px;
        z-index: 1;
    }

    .s-information__map-button-item a+img {
        transition: 0.5s;
        opacity: 0;
    }

    .s-information__map-button-item a:hover+img {
        opacity: 1;
    }

    .s-information__map-button-item.s-information__active img {
        opacity: 1;
    }
}

@media screen and (min-width: 600px) {
    .s-information__map-button-item--kansai {
        position: absolute;
    }

    .s-information__map-button-item--kansai:nth-of-type(1) {
        top: 366px;
        right: 59px;
    }

    .s-information__map-button-item--kansai:nth-of-type(1) a {
        right: 0;
        bottom: 0;
    }

    .s-information__map-button-item--kansai:nth-of-type(2) {
        top: 233px;
        right: 0px;
    }

    .s-information__map-button-item--kansai:nth-of-type(2) a {
        right: 0;
        bottom: 0;
    }

    .s-information__map-button-item--kansai:nth-of-type(3) {
        top: 346px;
        right: 81px;
    }

    .s-information__map-button-item--kansai:nth-of-type(3) a {
        right: 0;
        bottom: 0;
    }
}

@media screen and (min-width: 600px) {
    .s-information__map-button-item--others {
        position: absolute;
    }

    .s-information__map-button-item--others:nth-of-type(1) {
        top: 490px;
        right: 0px;
    }

    .s-information__map-button-item--others:nth-of-type(1) a {
        right: 0;
        bottom: 0;
    }

    .s-information__map-button-item--others:nth-of-type(2) {
        top: 511px;
        right: 86px;
    }

    .s-information__map-button-item--others:nth-of-type(2) a {
        right: 0;
        bottom: 0;
    }

    .s-information__map-button-item--others:nth-of-type(3) {
        top: 453px;
        left: 0px;
    }

    .s-information__map-button-item--others:nth-of-type(3) a {
        width: 270px;
        left: 0px;
        top: 0;
    }
}

.s-information__tab-button {
    display: flex;
    flex-flow: row nowrap;
    justify-content: space-between;
}

@media screen and (min-width: 600px) {
    .s-information__tab-button {
        margin-top: 80px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab-button {
        margin-top: 40px;
    }
}

.s-information__tab-button-item {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

@media screen and (min-width: 600px) {
    .s-information__tab-button-item {
        width: 32.40741%;
    }

    .s-information__tab-button-item a {
        transition: 0.5s;
        display: block;
        height: 70px;
        padding-top: 24px;
        color: #a5a5a5;
        background-color: #dadada;
        text-align: center;
        font-weight: bold;
    }

    .s-information__tab-button-item a br {
        display: none;
    }

    .s-information__tab-button-item a:hover,
    .s-information__tab-button-item.s-information__active a {
        color: #333;
        background-color: #fff;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab-button-item {
        width: 32.6087%;
    }

    .s-information__tab-button-item a {
        transition: 0.5s;
        display: flex;
        align-items: center;
        justify-content: center;
        height: 70px;
        padding-top: 5px;
        color: #a5a5a5;
        background-color: #dadada;
        text-align: center;
        font-weight: bold;
        font-size: 1.3rem;
        letter-spacing: 0.03em;
    }

    .s-information__tab-button-item.s-information__active a {
        color: #333;
        background-color: #fff;
    }

    .s-information__tab-button-item span {
        display: none;
    }
}

.s-information__tab-outer {
    position: relative;
}

@media screen and (min-width: 600px) {
    .s-information__tab {
        background-color: #fff;
        padding: 80px 40px;
        display: flex;
        flex-flow: row nowrap;
        justify-content: space-between;
        transition: 0.5s;
        visibility: hidden;
        position: absolute;
        opacity: 0;
        top: 0;
    }

    .s-information__tab.s-information__active {
        visibility: visible;
        position: relative;
        opacity: 1;
        top: 0;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab {
        background-color: #fff;
        padding: 40px 4.71014%;
        transition: 0.5s;
        visibility: hidden;
        position: absolute;
        opacity: 0;
        top: 0;
    }

    .s-information__tab.s-information__active {
        visibility: visible;
        position: relative;
        opacity: 1;
        top: 0;
    }
}

.s-information__tab-title {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    font-weight: normal;
}

@media screen and (min-width: 600px) {
    .s-information__tab-title {
        font-size: 1.8rem;
        margin-bottom: 20px;
    }

    .s-information__tab-title:nth-of-type(n+2) {
        margin-top: 85px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab-title {
        font-size: 1.7rem;
        margin-bottom: 20px;
    }

    .s-information__tab-title:nth-of-type(n+2) {
        margin-top: 40px;
    }
}

.s-information__tab-title-sub {
    color: #a5a5a5;
}

@media screen and (min-width: 600px) {
    .s-information__tab-title-sub {
        font-size: 1.4rem;
        margin-left: 15px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab-title-sub {
        display: block;
        margin-top: 10px;
        font-size: 1.4rem;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab-chart {
        display: flex;
        flex-flow: row nowrap;
    }

    .s-information__tab-chart:nth-of-type(2) {
        margin-top: 25px;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab-chart {
        display: none;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab-chart-item:nth-of-type(1) {
        width: 19.27711%;
    }

    .s-information__tab-chart-item:nth-of-type(2) {
        width: 80.72289%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    .s-information__tab-chart-item:nth-of-type(2) img {
        width: 100%;
        height: auto;
    }
}

@media screen and (min-width: 600px) {

    .s-information__tab-station,
    .s-information__tab-station-kobe,
    .s-information__tab-station-haneda,
    .s-information__tab-station-kinosaki {
        display: flex;
        align-items: center;
        justify-content: center;
        font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
        font-weight: bold;
        border: 2px solid #a5a5a5;
        border-radius: 10px;
        line-height: 1.4;
        text-align: center;
        height: 70px;
    }

    .s-information__tab-station span,
    .s-information__tab-station-kobe span,
    .s-information__tab-station-haneda span,
    .s-information__tab-station-kinosaki span {
        font-size: 1.2rem;
        font-weight: normal;
        display: block;
    }
}

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

    .s-information__tab-station,
    .s-information__tab-station-kobe,
    .s-information__tab-station-haneda,
    .s-information__tab-station-kinosaki {
        display: none;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab-station-kobe {
        height: 170px;
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab-station-haneda {
        height: 270px;
        margin-bottom: 30px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab-inner {
        width: 84%;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab-station-kinosaki {
        background-color: #b2a995;
        color: #fff;
        width: 15%;
        height: auto;
        margin-top: 45px;
    }
}

@media screen and (min-width: 600px) {
    .s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp {
        width: 100%;
    }
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1) img {
    width: 115.33333%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(2) img {
    width: 100%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(3) img {
    width: 100%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(4) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(4)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(4)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--kansai:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(4) img {
    width: 196.66667%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp {
        width: 100%;
    }
}

.s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(1) img {
    width: 100%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(2) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(2)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(2)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--kansai:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(2) img {
    width: 115.2%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp {
        width: 100%;
    }
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(1) img {
    width: 100%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(2) img {
    width: 100%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(3) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(3)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(3)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(3) img {
    width: 196.8%;
    height: auto;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(4) {
    padding-bottom: 45px;
    overflow-x: scroll;
    padding-top: 45px;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(4)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(4)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--kansai:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(4) img {
    width: 187.73333%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp {
        width: 100%;
    }
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(1) img {
    width: 164.66667%;
    height: auto;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(2) {
    padding-bottom: 45px;
    overflow-x: scroll;
    padding-top: 45px;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(2)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(2)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--others:nth-of-type(1) .s-information__tab-chart-sp:nth-of-type(2) img {
    width: 164.66667%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-information__tab--others:nth-of-type(2) .s-information__tab-chart-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab--others:nth-of-type(2) .s-information__tab-chart-sp {
        width: 100%;
    }
}

.s-information__tab--others:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(1) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--others:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--others:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--others:nth-of-type(2) .s-information__tab-chart-sp:nth-of-type(1) img {
    width: 164.66667%;
    height: auto;
}

@media screen and (min-width: 600px) {
    .s-information__tab--others:nth-of-type(3) .s-information__tab-chart-sp {
        display: none;
    }
}

@media screen and (max-width: 599px) {
    .s-information__tab--others:nth-of-type(3) .s-information__tab-chart-sp {
        width: 100%;
    }
}

.s-information__tab--others:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(1) {
    padding-bottom: 45px;
    overflow-x: scroll;
}

.s-information__tab--others:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar {
    background-color: #dadada;
    height: 5px;
}

.s-information__tab--others:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(1)::-webkit-scrollbar-thumb {
    background-color: #b9af96;
}

.s-information__tab--others:nth-of-type(3) .s-information__tab-chart-sp:nth-of-type(1) img {
    width: 126.4%;
    height: auto;
}

/* -----------------------------------------------------------------------------
   #Utility
   -------------------------------------------------------------------------- */
/* -----------------------------------------------------------------------------
   #Text
   -------------------------------------------------------------------------- */
/*doc
---
title: text
name: text
categories: [utility]
---

テキストのスタイルを指定する汎用クラスです。

```block
<p class="u-text-light">font-weight 300</p>
<p class="u-text-normal">font-weight 400</p>
<p class="u-text-bold">font-weight 600</p>
<p class="u-text-indent">先頭の1文字目を1文字分字下げします。</p>
<p class="u-text-note">2行目以降の1文字目を1文字分字下げします。<br>2行目以降の1文字目を1文字分字下げします。</p>
<p class="u-text-nowrap">テキストを折り返させません。横幅を超えても、このテキストは折り返さずに表示されます。</p>
<p class="u-text-breakword">テキストを折り返させます。長文になっても、このテキストは必ず折り返して表示されます。</p>
<p class="u-text-justify">テキストを両端揃え（均等割り付け）させます。通常のテキストと文字間が違うのが分かると思います。</p>
<p class="u-text-none">記述した通りに表示します。</p>
<p class="u-text-lowercase">abcdEFGH すべての英単語を小文字で表示します。</p>
<p class="u-text-uppercase">abcdEFGH すべての英単語を大文字で表示します。</p>
<p class="u-text-capitalize">abcdEFGH 英単語の先頭を大文字で表示します。</p>
<p class="u-text-smallcaps">abcdEFGH スモールキャップ（小文字と同じ高さで作られた大文字）で表示します。</p>
<p class="u-text-vertical">abcdEFGH 縦書きで表示します。</p>
<p class="u-text-vertical u-text-vertical--upright">abcdEFGH 英文も縦書きにする場合はModifierを指定します。</p>
<p class="u-text-right">text-align right</p>
<p class="u-text-center">text-align center</p>
<p class="u-text-left">text-align left</p>
<p class="u-text-top">vertical-align top</p>
<p class="u-text-middle">vertical-align middle</p>
<p class="u-text-bottom">vertical-align bottom</p>
```
*/
/* font-weightを指定します。 */
.u-text-light {
    font-weight: 300 !important;
}

.u-text-normal {
    font-weight: 400 !important;
}

.u-text-bold {
    font-weight: 600 !important;
}

/* 先頭の1文字目を1文字分字下げします。 */
.u-text-indent {
    text-indent: 1.2em !important;
}

/* 2行目以降の1文字目を1文字分字下げします。 */
.u-text-note {
    margin-left: 1.2em !important;
    text-indent: -1.2em !important;
}

/* テキストを改行させません。 */
.u-text-nowrap {
    white-space: nowrap !important;
}

/* テキストを改行させます。 */
.u-text-breakword {
    word-wrap: break-word !important;
    overflow-wrap: break-word !important;
}

/* テキストを両端揃えさせます。 */
.u-text-justify {
    text-align: justify !important;
    text-justify: inter-ideograph !important;
}

/* 記述した通りに表示します。 */
.u-text-none {
    text-transform: none !important;
}

/* すべての英単語を小文字にします。 */
.u-text-lowercase {
    text-transform: lowercase !important;
}

/* すべての英単語を大文字にします。 */
.u-text-uppercase {
    text-transform: uppercase !important;
}

/* 英単語の先頭を大文字にします。 */
.u-text-capitalize {
    text-transform: capitalize !important;
}

/* スモールキャップ（小文字と同じ高さで作られた大文字）にします。 */
.u-text-smallcaps {
    font-variant: small-caps !important;
}

/* 縦書きにします。 */
.u-text-vertical {
    -webkit-writing-mode: vertical-rl !important;
    -ms-writing-mode: tb-rl !important;
    writing-mode: vertical-rl !important;
    text-orientation: mixed !important;
}

/* 英文も縦書きにする場合はModifierを指定します。 */
.u-text-vertical--upright {
    text-orientation: upright !important;
}

.u-text-right {
    text-align: right !important;
}

.u-text-center {
    text-align: center !important;
}

.u-text-left {
    text-align: left !important;
}

.u-text-top {
    vertical-align: top !important;
}

.u-text-middle {
    vertical-align: middle !important;
}

.u-text-bottom {
    vertical-align: bottom !important;
}

.u-text-underline {
    text-decoration: underline;
}

/* キャプション用に色を薄く12pxにします。 */
.u-text-caption {
    color: #858585;
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
    margin-left: 1.2em !important;
    text-indent: -1.2em !important;
}

.u-text-caption a {
    color: #858585;
}

@media screen and (min-width: 600px) {
    .u-text-caption {
        font-size: 1.4rem;
        letter-spacing: 0.03em;
    }
}

@media screen and (max-width: 599px) {
    .u-text-caption {
        font-size: 1.2rem;
        letter-spacing: 0.03em;
    }
}

.u-text-sans-serif {
    font-family: "游ゴシック", YuGothic, "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
}

.u-text-underline {
    text-decoration: underline;
}

.u-text-color-pale {
    opacity: 0.4;
}

/* #Align
   -------------------------------------------------------------------------- */
/*doc
---
title: align
name: align
categories: [utility]
---

画像などを左右や中央に配置します。

```block
<div class="c-wrapper">
  <img src="http://lorempixel.com/150/150/">
  <img src="http://lorempixel.com/150/150/" class="u-align-center">
  <img src="http://lorempixel.com/150/150/" class="u-align-right">
</div>
```
*/
.u-align-left {
    display: block !important;
    margin-left: 0 !important;
    margin-right: auto !important;
}

.u-align-center {
    display: block !important;
    margin-right: auto !important;
    margin-left: auto !important;
}

.u-align-right {
    display: block !important;
    margin-left: auto !important;
    margin-right: 0 !important;
}

/* #Margin
   -------------------------------------------------------------------------- */
/*doc
---
title: margin
name: margin
categories: [utility]
---

マージンで余白の管理をします。常に下方向にだけ余白をとります。
`<section>`要素を使うようなセクションの余白はlayout/_section.scssで管理します。

* `.u-mb`は常に余白をとります。
* `.u-mb-gain`はあるブレイクポイント以上で余白を指定します。
* `.u-mb-lose`はあるブレイクポイント以上で余白を無くします。

サイズのバリエーションは最大で5つ、通常は3つとします。

1. `tiny`(optional)
2. `small`
3. `medium`
4. `large`
5. `huge`(optional)

```block
<div class="u-mb-medium">
  <p>Lorem ipsum</p>
</div>

<div class="u-mb-gain-medium">
  <p>Lorem ipsum</p>
</div>

<div class="u-mb-lose-medium">
  <p>Lorem ipsum</p>
</div>
```
*/
/* 常に余白を指定するクラス。 */
.u-mb-small {
    margin-bottom: 0.8em !important;
}

@media screen and (min-width: 600px) {
    .u-mb-small {
        margin-bottom: 1em !important;
    }
}

.u-mb-medium {
    margin-bottom: 1.6em !important;
}

@media screen and (min-width: 600px) {
    .u-mb-medium {
        margin-bottom: 2em !important;
    }
}

.u-mb-large {
    margin-bottom: 3.2em !important;
}

@media screen and (min-width: 600px) {
    .u-mb-large {
        margin-bottom: 4em !important;
    }
}

/* ブレイクポイント以上で余白を指定するクラス。 */
@media screen and (min-width: 600px) {
    .u-mb-gain-small {
        margin-bottom: 1em !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-medium {
        margin-bottom: 2em !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-large {
        margin-bottom: 4em !important;
    }
}

/* ブレイクポイント以下で余白を設定するクラス。 */
@media screen and (max-width: 599px) {
    .u-mb-lose-small {
        margin-bottom: 0.8em !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-medium {
        margin-bottom: 1.6em !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-large {
        margin-bottom: 3.2em !important;
    }
}

/* 常に余白を指定するクラス。 */
.u-mt-small {
    margin-top: 0.8em !important;
}

@media screen and (min-width: 600px) {
    .u-mt-small {
        margin-top: 1em !important;
    }
}

.u-mt-medium {
    margin-top: 1.6em !important;
}

@media screen and (min-width: 600px) {
    .u-mt-medium {
        margin-top: 2em !important;
    }
}

.u-mt-large {
    margin-top: 3.2em !important;
}

@media screen and (min-width: 600px) {
    .u-mt-large {
        margin-top: 4em !important;
    }
}

/* ブレイクポイント以上で余白を指定するクラス。 */
@media screen and (min-width: 600px) {
    .u-mt-gain-small {
        margin-top: 1em !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-medium {
        margin-top: 2em !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-large {
        margin-top: 4em !important;
    }
}

/* ブレイクポイント以下で余白を設定するクラス。 */
@media screen and (max-width: 599px) {
    .u-mt-lose-small {
        margin-top: 0.8em !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-medium {
        margin-top: 1.6em !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-large {
        margin-top: 3.2em !important;
    }
}

/* 常に余白を指定するクラス。 */
.u-mr-small {
    margin-right: 0.8em !important;
}

@media screen and (min-width: 600px) {
    .u-mr-small {
        margin-right: 1em !important;
    }
}

.u-mr-medium {
    margin-right: 1.6em !important;
}

@media screen and (min-width: 600px) {
    .u-mr-medium {
        margin-right: 2em !important;
    }
}

.u-mr-large {
    margin-right: 3.2em !important;
}

@media screen and (min-width: 600px) {
    .u-mr-large {
        margin-right: 4em !important;
    }
}

/* ブレイクポイント以上で余白を設定するクラス。 */
@media screen and (min-width: 600px) {
    .u-mr-gain-small {
        margin-right: 1em !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mr-gain-medium {
        margin-right: 2em !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mr-gain-large {
        margin-right: 4em !important;
    }
}

/* ブレイクポイント以下で余白を設定するクラス。 */
@media screen and (max-width: 599px) {
    .u-mr-lose-small {
        margin-right: 0.8em !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mr-lose-medium {
        margin-right: 1.6em !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mr-lose-large {
        margin-right: 3.2em !important;
    }
}

/* 常に余白を指定するクラス。 */
.u-mb-5 {
    margin-bottom: 5px !important;
}

.u-mb-10 {
    margin-bottom: 10px !important;
}

.u-mb-15 {
    margin-bottom: 15px !important;
}

.u-mb-20 {
    margin-bottom: 20px !important;
}

.u-mb-25 {
    margin-bottom: 25px !important;
}

.u-mb-30 {
    margin-bottom: 30px !important;
}

/* ブレイクポイント以下の設定 */
@media screen and (max-width: 599px) {
    .u-mb-lose-5 {
        margin-bottom: 5px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-10 {
        margin-bottom: 10px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-15 {
        margin-bottom: 15px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-20 {
        margin-bottom: 20px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-25 {
        margin-bottom: 25px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mb-lose-30 {
        margin-bottom: 30px !important;
    }
}

/* ブレイクポイント以上の設定 */
@media screen and (min-width: 600px) {
    .u-mb-gain-5 {
        margin-bottom: 5px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-10 {
        margin-bottom: 10px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-15 {
        margin-bottom: 15px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-20 {
        margin-bottom: 20px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-25 {
        margin-bottom: 25px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mb-gain-30 {
        margin-bottom: 30px !important;
    }
}

/* 常に余白を指定するクラス。 */
.u-mt-5 {
    margin-top: 5px !important;
}

.u-mt-10 {
    margin-top: 10px !important;
}

.u-mt-15 {
    margin-top: 15px !important;
}

.u-mt-20 {
    margin-top: 20px !important;
}

.u-mt-25 {
    margin-top: 25px !important;
}

.u-mt-30 {
    margin-top: 30px !important;
}

/* ブレイクポイント以下の設定。 */
@media screen and (max-width: 599px) {
    .u-mt-lose-5 {
        margin-top: 5px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-10 {
        margin-top: 10px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-15 {
        margin-top: 15px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-20 {
        margin-top: 20px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-25 {
        margin-top: 25px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mt-lose-30 {
        margin-top: 30px !important;
    }
}

/* ブレイクポイント以上の設定 */
@media screen and (min-width: 600px) {
    .u-mt-gain-5 {
        margin-top: 5px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-10 {
        margin-top: 10px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-15 {
        margin-top: 15px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-20 {
        margin-top: 20px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-25 {
        margin-top: 25px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mt-gain-30 {
        margin-top: 30px !important;
    }
}

/* 常に余白を指定するクラス。 */
.u-mr-5 {
    margin-right: 5px !important;
}

.u-mr-10 {
    margin-right: 10px !important;
}

.u-mr-15 {
    margin-right: 15px !important;
}

.u-mr-20 {
    margin-right: 20px !important;
}

/* ブレイクポイント以下の設定。 */
@media screen and (max-width: 599px) {
    .u-mr-lose-5 {
        margin-right: 5px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mr-lose-10 {
        margin-right: 10px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mr-lose-15 {
        margin-right: 15px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-mr-lose-20 {
        margin-right: 20px !important;
    }
}

/* ブレイクポイント以上の設定 */
@media screen and (min-width: 600px) {
    .u-mr-gain-5 {
        margin-right: 5px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mr-gain-10 {
        margin-right: 10px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mr-gain-15 {
        margin-right: 15px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-mr-gain-20 {
        margin-right: 20px !important;
    }
}

/* 常に余白を指定するクラス。 */
.u-ml-5 {
    margin-left: 5px !important;
}

.u-ml-10 {
    margin-left: 10px !important;
}

.u-ml-15 {
    margin-left: 15px !important;
}

.u-ml-20 {
    margin-left: 20px !important;
}

/* ブレイクポイント以下の設定。 */
@media screen and (max-width: 599px) {
    .u-ml-lose-5 {
        margin-left: 5px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-ml-lose-10 {
        margin-left: 10px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-ml-lose-15 {
        margin-left: 15px !important;
    }
}

@media screen and (max-width: 599px) {
    .u-ml-lose-20 {
        margin-left: 20px !important;
    }
}

/* ブレイクポイント以上の設定 */
@media screen and (min-width: 600px) {
    .u-ml-gain-5 {
        margin-left: 5px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-ml-gain-10 {
        margin-left: 10px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-ml-gain-15 {
        margin-left: 15px !important;
    }
}

@media screen and (min-width: 600px) {
    .u-ml-gain-20 {
        margin-left: 20px !important;
    }
}

/* #Display
   -------------------------------------------------------------------------- */
/*doc
---
title: display
name: display
categories: [utility]
---

表示非表示を切り替えます。改行位置のコントロールもできます。

```block
<p class="u-dn-md"><code>$-md</code>以降は非表示になります。</p>
<p class="u-dn u-db-md"><code>$-md</code>以降は表示されます。</p>
<p>基本はなりゆきでウィンドウサイズが狭くなると、<span class="u-dib">ここから改行されます。</span></p>
<p><code>$-md</code>以降になると、<span class="u-db-md">ここから改行されます。</span></p>
```
*/
.u-dn {
    display: none !important;
}

@media screen and (min-width: 600px) {
    .u-dn-sm {
        display: none !important;
    }
}

@media screen and (min-width: 768px) {
    .u-dn-md {
        display: none !important;
    }
}

@media screen and (min-width: 1080px) {
    .u-dn-lg {
        display: none !important;
    }
}

@media screen and (min-width: 1200px) {
    .u-dn-xl {
        display: none !important;
    }
}

.u-db {
    display: block !important;
}

@media screen and (min-width: 600px) {
    .u-db-sm {
        display: block !important;
    }
}

@media screen and (min-width: 768px) {
    .u-db-md {
        display: block !important;
    }
}

@media screen and (min-width: 1080px) {
    .u-db-lg {
        display: block !important;
    }
}

@media screen and (min-width: 1200px) {
    .u-db-xl {
        display: block !important;
    }
}

.u-di {
    display: inline !important;
}

@media screen and (min-width: 600px) {
    .u-di-sm {
        display: inline !important;
    }
}

@media screen and (min-width: 768px) {
    .u-di-md {
        display: inline !important;
    }
}

@media screen and (min-width: 1080px) {
    .u-di-lg {
        display: inline !important;
    }
}

@media screen and (min-width: 1200px) {
    .u-di-xl {
        display: inline !important;
    }
}

.u-dib {
    display: inline-block !important;
}

@media screen and (min-width: 600px) {
    .u-dib-sm {
        display: inline-block !important;
    }
}

@media screen and (min-width: 768px) {
    .u-dib-md {
        display: inline-block !important;
    }
}

@media screen and (min-width: 1080px) {
    .u-dib-lg {
        display: inline-block !important;
    }
}

@media screen and (min-width: 1200px) {
    .u-dib-xl {
        display: inline-block !important;
    }
}

/* #Over
   -------------------------------------------------------------------------- */
/*doc
---
title: over
name: over
categories: [utility]
---

マウスオーバー時のアニメーション設定です。
*/
.u-over {
    transition: 0.3s;
}

@media screen and (min-width: 768px) {
    .u-over:hover {
        opacity: 0.6;
    }
}

.u-over-todark {
    transition: 0.3s;
}

@media screen and (min-width: 768px) {
    .u-over-todark:hover {
        color: #333;
    }
}

.u-over-scale {
    overflow: hidden;
}

.u-over-scale img {
    transition: 0.8s;
}

@media screen and (min-width: 768px) {
    .u-over-scale:hover img {
        -webkit-transform: scale(1.03);
        transform: scale(1.03);
    }
}

.u-over-line {
    position: relative;
    transition: 0.3s;
}

@media screen and (min-width: 600px) {
    .u-over-line::before {
        transition: 0.3s;
        width: 0%;
        content: "";
        height: 1px;
        position: absolute;
        bottom: -6px;
        left: 0px;
        right: 0px;
        margin: auto;
        background-color: #333;
    }

    .u-over-line:hover {
        color: #333;
    }

    .u-over-line:hover::before {
        width: 100%;
    }
}

.u-over-line--active {
    color: #333 !important;
}

@media screen and (min-width: 600px) {
    .u-over-line--active::before {
        width: 100%;
    }
}

.u-over-line-nav {
    position: relative;
    transition: 0.3s;
}

@media screen and (min-width: 600px) {
    .u-over-line-nav::before {
        transition: 0.3s;
        width: 0%;
        content: "";
        height: 1px;
        position: absolute;
        bottom: -7px;
        left: 0px;
        right: 0px;
        margin: auto;
        background-color: #fff;
    }

    .u-over-line-nav:hover::before {
        width: 100%;
    }
}

.u-over-line-lang {
    position: relative;
    transition: 0.3s;
}

@media screen and (min-width: 600px) {
    .u-over-line-lang::before {
        transition: 0.3s;
        width: 0%;
        content: "";
        height: 1px;
        position: absolute;
        bottom: -6px;
        left: 0px;
        right: 0px;
        margin: auto;
        background-color: #fff;
    }

    .u-over-line-lang:hover::before {
        width: calc(100%);
    }
}

@media screen and (min-width: 600px) {
    .u-over-line-lang--active::before {
        width: calc(100%);
    }
}

/* #Img-fix
   -------------------------------------------------------------------------- */
/*doc
---
title: img-fix
name: img-fix
categories: [utility]
---

画像をwidth:100% height:auto に設定します。

*/
.u-img-fix {
    width: 100%;
    height: auto;
}

/* #Float
   -------------------------------------------------------------------------- */
/*doc
---
title: float
name: float
categories: [utility]
---

フロートの設定です。

*/
.u-float-left {
    float: left;
}

.u-float-right {
    float: left;
}

.u-float-clearfix:after {
    content: "";
    display: block;
    clear: both;
}

/* #Test
   --------------------------------------------------------------------------

一時格納場所です。

*/
.p-404 {
    padding-top: 100px;
    text-align: center;
    padding-bottom: 50px;
}

.index-banner {
    padding-top: 70px;
    position: relative;
}

.index-banner .swiper-slide {}

.index-banner .swiper-slide>img {
    width: 100%;
}

.index-banner .swiper-slide .info {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    text-align: center;
}

.index-banner .swiper-slide .info img {}

.index-banner .swiper-slide .info p {
    font-size: 1.9rem;
    font-weight: 900;
    line-height: 47.5px;
    letter-spacing: 2.8499999046325684px;
    text-align: center;
    color: #fff;
    margin-top: 4%;
    text-shadow: 1px 1px 1px rgba(0, 0, 0, .5);
}

.index-banner .swiper-pagination {
    bottom: 2%;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -moz-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

.index-banner .swiper-pagination-bullet {
    width: 14px;
    height: 14px;
    background: #FFFFFF;
    opacity: 1;
    margin: 0 5px;
}

.index-banner .swiper-pagination-bullet-active {
    background: #85A446;
}

::marker {
    display: none;
    font-size: 0;
}

/*.n-contents {
    padding-top: 70px;
}*/

.s-privacy,
.s-note {
    background-color: #fff;
}

@media screen and (min-width: 600px) {

    .s-privacy-detail,
    .s-note-detail,
    .s-contact-detail,
    .p-contact-detail {
        width: 69.44444%;
        min-width: 1000px;
        margin-left: auto;
        margin-right: auto;
        background-color: #fff;
        /* padding-left: 160px; */
        /* padding-right: 160px; */
        padding-top: 7%;
        padding-bottom: 7%;
    }

    .s-contact-detail,
    .p-contact-detail {
        padding-top: 0;
        padding-bottom: 3%;
    }
}

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

    .s-privacy-detail,
    .s-note-detail,
    .s-contact-detail,
    .p-contact-detail {
        background-color: #fff;
        width: 90.57971%;
        margin-left: auto;
        margin-right: auto;
        padding-left: 4.71014%;
        padding-right: 4.71014%;
        padding-top: 30px;
        padding-bottom: 50px;
    }

    .s-contact-detail,
    .p-contact-detail {
        /* padding: 0; */
    }
}

.s-privacy-detail h2:first-child {
    margin-top: 0;
}

.s-privacy-detail h2 {
    font-size: 2rem;
    font-weight: 500;
    line-height: 30px;
    text-align: left;
    color: #000;
    margin-top: 4%;
    margin-bottom: 2%;
}

.s-privacy-detail p {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 25.2px;
    text-align: left;
}

.s-note-detail p {
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 40px;
    text-align: left;
    margin-bottom: 3%;
}

.p-contact_area__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 30px 2%;
    text-align: center;
}

.p-contact_area__list__item {
    background: #fff;
    padding: 45px 50px;
    width: 100%;
}

.p-contact_area__list__item p {
    line-height: 3;
}

.p-contact_area__list__item .title {
    text-align: center
}

.p-contact_area__list__item .title span {
    border-bottom: 1px solid;
    font-weight: 700;
    padding-bottom: .2em
}

.p-contact_area__list__item .office {
    margin-top: 45px;
    text-align: center
}

.p-contact_area__list__item .tel {
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-family: Work Sans, sans-serif;
    font-size: 32px;
    font-weight: 300;
    justify-content: center;
    margin-top: 24px;
    color: #111;
    font-weight: 400;
}

.p-contact_area__list__item .tel .icon {
    color: #0D39D5;
    font-size: 16px;
    margin-right: .5em
}

.p-contact_area__list__item .text {
    color: #777;
    font-size: 13px;
    line-height: 1.4;
    margin-top: 1em;
    text-align: center
}

.p-contact {
    padding-bottom: 120px;
    padding-top: 70px
}

.p-contact__form {
    margin-top: 50px
}

.p-contact__bottom {
    margin-top: 100px
}

.p-contact__bottom a {
    text-decoration: underline;
    -webkit-transition: .25s;
    transition: .25s
}

@media only screen and (max-width: 1599px) {
    .p-contact_area__list {
        gap: calc(1.22449vw + 10.40816px) 2%;
    }

    .p-contact_area__list__item {
        padding: calc(1.22449vw + 10.40816px)
    }

    .p-contact_area__list__item .office {
        margin-top: calc(2.04082vw + 12.34694px)
    }

    .p-contact_area__list__item .tel {
        font-size: calc(.97959vw + 1.23265rem);
        margin-top: calc(.97959vw + 8.32653px)
    }

    .p-contact {
        padding-bottom: calc(4.89796vw + 41.63265px);
        padding-top: calc(2.85714vw + 24.28571px)
    }

    .p-contact__form {
        margin-top: calc(2.04082vw + 17.34694px)
    }

    .p-contact__bottom {
        margin-top: calc(4.08163vw + 34.69388px)
    }
}

.p-contact_area__sns {
    text-align: center;
}

.p-contact_area__sns li {
    display: inline-block;
}

.p-contact_area__sns li>a {
    padding: 10px;
}

.p-contact_area__sns li>a img {}

.l-content--contact {
    background: #fff;
}

.s-contact {
    background-color: #FDFBF7;
    padding: 5% 0;
}

.c-form {
    margin-top: 50px
}

.c-form__item {
    border-top: 1px solid #F0F0F0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.c-form__item:last-child {
    border-bottom: 1px solid #f0f0f0
}

.c-form__item.-required .c-form__item__head__inner:after {
    border: 1px solid #85A446;
    border-radius: 2px;
    color: #85A446;
    content: "\5fc5\9808";
    font-size: 11px;
    font-weight: 500;
    line-height: 1.4;
    margin-left: .5em;
    padding: 0 .5em;
    position: absolute;
    right: 0;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.c-form__item__head {
    background: #FDFBF7;
    max-width: 250px;
    min-width: 250px;
    padding: 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: 100%;
}

.c-form__item__head__inner {
    /* -webkit-box-align: center; */
    -ms-flex-align: center;
    align-items: center;
    /* display: -webkit-box; */
    display: -ms-flexbox;
    /* display: flex; */
    font-weight: 400;
    display: block;
    position: relative;
    width: 100%;
}

.c-form__item__body {
    padding: 30px
}

.c-form__item__body input {
    border: 1px solid #f0f0f0;
    border-radius: 3px;
    line-height: 1;
    padding: 10px;
    /* width: 100%; */
}

.c-form__item__body textarea {
    border: 1px solid #f0f0f0;
    width: 100%
}

.c-form__item__postal {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 1em
}

.c-form__item__postal input {
    margin: 0 .5em;
    width: auto
}

.c-form__item__select {
    margin-top: .5em;
    position: relative;
    width: 200px
}

.c-form__item__select .icon {
    color: #0D39D5;
    position: absolute;
    right: 16px;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(90deg);
    transform: translateY(-50%) rotate(90deg)
}

.mw_wp_form_confirm .c-form__item__select .icon {
    display: none
}

.c-form__item__select select {
    border: 1px solid #f0f0f0;
    border-radius: 3px;
    cursor: pointer;
    font-size: 13px;
    line-height: 1;
    padding: 16px;
    width: 100%
}

.c-form__item__radiobox span {
    display: block
}

.c-form__item__radiobox span label {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.c-form__item__radiobox span label input {
    display: none
}

.c-form__item__radiobox span label input:checked+.mwform-radio-field-text:before {
    border: 1px solid #0D39D5
}

.c-form__item__radiobox span label input:checked+.mwform-radio-field-text:after {
    background: #0D39D5;
    border-radius: 9999px;
    content: "";
    display: block;
    height: 10px;
    height: 6px;
    left: 9px;
    position: absolute;
    top: 9px;
    -webkit-transform: translate(-50%);
    transform: translate(-50%);
    width: 6px
}

.c-form__item__radiobox span label span {
    cursor: pointer;
    padding-left: 1.7em;
    position: relative
}

.c-form__item__radiobox span label span:before {
    border: 1px solid #f0f0f0;
    border-radius: 9999px;
    content: "";
    height: 18px;
    left: 0;
    position: absolute;
    top: 3px;
    width: 18px
}

.c-form__item__checkbox span {
    display: block
}

.c-form__item__checkbox span label {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.c-form__item__checkbox span label input {
    display: none
}

.c-form__item__checkbox span label input:checked+.mwform-checkbox-field-text:before {
    background: #0D39D5;
    border: 1px solid #0D39D5
}

.c-form__item__checkbox span label input:checked+.mwform-checkbox-field-text:after {
    content: ""
}

.c-form__item__checkbox span label span {
    cursor: pointer;
    line-height: 2;
    padding-left: 1.7em;
    position: relative
}

.c-form__item__checkbox span label span:after {
    background-image: url(../image/check-solid.svg);
    background-size: cover;
    content: "";
    height: 12px;
    left: 3px;
    position: absolute;
    top: 8px;
    width: 12px
}

.c-form__item__checkbox span label span:before {
    border: 1px solid #f0f0f0;
    border-radius: 3px;
    content: "";
    height: 20px;
    left: 0;
    position: absolute;
    top: 5px;
    width: 20px
}

.c-form_submit {
    /* margin-top: 50px; */
    text-align: center
}

.c-form_submit button {
    background: #85A446;
    color: #fff;
    cursor: pointer;
    margin: 0 auto;
    position: relative;
    text-align: center;
    width: 230px;
    line-height: 50px;
    /* border-radius: 84px; */
    margin-top: 6%;
    border: 2px solid #85A446;
}

.c-form_submit button.-back {
    background: #777
}

.c-form_submit button .icon {
    left: 1em;
    position: absolute;
    top: 50%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

.c-form_submit button .icon svg {
    fill: #fff
}

.c-form_submit button .c-arrow03__wrap {
    right: 30px
}

.c-form_submit button .c-arrow03__wrap.-left {
    left: 30px;
    right: auto !important
}

.c-form_submit button .c-arrow03__wrap.-left .c-arrow03__img {
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg)
}

.c-form_submit button:hover {
    background-color: #fff;
    color: #85A446;
}

.c-form_submit button:hover:after {
    background-color: #85a446;
}

@media only screen and (max-width: 1599px) {
    .c-form {
        margin-top: calc(2.04082vw + 17.34694px)
    }

    .c-form__item__body,
    .c-form__item__head {
        padding: calc(1.22449vw + 10.40816px)
    }

    .c-form__item__body input {
        padding: calc(.40816vw + 3.46939px)
    }

    .c-form__item__select .icon {
        right: calc(.65306vw + 5.55102px)
    }

    .c-form__item__select select {
        padding: calc(.65306vw + 5.55102px)
    }

    .c-form_submit {
        /* margin-top: calc(2.04082vw + 17.34694px); */
    }

    .c-form_submit button {
        width: 230px;
    }

    .c-form_submit button .c-arrow03__wrap {
        right: calc(1.22449vw + 10.40816px)
    }

    .c-form_submit button .c-arrow03__wrap.-left {
        left: calc(1.22449vw + 10.40816px)
    }
}

.c-form_submit button:after {
    content: '';
    width: 6px;
    height: 6px;
    border-radius: 9999px;
    background-color: #fff;
    display: block;
    position: absolute;
    top: 50%;
    right: 10%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}


/*cafe*/
.l-content--cafe {
    background: #fff;
}

.cafe-banner {
    position: relative;
    padding-top: 70px;
}

.cafe-banner>img {
    width: 100%;
}

.cafe-banner .info {
    position: absolute;
    left: 20%;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -moz-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
}

.cafe-banner .info h1 {
    font-size: 3.2rem;
    font-weight: 500;
    line-height: 52px;
    letter-spacing: 10.399999618530273px;
    text-align: left;
    color: #fff;
}

.cafe-banner .info p {
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 30px;
    letter-spacing: 2.799999952316284px;
    text-align: left;
    color: #fff;
    margin-top: 7%;
}

.l-content--cafe #content {
    margin-top: 6%;
}

.l-content--concept {
    padding-bottom: 7%;
}

.concept-banner {
    position: relative;
    padding-top: 70px;
}

.concept-banner>img {
    width: 100%;
}

.concept-banner .info {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
}

.concept-banner .info h1 {
    font-size: 2.6rem;
    font-weight: 500;
    line-height: 39px;
    letter-spacing: 2.5999999046325684px;
    text-align: center;
    color: #fff;
}

.concept-banner .info p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 16px;
    letter-spacing: 0.800000011920929px;
    text-align: center;
    color: #fff;
    margin-top: 1%;
}

.s-concept-lists {
    width: 75%;
    margin: 5% auto 0 auto;
}

.s-concept-lists>h2 {
    background: #9FBA5D;
    color: #fff;
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 58px;
    letter-spacing: 1px;
    text-align: center;
}

.s-concept-lists .p-room-list {
    margin-top: 3%;
    width: 100%;
}

.s-concept-lists .p-room-item {}

.s-concept-lists .p-news-list__anker {
    padding: 0;
}

.s-concept-lists .p-room-item__text {
    margin-top: 0;
    padding: 5% 6%;
    background: #fff;
}

.s-concept-lists .p-room-item__tit {
    font-size: 2rem;
    font-weight: 500;
    line-height: 30px;
    letter-spacing: 1px;
    text-align: left;
    color: #1C1C1C;
}

.s-concept-lists .p-room-item__category {
    margin-top: 7%;
    margin-bottom: 7%;
}

.s-concept-lists .p-room-item__category img {
    margin-right: 8px;
}

.s-concept-lists .p-room-item__category span {
    margin-right: 10px;
}

.s-concept-lists .p-room-item__button {
    display: block;
    width: 70%;
    height: 45px;
    line-height: 42px;
    text-align: center;
    border: 2px solid #85A446;
    font-size: 1.4rem;
    font-weight: 700;
    letter-spacing: 2px;
    color: #85A446;
    margin-top: 3%;
    transition: all .3s
}

.s-concept-lists .p-room-item__button:hover {
    background: #85A446;
    color: #fff;
}

.s-concept__content-text h3 {
    font-size: 2rem;
    font-weight: 700;
    line-height: 30px;
    letter-spacing: 1px;
    text-align: left;
    margin-bottom: 3%;
}

.s-concept__content-text p {
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 28px;
    letter-spacing: 1px;
    text-align: left;
    color: #5C5C5C;
}

.l-room--concept {
    padding-top: 70px;
    background: #fff;
}

.l-room--concept .s-concept-lists {
    width: 90%;
    max-width: 1200px;
}

.p-room__l {
    width: 67%;
}

.p-room__l .p-room__back {
    display: block;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 30px;
    letter-spacing: 1px;
    text-align: left;
    color: #1C1C1C;
    margin-bottom: 4%;
}

.p-room__l .p-room__pics {
    overflow: hidden;
    position: relative;
}

.p-room__l .p-room__pics .mySwiper2 {}

.p-room__l .p-room__pics .mySwiper {
    margin-top: 2%;
}

.p-room__l .p-room__pics .mySwiper .swiper-slide>img {
    width: 100%;
}

.p-room__l .p-room__pics .mySwiper2 .swiper-slide>img {
    width: 100%;
}

.p-room__l .swiper-button-next {
    background-image: url('../images/arrowR.png');
    width: 54px;
    height: 54px;
    background-size: 54px 54px;
}

.p-room__l .swiper-button-prev {
    background-image: url('../images/arrowL.png');
    width: 54px;
    height: 54px;
    background-size: 54px 54px;
}

.p-room__l .p-room__content {
    margin-top: 8%;
    margin-bottom: 8%;
}

.p-room__l .p-room__content p {
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 30.6px;
    text-align: left;
}

.p-room__l .p-room__content>h3 {
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 30px;
    text-align: left;
}

.p-room__l .p-room__content ul {
    overflow: hidden;
    margin-top: 3%;
}

.p-room__l .p-room__content ul li {
    float: left;
    width: calc(100% / 3 - 2%);
    font-size: 1.7rem;
    font-weight: 500;
    line-height: 20.4px;
    text-align: left;
    margin-right: 2%;
    border-radius: 20px;
    border: 1px solid #E5E5E5;
    padding: 10px;
    margin-bottom: 2%;
    min-height: 58px;
}

.p-room__l .p-room__content ul li:nth-child(3n+3) {
    margin-right: 0;
}

.p-room__l .p-room__content ul li img {
    margin-right: 10px;
}

.p-room__content hr {
    border: none;
    height: 1px;
    margin: 5% 0;
    background-color: #E6E6E6;
}

.p-room__r {
    width: 23%;
    position: fixed;
    top: 21%;
    right: 10%;
    z-index: 111111111;
    background: #FDFBF7;
}

.p-room__r .p-room-list {}

.p-room__r .p-room-item {
    width: 100%;
}

.p-room__r .p-room-item__text,
.p-room__r .p-news-list__anker {
    background: #FDFBF7;
}

.p-room__r .p-room-item__button {
    background-color: #85A446;
    color: #fff;
    width: 100%;
    border-radius: 5px;
    height: 62px;
    line-height: 62px;
    margin-bottom: 15%;
    margin-top: 10%;
}

.p-room__r .p-room-item__price {
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 27px;
    letter-spacing: 1px;
    text-align: left;
    margin-bottom: 8%;
}

.p-room__r .p-room-item__price span {
    font-size: 1.8rem;
    font-weight: 600;
    line-height: 27px;
    letter-spacing: 1px;
    text-align: left;
    display: block;
}

.l-footer__middle {
    width: 50%;
    max-width: 700px;
}

@media only screen and (max-width: 767px) {
    .c-form__item {
        display: block
    }

    .c-form__item__head {
        max-width: 100%;
        min-width: 100%
    }

    .c-form_submit button {
        width: 100%
    }

    .c-form_submit button.-back {
        margin-bottom: 1em
    }

    .c-form__item__body input {
        width: 100%;
    }
}

@media screen and (max-width: 599px) {
    .l-footer__middle {
        width: 100%;
        text-align: center;
        display: none;
    }

    .l-footer__other {
        text-align: center;
    }

    .index-banner {
        padding-top: 0;
    }

    .index-banner .swiper-slide .info {
        width: 96%;
    }

    .index-banner .swiper-slide .info p {
        font-size: 1.3rem;
        line-height: 1.5;
    }

    .index-banner .swiper-slide .info img {
        width: 100px;
    }

    .s-top-concept__bg,
    .s-top-concept__bg>img {
        width: 100%;
    }

    .l-header-top .logo {
        margin-top: 0;
    }

    .l-information-map {
        height: auto;
    }

    .l-information-img {
        position: static;
        width: 100%;
    }

    .concept-banner {
        padding-top: 0;
        height: 180px;
    }

    .cafe-banner {
        padding-top: 0;
        height: 250px;
    }

    .concept-banner>img,
    .cafe-banner>img {
        height: 100%;
        object-fit: cover;
    }

    .cafe-banner .info {
        left: 5%;
        width: 90%;
    }

    .cafe-banner .info p {
        line-height: 1.5;
        margin-top: 3%;
        text-shadow: 1px 1px 1px rgba(0, 0, 0, .5);
    }

    .cafe-banner .info h1 {
        font-size: 2.2rem;
        letter-spacing: 5px;
    }

    .s-concept-lists {
        width: 90%;
        margin-bottom: 10%;
    }

    .l-room--concept {
        padding-top: 0;
    }

    .p-room__r {
        position: static;
        width: 100%;
        margin-bottom: 5%;
    }

    .p-room__l {
        width: 100%;
    }

    .p-room__l .p-room__content ul li {
        width: 100%;
        margin-right: 0;
    }

    /*.p-room__l .p-room__content p{
        font-size: 1.4rem;
    }*/

    .l-content--news,
    .l-content--information {
        padding-top: 10%;
    }

    .s-information__list-title:nth-of-type(1) {
        padding-top: 10px;
        padding-bottom: 10px;
    }

    .s-concept-lists .p-room-item__button {
        margin-top: 8%;
        margin-bottom: 6%;
    }
}