@charset "utf-8";

/*
font-family: 'Noto Sans JP', sans-serif;
font-family: 'Noto Serif JP', serif;
font-family: 'dftlei5';
*/

@font-face {
    font-family: 'dftlei5';
    src: url('../font/dftlei5.ttf') format("truetype");
}


html {
    font-family: 'dftlei5';
    caret-color: transparent;
    max-width: 750px;
    margin: 0 auto;
}
body {
    background: #fff;
    color: #1e1e1e;
    min-width: auto;
    margin: 0 auto;
}
.inner {max-width: 1180px;width: 100%;margin: 0 auto;box-sizing: border-box;}
.inner_s {max-width: 1080px;width: 100%;margin: 0 auto;box-sizing: border-box;}

.marker {background: linear-gradient(transparent 60%, rgba(249, 240, 78, 0.8) 60%);}

.fmctr {
    caret-color: #1e1e1e;
    border-radius: 0.3em
}

/* **************************************************************** */
/* ヘッダー
*/
header.flex {
    background: #cfbfae;
    align-items: center;
    justify-content: space-between;
}
.header_logo {
    padding: 0.5em 1em;
}
.header_reserve {

}
.header_reserve a {
    display: block;
    background: #960000;
    color: #fff;
    padding: 0.5rem 3rem 1rem 2rem;
    text-decoration: none;
    position: relative;
}
.header_reserve a:hover {
    background: #AB3333;
}
.header_reserve a span {
    display: block;
    font-size: 18px;
    line-height: 1em;
}
.header_reserve a em {
    display: block;
    font-size: 36px;
    line-height: 1em;
}

.header_reserve a:after {
    content: "";
    width: 29px;
    height: 15px;
    background: url(../images/icon_arrow.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    right: 1rem;
}




/* **************************************************************** */
/* フッター
*/
footer {
    background: #000;
    color: #fff;
    padding: 2rem 0 0;
}

.footer_logo {
    margin-bottom: 2rem;
}
.footer_logo img {
    display: block;
    margin: 0 auto;
}
.footer_logo a {
    display: inline-block;
    color: #fff;
    text-decoration: none;
    font-size: 30px;
    line-height: 1em;
}
.footer_logo a:hover {

}

.footer_sns {
    margin-bottom: 2rem;
}
.footer_sns ul {
    align-items: center;
    justify-content: center;
    gap: 1rem;
}
.footer_sns ul li {

}

footer .btn_bloc {
    margin-bottom: 2rem;
}

footer .copy {
    display: block;
    background: #000;
    color: #fff;
    font-size: 16px;
    line-height: 1;
    padding: 1em 0 1em;
}

/* **************************************************************** */
/* 個別CSS
*/
main {
    background: #cfbfae;
}

.mv {
    position: relative;
}
.mv_logo {
    position: absolute;
    top: 2em;
    left: 2em;
}
.mv figure {

}

.message {
    padding: 3rem 2rem 1rem;
    overflow: hidden;
}
.message h2 {
    font-size: 64px;
    line-height: 1.4em;
    font-weight: normal;
}
.message p {
    font-size: 30px;
    line-height: 1.6em;
    text-align: left;
}

.about {
    padding: 3rem 0 1rem;
    text-align: left;
    overflow: hidden;
}
.about h2 {
    display: inline-block;
    background: #960000;
    color: #fff;
    font-size: 58px;
    line-height: 1em;
    font-weight: normal;
    padding: 0.5rem 1rem;
    margin-bottom: 2rem;
}
.about h2 span {

}
.about figure {
    text-align: right;
    margin-bottom: 2rem;
}
.about p {
    font-size: 30px;
    line-height: 1.6em;
    text-align: left;
    padding: 0 2rem;
}

.floor {
    padding: 3rem 0;
    overflow: hidden;
}
.floor_upper {
    align-items: flex-start;
    justify-content: center;
    gap: 2rem;
    padding: 0 2rem;
    margin-bottom: 3rem;
}
.floor_upper h2 {

}
.floor_upper figure {
    
}

.floor_bloc {
    margin-bottom: 3rem;
}
.floor_item {

}
.floor_item + .floor_item {
    margin-top:3rem;
}

.floor_meta {
    padding: 0 2rem;
    margin-bottom: 1rem;
}
.floor_meta h3 {
    font-size: 48px;
    line-height: 1em;
    font-weight: normal;
}
.floor_meta p {
    font-size: 30px;
    line-height: 1.2em;
}

.floor_item:nth-child(odd) .floor_meta {
    text-align: left;
}
.floor_item:nth-child(even) .floor_meta {
    text-align: right;
}

.floor_item:nth-child(odd) .floor_photo figure {
    text-align: left;
    padding-right: 2rem;
}
.floor_item:nth-child(even) .floor_photo figure {
    text-align: right;
    padding-left: 2rem;
}

.floor_photo {

}
.floor_photo figure {
    
}
.floor_photo figure + figure {
    margin-top: 2rem;
    padding-left: 2rem;
    padding-right: 0 !important;
    text-align: right !important;
}

.floor_inside {

}
.floor_inside figure {
    
}
.floor_inside figure figcaption {
    font-size: 48px;
    line-height: 1em;
    font-weight: normal;
    margin-bottom: 0.5rem;
    padding: 0 2rem;
}

.floor_inside figure + figure {
    margin-top: 2rem;
}
.floor_inside figure:nth-child(odd) {
    text-align: right;
}
.floor_inside figure:nth-child(even) {
    text-align: left;
}

.menu {
    background: url(../images/bg_menu.png) no-repeat center bottom;
    background-size: cover;
    padding: 3rem 2rem;
}
.menu h2 {
    color: #e50012;
    font-size: 60px;
    line-height: 1em;
    font-weight: normal;
    margin-bottom: 2rem;
}
.menu p {
    color: #fff;
    font-size: 26px;
    line-height: 1.6em;
    margin-bottom: 2rem;
}
.menu a {
    display: block;
    color: #fff;
    text-decoration: none;
    font-size: 42px;
    line-height: 1em;
    border: solid 1px #fff;
    padding: 1rem;
    position: relative;
}
.menu a:hover {
    background: #960000;;
    color: #fff;
}
.menu a:after {
    content: "";
    width: 29px;
    height: 15px;
    background: url(../images/icon_arrow.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    right: 2rem;
}

.cv {
    padding:3rem 0;
}

.btn_bloc {
    margin: 0 2em;
    background: #fff;
    border-radius: 100px;
}
.btn_bloc a {
    display: block;
    background: #960000;
    color: #fff;
    padding: 1rem 3rem 1rem 3rem;
    text-decoration: none;
    position: relative;
    width: 100%;
    box-sizing: border-box;
    border-radius: 100px;
}
.btn_bloc a:hover {
    background: #AB3333;
}
.btn_bloc a:after {
    content: "";
    width: 29px;
    height: 15px;
    background: url(../images/icon_arrow.png) no-repeat;
    background-size: contain;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    right: 2rem;
}
.btn_bloc a span {
    display: block;
    font-size: 18px;
    line-height: 1em;
}
.btn_bloc a em {
        display: block;
    font-size: 36px;
    line-height: 1em;
}

.information {
    padding: 3rem 0;
}
.information .ttl_bloc {
    margin-bottom: 2rem;
}
.information .ttl_bloc span {
    font-size: 48px;
    line-height: 1em;
}
.information .ttl_bloc h2 {
    font-size: 30px;
    line-height: 1em;
    font-weight: normal;
}
.information_bloc {
    align-items: center;
    justify-content: space-between;
}
.information_bloc figure {
    flex: 1 0 0%;
}

.information_box {
    width: 60%;
    text-align: left;
    padding: 0 2rem;
    box-sizing: border-box;
}
.information_box dl {
    
}
.information_box dl + dl {
    margin-top:1rem;
}
.information_box dl dt {
    font-size: 30px;
    line-height: 1.4em;
}
.information_box dl dd {
    font-size: 21px;
    line-height: 1.4em;
}
.information_box dl dd .mini {
    display: block;
    font-size: 16px;
    line-height: 1.2em;
}

.map {

}
.gmap {
    aspect-ratio: 4 / 2;
}
.gmap iframe {
    display: block;
    width: 100%;
    height: 100%;
}


