@charset "utf-8";
@import url('https://fonts.googleapis.com/css?family=Noto+Serif+JP:900&display=swap');
/*--------------------------------------

Theme Name: unit_TM2_KITCHEN
Author: PPAW unit
Version:1.0

--------------------------------------*/
/*/////////////////////////////////////////////////////
///////////////////////////////////////////////////////
///////////////////////////////////////////////////////

reset

///////////////////////////////////////////////////////
///////////////////////////////////////////////////////
/////////////////////////////////////////////////////*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-style: normal;
    font-weight: normal;
    font-size: 100%;
    vertical-align: baseline;
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
    display: block;
}
html {
    overflow-y: scroll;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after, q:before, q:after {
    content: '';
    content: none;
}
input, textarea, {
    margin: 0;
    padding: 0;
}
ol, ul {
    list-style: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}
caption, th {
    text-align: left;
}
a:focus {
    outline: none;
}
.clearfix:after {
    content: ".";
    display: block;
    clear: both;
    height: 0;
    visibility: hidden;
}
.clearfix {
    min-height: 1px;
}
* html .clearfix {
    height: 1px;
}
.both {
    clear: both;
}
.inline_block {
    display: inline-block;
    *display: inline;
    *zoom: 1;
}
/*/////////////////////////////////////////////////////
///////////////////////////////////////////////////////
///////////////////////////////////////////////////////

common

///////////////////////////////////////////////////////
///////////////////////////////////////////////////////
/////////////////////////////////////////////////////*/
/******************************************

common_pc

******************************************/
* {
    box-sizing: border-box;
}
.sp_v {
    display: none;
}
.clearfix:after {
    content: ".";
    height: 0;
    clear: both;
    display: block;
    visibility: hidden;
}
.clearfix {
    zoom: 100%;
}
.fl_left {
    float: left;
}
.fl_right {
    float: right;
}
.ib_wrap {
    letter-spacing: -0.4em;
}
.ib_box {
    letter-spacing: 0;
    display: inline-block;
    vertical-align: top;
}
.flex_wrap {
    display: flex;
    justify-content: flex-end;
}
.flex_item {
    display: flex;
}
a {
    text-decoration: none;
    outline: none;
    color: inherit;
    transition: .3s;
    opacity: 1;
}
a:hover {
    opacity: 0.6;
}
img {
    vertical-align: top;
    max-width: 100%;
    height: auto;
}
section {
    width: 100%;
    padding: 70px 0;
    position: relative;
}
/******************************************

common_sp

******************************************/
@media (max-width: 767px) {
    .pc_v {
        display: none;
    }
    .sp_v {
        display: inherit;
    }
    section {
        padding: 20px 0;
    }
}
/*/////////////////////////////////////////////////////
///////////////////////////////////////////////////////
///////////////////////////////////////////////////////

pc

///////////////////////////////////////////////////////
///////////////////////////////////////////////////////
/////////////////////////////////////////////////////*/
/*/////////////////////////////////////////////////////

common

/////////////////////////////////////////////////////*/
html {
    display: block;
    height: 100%;
}
body {
    font-size: 12px;
    font-family: "Hiragino Mincho ProN", "ヒラギノ明朝 ProN W3", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", serif;
    line-height: 180%;
    display: block;
    color: #2d2d2d;
    position: relative;
    height: 100%;
    background: url(library/img/bg1.png);
    background-size: 500px 500px;
}
.heading {
    background-color: #ffffff;
    color: #221916;
    padding: 5px 50px;
}
#body_inner {
    height: 100%;
    width: 100%;
    position: relative;
}
@media screen and (max-width:767px) {
    .heading {
        padding: 5px 3%;
    }
    #body_inner {
        background-size: 100%;
        overflow-x: hidden;
    }
}
.fadein {
    transition: .8s ease-out;
    opacity: 0;
    transform: translate(0, 40px);
    -webkit-transform: translate(0, 40px);
}
.fadein.active {
    transition: .8s;
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}
/*load*/
#loader-bg {
    width: 100%;
    height: 100vh !important;
    position: fixed;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    z-index: 50000;
    background: #fff;
}
#loading {
    position: absolute;
    height: auto;
    top: 50%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    -webkit- transform: translateY(-50%) translateX(-50%);
    display: none;
}
/*container*/
#container {
    width: 100%;
    position: relative;
    margin: 0 auto;
    z-index: 10;
}
#top #container {
    background: #ffffff;
}
#contents_wrap {
    width: 100%;
    display: flex;
}
#main_contents {
    width: calc(100% - 255px);
    border-left: 37px solid #133300;
    padding: 0 50px;
}
#top #main_contents {
    padding: 0;
}
#main_contents section {
    max-width: 900px;
    margin-left: auto;
    margin-right: auto;
}
#top #main_contents section {
    max-width: none;
}
#sidebar {
    width: 255px;
    padding: 20px 20px 30px;
    background: #061723;
}
:not(#top) #main_contents {
    width: 100%;
}
:not(#top) #sidebar {
    display: none;
}
/*ttl*/
#main_contents h2 {
    font-size: 1.25rem;
    color: #997300;
    font-weight: bold;
    margin-bottom: 1rem;
}
#main_contents h2 span {
    font-size: 13px;
    color: #8f8f8f;
    letter-spacing: 0;
    font-weight: bold;
    display: inline-block;
    margin-left: 10px;
}
#section_ttl {
    padding-bottom: 10px;
    border-bottom: 1px solid #e5e5e5;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 60px;
}
#section_ttl p {
    width: 70%;
    line-height: 150%;
}
.menu_list_cat_craft {
    position: relative;
}
.menu_list_cat_craft::before {
    position: absolute;
    content: '';
    top: -2rem;
    bottom: -2rem;
    left: -2rem;
    right: -2rem;
    background-color: rgb(222 120 43 / 5%);
    transform: rotate(-1deg);
}
.menu_cat_ttl {
    position: relative;
    margin-bottom: 50px;
    margin-top: 80px;
}
.menu_cat_ttl span {
    position: absolute;
    right: 0;
    bottom: 0;
    color: #c14406;
    font-weight: bold;
}
.menu_cat_ttl:after {
    content: "　";
    position: absolute;
    bottom: -5px;
    left: 0;
    width: 100%;
    height: 1px;
    background: #997300;
    z-index: 40;
}
.menu_cat_ttl strong {
    font-size: 17px;
    font-weight: bold;
    padding-right: 10px;
    position: relative;
    color: #997300;
    z-index: 50;
}
/*breadcrumb*/
#breadcrumb {
    padding: 10px 10px 10px 50px;
    background: #133300;
    color: #fff;
}
/*/////////////////////////////////////////////////////

header

/////////////////////////////////////////////////////*/
/*top_sns*/
#top_sns {
    position: absolute;
    display: flex;
    justify-content: flex-end;
    right: 10px;
    top: 10px;
}
#top_sns a {
    width: 36px;
    padding: 10px;
}
#top_sns a img {
    width: 100%;
    display: block;
    filter: invert(1);
}
/*top_btn*/
#top_btn {
    position: absolute;
    top: 22px;
    left: 130px;
    height: 113px;
    background-color: #fea700;
    z-index: 5500;
    transition: 1s ease-out;
}
#top_btn.slideup {
    display: none;
}
.top_btn_inner {
    position: relative;
    height: 100%;
}
#top_btn a {
    display: block;
    width: 140px;
}
.top_btn_rsv {
    background-color: #ae221b;
    padding: 0 5px;
}
.top_btn_tel_2 {
    background: url(library/img/btn_tel_bg.png) no-repeat;
    background-size: 100%;
    height: 56px;
    overflow: hidden;
    padding: 25px 5px 0 5px;
    background-color: #fea700;
}
.top_btn_tel_2 span {
    font-family: 'Noto Serif JP', serif;
    font-size: 17px;
    letter-spacing: 0;
}

/*header*/
header {
    position: relative;
    z-index: 5000;
}
#header_nav {
    display: flex;
    justify-content: flex-start;
    width: 40%;
}
@media screen and (min-width:768px) {
    #body_inner > header #header_nav {
        width: 100%;
        padding: 20px;
        background: #fff;
    }
    #body_inner > header #header_nav h1 {
        position: absolute;
        left: 30px;
        top: 15px;
        width: 130px;
        height: 113px;
    }
    #body_inner > header #header_nav .header_nav_list {
        justify-content: flex-end;
        justify-content: flex-start;
        margin-left: 7rem;
    }
    #body_inner > header #header_nav .header_nav_list a {
        padding: 0 1.25rem;
        border-right: 1px solid rgb(255 255 255 / 0.5);
    }
    #body_inner > header #header_nav .header_nav_list a:last-child {
        border-right: none;
    }
}
@media screen and (min-width: 1368px) {
    #body_inner > header #header_nav .header_nav_list a {
        padding: 0 2rem;
        border-right: 1px solid rgb(34 25 22 / 25%);
    }
}
@media screen and (min-width: 1441px) {
    #body_inner > header #header_nav .header_nav_list {
        justify-content: center;
        justify-content: flex-start;
        margin-left: 7rem;
    }
}
#header_nav h1 {
    background: #fff;
}
#header_nav h1 a {
    display: block;
    height: 100%;
}
#header_nav h1 a img {
    width: 100%;
    height: 100%;
    object-fit: contain;
}
.header_nav_list {
    padding: 0;
    background: #ffffff;
    display: flex;
    justify-content: space-between;
    width: 0;
    transition: 1s ease-out;
    overflow: hidden;
}
.header_nav_list.active {
    width: 100%;
    padding: 0 20px;
}
.header_nav_list a {
    padding: 20px 10px;
    display: block;
    position: relative;
    font-size: 13px;
    font-weight: bold;
    color: #221916;
    white-space: nowrap;
}
.header_nav_list a:hover {
    opacity: 0.25;
}
/* fix_nav */
#fix_nav {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 8000;
    width: 100%;
    display: none;
}
#fix_nav header {
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    box-shadow: 0px 5px 10px 0px rgb(0 0 0 / 10%);
    background: #ffffff;
}
#fix_nav header #header_nav {
    position: static;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    width: 100%;
}
#fix_nav header #header_nav h1 a {
    height: 60px;
    padding: 0 10px;
}
#fix_nav header #header_nav h1 img {
    max-width: 100px;
}
#fix_nav header #header_nav .header_nav_box {
    display: flex;
    height: 62px;
}
#fix_nav header #header_nav #top_btn {
    position: static;
    top: 0;
    left: 0;
    height: auto;
    z-index: 0;
}
#fix_nav header #header_nav #top_btn a.top_btn_rsv {
    height: 50%;
    overflow: hidden;
    display: flex;
    justify-content: center;
    align-items: flex-end;
}
#fix_nav header #header_nav #top_btn a.top_btn_tel_2 {
    padding: 5px;
    background: none;
    height: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
}
#fix_nav header .header_nav_list {
    margin-top: 0;
    padding: 0 20px;
    width: auto;
    background: #ffffff;
}
#fix_nav header .header_nav_list a {
    -webkit-writing-mode: horizontal-tb;
    -ms-writing-mode: lr-tb;
    writing-mode: horizontal-tb;
    padding: 20px 20px;
    width: auto;
    text-align: center;
}
#fix_nav header #top_sns {
    display: none;
    position: absolute;
    right: 15px;
    left: auto;
    top: 15px;
}
#menu-trigger-box {
    display: none;
}
.sp_logo {
    display: none;
}
/*/////////////////////////////////////////////////////

mainv

/////////////////////////////////////////////////////*/
/*mainv*/
.home_wrap {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    flex-direction: row-reverse;
    height: calc(45vw + 35px);
    background-image: linear-gradient(0deg, #133300 0px,#133300 35px,#fff 35px);
}
.mainv_wrap {
    width: 70%;
    transition: 1s ease-out;
    opacity: 1;
    transform: translate(-100%, 0);
    -webkit-transform: translate(-100%, 0);
    position: relative;
    z-index: 20;
}
#mainv {
    width: 100%;
    transform: translate(100%, 0);
    -webkit-transform: translate(100%, 0);
}
#mainv .slick-track {
    height: 100%;
}
#mainv .slick-list {
    height: 45vw;
    overflow: hidden;
}
#mainv .slide_list img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.slick_counter {
    color: #fff;
    line-height: 35px;
    text-align: center;
}
.fv2_wrap {
    width: 30%;
    padding-bottom: 35px;
    position: relative;
    z-index: 4000;
    transition: 1s ease-out;
    opacity: 1;
    transform: translate(-100%, 0);
    -webkit-transform: translate(-100%, 0);
}
.fv2 {
    height: 41.5vw;
    transform: translate(100%, 0);
    -webkit-transform: translate(100%, 0);
}
.fv2 .slick-list {
    height: 100%;
}
.fv2 .slick-track {
    height: 100%;
}
.fv2 .slick-track img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.mainv_wrap.active, .fv2_wrap.active, .mainv_wrap.active #mainv, .fv2_wrap.active .fv2 {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}
.slick-next:before, .slick-prev:before {}
#under_mainv {
    height: 300px;
    overflow: hidden;
}
#under_mainv img {
    object-fit: cover;
    width: 100%;
    height: 300px;
}
#lunch_page #under_mainv img {
    object-position: 0 65%;
}
#course_page #under_mainv img {
    object-position: 0 45%;
}
#food_page #under_mainv img {
    object-position: 0 45%;
}
#drink_page #under_mainv img {
    object-position: 0 -50px;
}
.single #under_mainv {
    height: 125px;
}
/*/////////////////////////////////////////////////////

top

/////////////////////////////////////////////////////*/
/*about*/
#about {
    background-size: cover;
    background-attachment: fixed;
    position: relative;
    text-align: center;
    min-height: 80vh;
    display: flex;
    justify-content: center;
    align-items: flex-end;
    padding: 0;
}
.about_lead {
    background: rgba(255, 255, 255, 0.95);
    display: block;
    width: auto;
    margin: 0 auto 2rem;
    opacity: 0;
    transition: .8s ease-out;
    opacity: 0;
    transform: translate(0, 40px);
    -webkit-transform: translate(0, 40px);
}
.about_lead.active {
    opacity: 1;
    transition: .8s ease-out;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}
.about_lead_inner {
    padding: 1rem 1rem 0.5rem;
    max-width: 830px;
    font-family: sans-serif;
}
@media screen and (min-width:768px) {
.about_lead_inner {
    padding: 2rem 2.5rem;
}
}
#main_contents .about_lead h2 {
    margin-bottom: 2rem;
    font-size: 1.35rem;
    line-height: 1.5;
    margin-bottom: 0.75rem;
}
#main_contents .about_lead h3 {
    margin-bottom: 1.35rem;
    font-size: 1.25rem;
    color: #997300;
    font-weight: bold;
    line-height: 1.5;
}
.about_lead p {
    font-size: 0.9rem;
    line-height: 1.5;
    margin-bottom: 1rem;
}
.about_lead p:first-of-type {
    color: #133300;
}
/*linkbox_wrap*/
#linkbox_wrap {
    padding: 0;
}
.linkboxinner {
    background: #ffffff;
    overflow: hidden;
    padding: 30px;
}
.linkboxinner.fadein {
    opacity: 1;
    transform: translate(-99%, 0);
    -webkit-transform: translate(-99%, 0);
    transition: 1.0s ease-in-out;
}
.linkboxinner.fadein.active {
    transition: 1.0s ease-in-out;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}
.linkbox_half_wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 80%;
    margin: 0 auto;
    position: relative;
}
.linkbox_half_list {
    width: 32%;
    background: #fff;
    transition: .8s ease-in-out;
    opacity: 0;
}
.linkbox_half_list:nth-child(1) {
    transform: translate(0, 40px);
    -webkit-transform: translate(0, 40px);
}
.linkbox_half_list:nth-child(2) {
    transform: translate(0, 40px);
    -webkit-transform: translate(0, 40px);
}
.linkbox_half_list:nth-child(3) {
    transform: translate(0, 40px);
    -webkit-transform: translate(0, 40px);
}
.linkboxinner.fadein.active .linkbox_half_list {
    opacity: 1;
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0);
}
.linkboxinner.fadein.active .linkbox_half_list:nth-child(1) {
    transition: .8s ease-in-out .6s;
}
.linkboxinner.fadein.active .linkbox_half_list:nth-child(2) {
    transition: .8s ease-in-out .8s;
}
.linkboxinner.fadein.active .linkbox_half_list:nth-child(3) {
    transition: .8s ease-in-out 1.0s;
}
.linkbox_img {
    display: block;
    box-sizing: content-box;
    width: 100%;
    background-size: 102% !important;
    transition: .3s;
    vertical-align: top;
}
.linkbox_img:hover {
    background-size: 110% !important;
    opacity: 1 !important;
}
.linkbox_list h3 {
    margin-bottom: 10px;
    font-weight: bold;
    font-size: 14px;
}
.linkbox_list h3:after {
    content: "　";
    width: 47px;
    height: 2px;
    background: #997300;
    display: block;
    margin-top: 7px;
}
.linkbox_list h3 span {
    color: #8f8f8f;
    font-weight: bold;
    font-size: 12px;
    display: inline-block;
    margin-left: 8px;
}
.linkbox_contents {
    padding: 20px;
}
.linkbox_half_list .linkbox_img {
    padding-bottom: 84%;
}
/*smile*/
#smile {
    display: flex;
    justify-content: space-around;
    background: #c14406;
    padding: 0;
}
#smile > div {
    width: 50%;
}
.smile_ttl {
    color: #fff;
    position: relative;
}
.smile_ttl_inner {
    position: absolute;
    top: 30%;
    left: 10%;
}
.smile_ttl h2 {
    width: 233px;
    margin-bottom: 30px;
}
.smile_ttl > a {
    color: #fff;
    position: absolute;
    bottom: 30px;
    left: 10%;
    border: 1px solid #fff;
    padding: 10px 100px;
    display: inline-block;
}
.smile_ttl > a:before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    content: '';
    background: #fff;
    transform-origin: left top;
    transform: scale(0, 1);
    transition: transform .3s;
}
.smile_ttl > a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1);
}
.smile_ttl > a:hover {
    opacity: 1;
    color: #c14406;
}
.smile_img a {
    display: block;
    width: 100%;
}
.smile_img a img {
    width: 100%;
    height: auto;
    display: block;
}
/*footer_voice*/
#footer_voice {
    display: flex;
    padding: 0;
}
.footer_voice_title {
    width: 25%;
    display: flex;
    justify-content: center;
    align-items: center;
}
.footer_voice_title h2 {
    width: 190px;
}
.footer_voice_body {
    width: 75%;
    background-color: #fff;
}
.footer_voice_body iframe {
    background-color: #ffffff;
}
@media screen and (max-width:767px) {
    #footer_voice {
        flex-direction: column;
    }
    .footer_voice_title {
        width: 100%;
        padding: 40px 5%;
        justify-content: flex-start;
        height: auto;
        min-height: auto;
    }
    .footer_voice_title h2 {
        width: 40%;
    }
    .footer_voice_body {
        width: 100%;
        padding: 0 5% 30px;
    }
}
/*footer_gallery*/
#footer_gallery {
    display: flex;
    justify-content: space-around;
    padding: 0;
    background: #221916;
}
.footer_gallery_list {
    width: 25%;
}
.footer_gallery_list img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.footer_gallery_ttl {
    background: #133300;
    position: relative;
    text-align: center;
}
.footer_gallery_ttl h2 {
    width: 160px;
    margin: 0 auto;
    padding-top: 45%;
}
.footer_gallery_ttl > a {
    display: block;
    width: 60%;
    padding: 5px;
    margin: auto;
    position: absolute;
    bottom: 30px;
    left: 0;
    right: 0;
    color: #fff;
    border: 1px solid #fff;
}
.footer_gallery_ttl > a:before {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    z-index: -1;
    content: '';
    background: #fff;
    transform-origin: left top;
    transform: scale(0, 1);
    transition: transform .3s;
}
.footer_gallery_ttl > a:hover:before {
    transform-origin: left top;
    transform: scale(1, 1);
}
.footer_gallery_ttl > a:hover {
    color: #061723;
    opacity: 1;
}
/*/////////////////////////////////////////////////////

footer

/////////////////////////////////////////////////////*/
#footer_wrap {
    border-left: 37px solid #133300;
}
/*access*/
#access {
    margin-top: -50px;
    padding-top: 50px;
    padding-bottom: 0;
}
.access_header {
    display: flex;
}
.access_header .access_ttl {
    width: 25%;
    background: #133300;
    height: 400px;
    min-height: 200px;
    display: flex;
    justify-content: center;
    align-items: center;
}
#top .access_header .access_ttl {
    background: none;
}
.access_header .access_ttl h2 {
    text-align: center;
}
.access_header .access_ttl h2 img {
    width: 167px;
    height: auto;
}
#map {
    width: 75%;
    height: 400px;
}
#map > iframe {
    width: 100%;
    height: 100%;
}
.access_contents {
    background: #fff;
    padding: 50px;
    display: flex;
    justify-content: space-between;
}
.access_contents table {
    width: 48%;
}
.access_contents table tr th {
    padding: 0 10px 10px 0;
    width: 100px;
}
.access_contents table tr td {
    padding: 0 0 10px 10px;
}
.access_contents table tr:last-child th {
    padding: 0 10px 0 0;
}
.access_contents table tr:last-child td {
    padding: 0 0 0 10px;
}
.access_contents table tr th {
    border-right: 1px solid #e5e5e5;
}
.access_contents table tr th span, .access_contents table tr td span {
    border-top: 1px solid #e5e5e5;
    display: block;
    height: 100%;
    padding-top: 10px;
    padding-left: 5px;
    font-size: 13px;
}
.access_contents table tr:first-child th span, .access_contents table tr:first-child td span {
    border-top: none;
    padding-top: 0;
}
.access_contents table tr th span {
    color: #997300;
    font-weight: bold;
}
/*footer_sns*/
#footer_sns {
    width: 100%;
    padding: 20px 50px;
    background: #7c6449;
    color: #fff;
}
.footer_sns h3 {
    font-weight: bold;
    font-size: 14px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 30px;
}
.footer_sns a {
    width: 23px;
    display: inline-block;
    vertical-align: middle;
    margin-right: 10px;
}
.footer_sns a:last-child {
    margin-right: 0;
}
.paid_media {
    color: #fff;
    margin-top: 20px;
}
.paid_media a {
    margin-right: 15px;
    padding-right: 15px;
    border-right: 1px solid #fff;
}
.paid_media a:last-child {
    margin-right: 0;
    padding-right: 0;
    border-right: none;
}
/*footer*/
footer {
    background: #ffffff;
    position: relative;
    z-index: 1000;
    padding: 60px 0 0;
}
.footer_inner {
    padding: 0 50px;
}
#footer_logo {
    display: none;
    text-align: center;
    margin-bottom: 30px;
    max-width: 100%;
}
#footer_logo a {
    display: inline-block;
}
#footer_nav {
    margin-bottom: 50px;
}
.footer_nav1 {
    margin-bottom: 20px;
}
#footer_nav a {
    color: #000;
    display: inline-block;
    padding: 0 30px;
    border-right: 1px solid #000;
    font-size: 14px;
}
#footer_nav a:first-child {
    padding: 0 30px 0 0;
}
#footer_nav a:last-child {
    padding: 0 0 0 30px;
    border-right: 0;
}
#copy {
    background: #133300;
    color: #fff;
    font-size: 12px;
    padding: 5px 50px;
}
/*totop*/
#totop {
    position: fixed;
    bottom: 20px;
    right: 20px;
    display: none;
    z-index: 1020;
}
/*/////////////////////////////////////////////////////

sidebar

/////////////////////////////////////////////////////*/
/*common*/
.side_contents {
    margin-top: 30px;
    padding-bottom: 30px;
    color: #fff;
}
.side_contents:first-of-type {
    margin-top: 0;
}
.side_contents:last-of-type {
    border-bottom: 0;
    padding-bottom: 0;
}
.side_ttl {
    position: relative;
    margin-bottom: 20px;
}
.side_ttl h3 {
    font-size: 14px;
    font-weight: bold;
    padding-left: 36px;
    letter-spacing: 0.1em;
    line-height: 100%;
    color: #fff;
}
.side_ttl h3 span {
    font-size: 11px;
    font-weight: bold;
    color: #fff;
    display: block;
    margin-bottom: 5px;
}
.side_ttl h3:before {
    content: "　";
    width: 24px;
    height: 24px;
    display: inline-block;
    position: absolute;
    top: 3px;
    left: 0;
}
.side_ttl a {
    font-size: 12px;
    font-weight: bold;
    position: absolute;
    bottom: 0;
    right: 0;
}
#side_tw .side_ttl h3:before {
    background: url(library/img/icn_tw3.png) center center no-repeat;
    background-size: contain;
}
#side_fb .side_ttl h3:before {
    background: url(library/img/icn_fb2.png) center center no-repeat;
    background-size: contain;
}
#side_ig .side_ttl h3:before {
    background: url(library/img/icn_ig2.png) center center no-repeat;
    background-size: contain;
}
#side_blog .side_ttl h3:before {
    background: url(library/img/icn_blog.png) center center no-repeat;
    background-size: contain;
}
/*side_blog*/
.side_blog_list {
    display: flex;
    justify-content: space-between;
    padding-bottom: 20px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 20px;
}
.side_blog_list:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
    margin-bottom: 0;
}
.side_blog_thumbnail {
    width: 32%;
}
.side_blog_contents {
    width: 65%;
    line-height: 120%;
    letter-spacing: 0.05em;
}
.side_blog_contents .blog_title {
    font-size: 12px;
    margin-bottom: 5px;
    color: #997300;
}
.side_blog_contents .blog_date {
    margin-bottom: 5px;
}
.side_blog_contents .blog_date span {
    font-size: 11px;
    color: #fff;
    display: inline-block;
}
/*side_archive*/
#side_archive h3 {
    font-size: 15px;
    font-weight: bold;
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
}
/*/////////////////////////////////////////////////////

menu_list(menuページ & drinkページ)

/////////////////////////////////////////////////////*/
.menu_list {
    margin-bottom: 50px;
}
.menu_list.have_img {
    display: flex;
    justify-content: space-between;
    padding-bottom: 50px;
    border-bottom: 1px solid #e5e5e5;
}
.menu_list.have_img:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
}
.menu_list.have_img .menu_list_img {
    width: 35%;
}
.menu_list.have_img .menu_list_contents {
    width: 61%;
}
.menu_list_name {
    font-size: 17px;
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
}
.menu_list.have_noimg .menu_list_name {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: 14px;
}
.menu_list.have_noimg .menu_list_name span {
    font-size: 12px;
    font-weight: normal;
}
.menu_list_description {
    margin-bottom: 10px;
}
.menu_list_table {
    display: flex;
    justify-content: space-between;
    padding-bottom: 1rem;
}
.menu_list_table table {
    width: 100%;
}
.menu_list_table_half table {
    width: 47.5%;
}
.menu_list_table table th {
    width: 75%;
    padding: 10px 5px 10px 0;
    font-size: 13px;
    border-bottom: 1px solid #e5e5e5;
}
.menu_list_table table td {
    width: 25%;
    padding: 10px 0;
    text-align: right;
    border-bottom: 1px solid #e5e5e5;
}
/*/////////////////////////////////////////////////////

course_list(courseページ)

/////////////////////////////////////////////////////*/
.course_list {
    margin-bottom: 50px;
    display: flex;
    justify-content: space-between;
    padding-bottom: 50px;
    border-bottom: 1px solid #e5e5e5;
}
.course_list:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
}
.course_list_img {
    width: 35%;
}
.course_list_contents {
    width: 61%;
}
.course_list_name {
    font-size: 17px;
    font-weight: bold;
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
}
.course_list_name p:last-child {
    padding-left: 10px;
    /*white-space: nowrap;*/
}
.course_list_name p:last-child span {
    font-size: 13px;
    font-weight: bold;
}
.course_list_price {
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
    color: #7f746e;
    font-size: 13px;
  font-weight: bold;
}
.course_list_description {
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
    color: #7f746e;
    font-size: 13px;
}
.course_list_txt {
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 20px;
}
.course_list_contents_table {
    width: 100%;
    display: none;
}
.course_list_table table {
    width: 100%;
}
.course_list_table table tr th {
    padding: 0 10px 10px 0;
    width: 23%;
}
.course_list_table table tr td {
    padding: 0 0 10px 10px;
    width: 78%;
}
.course_list_table table tr:last-child th {
    padding: 0 10px 0 0;
}
.course_list_table table tr:last-child td {
    padding: 0 0 0 10px;
}
.course_list_table table tr th {
    border-right: 1px solid #e5e5e5;
}
.course_list_table table tr th span, .course_list_table table tr td span {
    border-top: 1px solid #e5e5e5;
    display: block;
    height: 100%;
    padding-top: 10px;
    padding-left: 5px;
}
.course_list_table table tr:first-child th span, .course_list_table table tr:first-child td span {
    border-top: none;
    padding-top: 0;
}
.course_list_btn {
    display: flex;
    justify-content: space-between;
    margin-bottom: 20px;
}
.course_list_btn a {
    display: block;
    width: 49%;
    font-weight: bold;
    text-align: center;
    padding: 5px;
}
.course_list_btn a span {
    font-weight: bold;
}
.btn_course_readmore {
    background: #e5e5e5;
    position: relative;
    cursor: pointer;
}
.btn_course_readmore .icn {
    position: absolute;
    top: 4px;
    left: 10px;
}
.btn_course_rsv {
    background: #c13414;
    color: #fff;
}
.course_nomiho_wrap {
    border-bottom: 1px solid #e5e5e5;
    padding-bottom: 50px;
    margin-bottom: 50px;
}
.course_nomiho_wrap h3 {
    font-weight: bold;
    font-size: 17px;
    color: #808480;
    margin-bottom: 30px;
}
/*/////////////////////////////////////////////////////

luch_list(luchページ)

/////////////////////////////////////////////////////*/
.lunch_list {
    margin-bottom: 50px;
    display: flex;
    justify-content: space-between;
    padding-bottom: 50px;
    border-bottom: 1px solid #e5e5e5;
}
.lunch_list:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
}
.lunch_list_img {
    width: 35%;
}
.lunch_list_contents {
    width: 61%;
}
.have_noimg .lunch_list_img {
    display: none;
}
.have_noimg .lunch_list_contents {
    width: 100%;
}
.lunch_list_name {
    font-weight: bold;
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    font-size: 14px;
}
.lunch_list .lunch_list_name span {
    font-size: 12px;
    font-weight: normal;
    white-space: nowrap;
}
.lunch_list_description {
    margin-bottom: 10px;
}
/*/////////////////////////////////////////////////////

space_list(spaceページ)

/////////////////////////////////////////////////////*/
.space_list {
    margin-bottom: 50px;
    display: flex;
    justify-content: space-between;
    padding-bottom: 50px;
    border-bottom: 1px solid #e5e5e5;
}
.space_list:last-of-type {
    padding-bottom: 0;
    border-bottom: none;
}
.space_list_img {
    width: 35%;
}
.space_list_contents {
    width: 61%;
}
.space_list_name {
    font-size: 17px;
    font-weight: bold;
    padding-bottom: 5px;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 10px;
}
.space_list_description {
    padding-bottom: 5px;
    margin-bottom: 10px;
}
.space_list_contents_table {
    width: 100%;
}
.space_list_table table {
    width: 100%;
}
.space_list_table table tr th {
    padding: 0 10px 0 0;
    width: 23%;
}
.space_list_table table tr td {
    padding: 0 0 0 10px;
    width: 78%;
}
.space_list_table table tr th {
    border-right: 1px solid #e5e5e5;
}
.space_list_table table tr th span, .space_list_table table tr td span {
    border-top: 1px solid #e5e5e5;
    display: block;
    height: 100%;
    padding-top: 10px;
    padding-left: 5px;
}
.space_list_table table tr:first-child th span, .space_list_table table tr:first-child td span {
    border-top: none;
    padding-top: 0;
}
/*/////////////////////////////////////////////////////

blog(blogページ & infoページ)

/////////////////////////////////////////////////////*/
.archive_blog_wrap {
    display: flex;
    justify-content: flex-start;
    flex-wrap: wrap;
}
.archive_blog_wrap .blog_list {
    display: block;
    width: 30%;
    margin-bottom: 40px;
    margin-right: 5%;
}
.archive_blog_wrap .blog_list:nth-child(3n) {
    margin-right: 0;
}
.archive_blog_wrap .blog_date {
    margin-bottom: 3px;
}
.archive_blog_wrap .blog_title {
    margin-bottom: 8px;
    font-size: 14px;
    color: #997300;
}
.archive_blog_wrap .blog_thumbnail {
    margin-bottom: 8px;
    height: 270px;
    overflow: hidden;
}
.archive_blog_wrap .blog_thumbnail img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
/*pagenation*/
#pagenation {
    margin: 60px auto;
}
.wp-pagenavi {
    text-align: center;
}
.wp-pagenavi span, .wp-pagenavi a {
    border: none !important;
}
.wp-pagenavi span.pages {
    display: none;
}
/*/////////////////////////////////////////////////////

blog記事

/////////////////////////////////////////////////////*/
.post_time {
    margin-bottom: 5px;
}
.post_ttl {
    color: #997300;
    font-size: 14px;
    margin-bottom: 20px;
    font-weight: bold;
}
#post_contents p, #post_contents img {
    margin-bottom: 20px;
}
#blog_btn {
    display: flex;
    justify-content: center;
    margin: 60px auto 0;
}
#blog_btn a {
    color: #fff;
    text-align: center;
    width: 40%;
    background: #133300;
    padding: 10px;
}
/*記事内コンバージョンボタン*/
#single_cv {
    width: 100%;
    padding: 0;
    margin: 60px auto;
}
#single_cv ul {
    display: flex;
    justify-content: space-between;
}
#single_cv ul li {
    width: 30%;
    padding: 0;
    text-align: center;
    font-size: 14px;
    background: #e5e5e5;
}
#single_cv a {
    display: block;
    padding: 10px 0;
}
#single_cv a, #single_cv a:hover, #single_cv a:active, #single_cv a:focus {
    text-decoration: none !important;
}
#single_cv i {
    display: inline-block;
    font-size: 15px;
    padding-right: 10px;
}
/*/////////////////////////////////////////////////////

サイトマップ

/////////////////////////////////////////////////////*/
#sitemap #section_ttl p {
    width: 50%;
}
#sitemap_list ul {
    width: 50%;
}
#sitemap_list a {
    display: block;
    line-height: 2em;
    padding: 10px 0;
    border-bottom: 1px solid #eee;
    font-size: 14px;
}
#sitemap_list a:before {
    content: "・";
    display: inline-block;
    margin-right: 10px;
    color: #bbb;
}
#sitemap_list span {
    padding-left: 20px;
    color: #000;
    font-size: 12px;
}
/*/////////////////////////////////////////////////////

キャンペーン

/////////////////////////////////////////////////////*/
#campaign {
    margin-top: 40px;
    padding-bottom: 40px;
    border-bottom: 1px solid #e5e5e5;
}
.campaign_wrap {
    width: 700px;
    margin: 0 auto;
}
.campaign_list {
    display: block;
    max-width: 700px;
    margin: 0 20px;
}
.campaign_list_contents {
    margin-top: 20px;
}
.campaign_list_ttl {
    font-size: 16px;
    font-weight: bold;
}
.campaign_list_description {
    margin-top: 20px;
}
.campaign_read_more {
    margin-top: 20px;
    text-align: right;
}
.campaign_read_more span {
    font-size: 12px;
    color: #ccc;
}
/*/////////////////////////////////////////////////////

404

/////////////////////////////////////////////////////*/
#page_404 {
    width: 90%;
    text-align: center;
    margin: 2em auto 4em;
}
#sp_btn {
    display: none;
}
/*/////////////////////////////////////////////////////
///////////////////////////////////////////////////////
///////////////////////////////////////////////////////

sp

///////////////////////////////////////////////////////
///////////////////////////////////////////////////////
/////////////////////////////////////////////////////*/
@media (max-width: 767px) {
/*/////////////////////////////////////////////////////

common

/////////////////////////////////////////////////////*/
    html {
        min-width: 0;
        height: auto;
    }
    body {
        font-size: 12px;
        height: auto;
        border-top: 15px solid #133300;
    }
    /*container*/
    #container {
        width: 100%;
    }
    #contents_wrap {
        width: 100%;
        margin: 0 auto;
        display: block;
        margin-top: 0;
    }
    #main_contents {
        width: 100%;
        padding: 20px 5% 0;
        border: none;
        overflow: hidden;
    }
    #sidebar {
        width: 100%;
        padding-left: 0;
        border-left: none;
    }
    /*ttl*/
    #main_contents h2 {
        font-size: 1.1rem;
    }
    #main_contents h2 span {
        font-size: 11px;
        margin-left: 10px;
    }
    #section_ttl {
        display: block;
        margin-bottom: 40px;
    }
    #section_ttl h2 {
        margin-bottom: 10px;
    }
    #section_ttl p {
        width: 100%;
        line-height: 150%;
        margin-bottom: 10px;
    }
    /*breadcrumb*/
    #breadcrumb {
        padding: 10px 5%;
    }
/*/////////////////////////////////////////////////////

overlay

/////////////////////////////////////////////////////*/
    /* スマホメニュートリガー 共通 */
    #menu-trigger-box {
        display: block;
        position: fixed;
        bottom: 25vw;
        right: 3%;
        background: rgb(19 51 0 / 80%);
        width: 44px;
        height: 50px;
        z-index: 1001;
    }
    .menu-trigger, .menu-trigger span {
        display: inline-block;
        transition: all .4s;
        box-sizing: border-box;
    }
    .menu-trigger {
        position: absolute;
        width: 30px;
        height: 23px;
        top: 8px;
        right: 7px;
        z-index: 2100;
        cursor: pointer;
        opacity: 1;
        display: block;
    }
    .menu-trigger:hover {
        opacity: 1;
    }
    .menu-trigger span {
        position: absolute;
        left: 0;
        width: 100%;
        height: 3px;
        background-color: #fff;
    }
    .menu-trigger span:nth-of-type(1) {
        top: 0;
    }
    .menu-trigger span:nth-of-type(2) {
        top: 10px;
    }
    .menu-trigger span:nth-of-type(3) {
        bottom: 0px;
    }
    .menu-trigger p {
        position: absolute;
        left: -20%;
        top: 105%;
        width: 140%;
        text-align: center;
        font-size: 9px;
        font-family: "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", 游明朝, "Yu Mincho", YuMincho, HGS明朝E, "ＭＳ Ｐ明朝", "MS PMincho", "serif";
        color: #fff;
        font-feature-settings: "palt";
    }
    .menu-trigger.active span {
        background-color: #fff !important;
    }
    .menu-trigger.active p {
        color: #fff !important;
    }
    /* スマホメニュートリガー エフェクト */
    .menu-trigger.active span:nth-of-type(1) {
        -webkit-transform: translateY(11px) rotate(-45deg);
        transform: translateY(11px) rotate(-45deg);
    }
    .menu-trigger.active span:nth-of-type(2) {
        opacity: 0;
    }
    .menu-trigger.active span:nth-of-type(3) {
        -webkit-transform: translateY(-11px) rotate(45deg);
        transform: translateY(-11px) rotate(45deg);
        bottom: -2px;
    }
    /* overlay_outer */
    #overlay_outer {
        position: fixed;
        width: 100%;
        height: 100%;
        z-index: 2000;
        display: none;
    }
/*/////////////////////////////////////////////////////

header

/////////////////////////////////////////////////////*/
    /*logo*/
    .sp_logo {
        display: block;
    }
    .sp_logo h1 {
        width: 30%;
        margin: 0 auto 20px;
        padding-top: 20px;
    }
    .sp_logo h1 img {
        width: 100%;
        height: auto;
    }
    .page h1, .single h1 {
        display: none;
    }
    /*top_sns*/
    #top_sns {}
    /*top_btn*/
    #top_btn {
        display: none;
    }
    /*header*/
    header {
        padding: 20px 0 20px;
        display: none;
        background: #061723;
        background: #ffffff;
        position: fixed;
        top: 0;
        left: 0;
        z-index: 2000;
        width: 100%;
    }
    #header_nav {
        position: static;
        display: block;
        width: 90%;
        margin: 0 auto;
    }
    .header_nav_box {
        width: 50%;
        margin: 0 auto;
    }
    #fix_nav {
        display: none !important;
    }
    #fix_nav header {
        display: none;
    }
    #drink_page #under_mainv img {
        object-position: 0;
    }
    .header_nav_list {
        margin-top: 15px;
        padding: 0 10px;
        background: none;
        display: block;
        width: 100% !important;
    }
    .header_nav_list a {
        padding: 10px 10px;
        display: block;
        position: relative;
        font-size: 13px;
        font-weight: bold;
        -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
        writing-mode: horizontal-tb;
        color: #221916;
        border-bottom: 1px solid #555;
    }
    .header_nav_list a:hover {
        background: none;
    }
/*/////////////////////////////////////////////////////

mainv

/////////////////////////////////////////////////////*/
    /*mainv*/
    .home_wrap {
        display: block;
        background-image: none;
        height: auto;
    }
    .mainv_wrap {
        width: 100%;
        float: none;
        opacity: 1;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
    #mainv {
        width: 100%;
        padding-bottom: 0;
    }
    .slick-prev, .slick-next, .slick_counter {
        display: none !important;
    }
    #mainv .slick-list {
        height: 77.7vw;
    }
    .fv2_wrap {
        display: none;
    }
    .fv2 {
        width: 100%;
        position: static;
        transition: 1s;
        opacity: 1;
        transform: translate(0, 0);
        -webkit-transform: translate(0, 0);
    }
/*/////////////////////////////////////////////////////

top

/////////////////////////////////////////////////////*/
    /*about*/
    #about {
        padding: 30px 5%;
        width: 100%;
        background-attachment: scroll;
        background-position: center top !important;
        background-size: cover;
        justify-content: flex-end;
        flex-direction: column;
    }
    #main_contents .about_lead {
        width: 90%;
        min-width: 0;
        margin: 0 auto;
    }
    #main_contents .about_lead h2 {
    font-size: 1.1rem;
    }
    #main_contents .about_lead h2 br {
        /* display: none; */
    }
    #main_contents .about_lead h2 img {
        width: 100%;
        height: auto;
    }
    #main_contents .about_lead h3 {
    font-size: 1rem;
    }
    #main_contents .about_lead p {
        font-size: 0.75rem;
        line-height: 1.5;
    }
    #main_contents .about_contents_img {
        position: relative;
        margin-top: 0;
        height: 0;
        box-sizing: content-box;
        padding-bottom: 76.07362%;
        width: 100%;
    }
    .about_contents_img img {
        position: absolute;
    }
    .about_contents_img img:nth-of-type(1) {
        width: 60%;
        height: auto;
        right: auto;
        left: 0;
        z-index: 40;
    }
    .about_contents_img img:nth-of-type(2) {
        width: 35%;
        height: auto;
        top: 25%;
        right: 0;
        left: auto;
    }
    .about_contents_img img:nth-of-type(3) {
        width: 60%;
        height: auto;
        left: 15%;
        margin-left: 0;
        top: auto;
        bottom: 0;
    }
    /*linkbox_wrap*/
    #linkbox_wrap {
        padding: 0;
    }
    .linkboxinner {
        padding: 30px 5%;
    }
    .linkbox_half_wrap {
        display: block;
        width: 100%;
    }
    .linkbox_half_list {
        width: 100%;
        margin-bottom: 20px;
    }
    /*smile*/
    #smile {
        display: block;
        padding: 30px 5%;
    }
    #smile > div {
        width: 100%;
    }
    .smile_ttl {
        color: #fff;
        position: relative;
        margin-top: 20px;
        text-align: center;
    }
    .smile_ttl h2 {
        width: 40%;
        margin-bottom: 20px;
        text-align: left;
    }
    .smile_ttl p {
        font-size: 12px;
        text-align: left;
    }
    .smile_ttl > a {
        position: static;
        padding: 10px 20%;
        margin-top: 20px;
    }
    /*footer_gallery*/
    #footer_gallery {
        display: flex;
        justify-content: space-around;
        flex-wrap: wrap;
        padding: 0;
    }
    .footer_gallery_list {
        width: 50%;
    }
    .footer_gallery_ttl {
        background: #133300;
        position: relative;
        text-align: center;
    }
    .footer_gallery_ttl h2 {
        width: 70%;
        margin: 0 auto;
        padding-top: 40%;
    }
    .footer_gallery_ttl > a {
        display: block;
        width: 60%;
    }
/*/////////////////////////////////////////////////////

footer

/////////////////////////////////////////////////////*/
    #footer_wrap {
        border-left: none;
    }
    /*access*/
    .access_header {
        display: block;
    }
    .access_header .access_ttl {
        width: 100%;
        padding: 40px 5%;
        height: auto;
        min-height: auto;
    }
    .access_header .access_ttl h2 {
        padding: 0;
        text-align: left;
    }
    .access_header .access_ttl h2 img {
        width: 40%;
        height: auto;
    }
    #map {
        width: 100%;
    }
    .access_contents {
        padding: 20px 5% 30px;
        background: none;
        display: block;
    }
    .access_contents table {
        width: 100%;
    }
    .access_contents table tr th {
        width: 25%;
    }
    .access_contents table tr td {
        width: 75%;
    }
    .access_contents table tr th span, .access_contents table tr td span {
        font-size: 11px;
    }
    .access_contents table tr:last-child th, .access_contents table tr:last-child td {
        border-bottom: 1px solid #e5e5e5;
    }
    .access_contents table tr:last-child th {
        padding: 0 10px 10px 0;
    }
    .access_contents table tr:last-child td {
        padding: 0 0 10px 10px;
    }
    .access_contents table tr:first-child th, .access_contents table tr:child td {
        padding-top: 10px;
    }
    /*footer_sns*/
    #footer_sns {
        padding: 10px 5%;
    }
    .footer_sns_inner {
        width: 100%;
        text-align: center;
    }
    .footer_sns h3 {
        font-size: 11px;
        margin-right: 20px;
    }
    .footer_sns a {
        margin-right: 20px;
    }
    .footer_sns a:last-child {
        margin-right: 0;
    }
    .paid_media {
        margin-top: 15px;
    }
    .paid_media a {
        margin-right: 10px;
        padding-right: 10px;
        font-size: 11px;
    }
    .paid_media a:last-child {
        margin-right: 0;
        padding-right: 0;
        border-right: none;
    }
    /*footer*/
    footer {
        padding-top: 40px;
        padding-bottom: 20vw;
        text-align: center;
    }
    .footer_inner {
        width: 100%;
        padding: 0 5%;
    }
    #footer_logo {
        margin-bottom: 40px;
    }
    #footer_nav {
        margin-bottom: 30px;
    }
    .footer_nav1 {
        margin-bottom: 0;
    }
    #footer_nav a {
        display: block;
        padding: 10px 0;
        border-top: 1px solid #ddd;
        border-right: none;
        text-align: left;
        font-size: 12px;
        position: relative;
    }
    #footer_nav a:first-child {
        padding: 10px 0;
    }
    #footer_nav .footer_nav1 a:first-child {
        border-top: none;
    }
    #footer_nav a:last-child {
        padding: 10px 0;
    }
    #footer_nav a:after {
        content: ">";
        position: absolute;
        top: 50%;
        right: 2.5%;
        margin-top: -0.8em;
    }
    #copy {
        font-size: 11px;
    }
/*/////////////////////////////////////////////////////

sidebar

/////////////////////////////////////////////////////*/
    /*common*/
    #sidebar {
        padding: 30px 5%;
    }
    .side_contents:first-of-type {
        margin-top: 30px;
    }
    .side_contents:last-of-type {
        padding-bottom: 30px;
        border-bottom: 1px solid #e5e5e5;
    }
    .side_ttl h3 {
        font-size: 21px;
        padding-left: 55px;
    }
    .side_ttl h3 span {
        font-size: 16px;
        margin-bottom: 5px;
    }
    .side_ttl h3:before {
        content: "　";
        width: 40px;
        height: 40px;
    }
/*/////////////////////////////////////////////////////

sp_btn

/////////////////////////////////////////////////////*/
    #sp_btn {
        display: block;
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        z-index: 2000;
    }
    #sp_btn:before {
        display: block;
        position: fixed;
        bottom: 0;
        left: 0;
        width: 100%;
        height: 0;
        padding-bottom: 13.561841%;
        content: "　";
        box-sizing: content-box;
        background: #133300;
        z-index: 1990;
        transition: .3s;
    }
    #sp_btn.sp_btn_bg_b:before {
        padding-bottom: 0;
    }
    #sp_btn ul {
        position: relative;
        display: flex;
        justify-content: space-between;
        align-items: flex-end;
        width: 100%;
        z-index: 2000;
    }
    #sp_btn ul li:nth-child(1), #sp_btn ul li:nth-child(3) {
        width: 38.889%;
    }
    #sp_btn ul li:nth-child(2) {
        width: 22.222%;
    }
/*/////////////////////////////////////////////////////

menu_list(menuページ & drinkページ)

/////////////////////////////////////////////////////*/
    .menu_list {
        margin-bottom: 40px;
    }
    .menu_list_cat_craft::before {
        transform: rotate(-3deg);
    }
    .menu_list.have_img {
        padding-bottom: 0;
        border-bottom: none;
        display: block;
    }
    .menu_list.have_img .menu_list_img {
        width: 100%;
        margin-bottom: 20px;
    }
    .menu_list.have_img .menu_list_contents {
        width: 100%;
    }
    .menu_list_name {
        font-size: 15px;
    }
    .menu_list.have_noimg .menu_list_name {
        font-size: 13px;
    }
    .menu_list.have_noimg .menu_list_name span {
        font-size: 12px;
        font-weight: normal;
        padding-left: 10px;
    }
    .menu_list_table {
        display: block;
    }
    .menu_list_table table {
        width: 100%;
    }
/*/////////////////////////////////////////////////////

course_list(courseページ)

/////////////////////////////////////////////////////*/
    .course_list {
        margin-bottom: 40px;
        display: block;
        padding-bottom: 40px;
        border-bottom: none;
    }
    .course_list:last-of-type {
        padding-bottom: 0;
    }
    .course_list_img {
        width: 100%;
        margin-bottom: 20px;
    }
    .course_list_contents {
        width: 100%;
    }
    .course_list_name {
        font-size: 15px;
        font-weight: bold;
        padding-bottom: 5px;
        border-bottom: 1px solid #e5e5e5;
        margin-bottom: 10px;
        display: flex;
        justify-content: space-between;
    }
    .course_list_name p:last-child {
        padding-left: 10px;
    }
    .course_list_name p:last-child span {
        font-size: 13px;
        font-weight: bold;
    }
    .course_list_description {
        padding-bottom: 5px;
        border-bottom: 1px solid #e5e5e5;
        margin-bottom: 10px;
        color: #7f746e;
        font-size: 13px;
    }
    .course_list_txt {
        padding-bottom: 5px;
        border-bottom: 1px solid #e5e5e5;
        margin-bottom: 20px;
    }
    .course_list_contents_table {
        width: 100%;
        display: none;
    }
    .course_list_table table {
        width: 100%;
    }
    .course_list_table table tr th {
        padding: 0 10px 10px 0;
        width: 23%;
    }
    .course_list_table table tr td {
        padding: 0 0 10px 10px;
        width: 78%;
    }
    .course_list_table table tr:last-child th {
        padding: 0 10px 0 0;
    }
    .course_list_table table tr:last-child td {
        padding: 0 0 0 10px;
    }
    .course_list_table table tr th {
        border-right: 1px solid #e5e5e5;
    }
    .course_list_table table tr th span, .course_list_table table tr td span {
        border-top: 1px solid #e5e5e5;
        display: block;
        height: 100%;
        padding-top: 10px;
        padding-left: 5px;
    }
    .course_list_table table tr:first-child th span, .course_list_table table tr:first-child td span {
        border-top: none;
        padding-top: 0;
    }
    .course_list_btn {
        display: flex;
        justify-content: space-between;
        margin-bottom: 20px;
    }
    .course_list_btn a {
        display: block;
        width: 49%;
        font-weight: bold;
        text-align: center;
        padding: 5px;
    }
    .course_list_btn a span {
        font-weight: bold;
    }
    .btn_course_readmore {
        background: #e5e5e5;
        position: relative;
    }
    .btn_course_readmore .icn {
        position: absolute;
        top: 4px;
        left: 10px;
    }
    .btn_course_rsv {
        background: #be9f60;
        color: #fff;
    }
    .course_nomiho_wrap {
        border-top: 1px solid #e5e5e5;
        padding-top: 60px;
    }
    .course_nomiho_wrap h3 {
        font-weight: bold;
        font-size: 17px;
        color: #808480;
        margin-bottom: 30px;
    }
/*/////////////////////////////////////////////////////

luch_list(luchページ)

/////////////////////////////////////////////////////*/
    .lunch_list {
        margin-bottom: 40px;
        display: block;
        padding-bottom: 0;
        border-bottom: none;
    }
    .lunch_list:last-of-type {
        padding-bottom: 0;
        border-bottom: none;
    }
    .lunch_list_img {
        width: 100%;
        margin-bottom: 20px;
    }
    .lunch_list_contents {
        width: 100%;
    }
    .lunch_list_name {
        font-size: 14px;
    }
    .lunch_list .lunch_list_name span {
        font-size: 12px;
        font-weight: normal;
    }
/*/////////////////////////////////////////////////////

space_list(spaceページ)

/////////////////////////////////////////////////////*/
    .space_list {
        margin-bottom: 40px;
        display: block;
        padding-bottom: 0;
        border-bottom: none;
    }
    .space_list_img {
        width: 100%;
        margin-bottom: 20px;
    }
    .space_list_contents {
        width: 100%;
    }
    .space_list_name {
        font-size: 14px;
    }
    .space_list_table table tr th {
        padding: 0 10px 0 0;
        width: 23%;
    }
    .space_list_table table tr td {
        padding: 0 0 0 10px;
        width: 78%;
    }
/*/////////////////////////////////////////////////////

blog(blogページ & infoページ)

/////////////////////////////////////////////////////*/
    .archive_blog_wrap {
        display: block;
    }
    .archive_blog_wrap .blog_list {
        display: block;
        justify-content: space-between;
        width: 100%;
        margin-bottom: 40px;
    }
    .archive_blog_wrap .blog_date {
        margin-bottom: 3px;
    }
    .archive_blog_wrap .blog_title {
        margin-bottom: 8px;
        font-size: 14px;
        color: #997300;
    }
    .archive_blog_wrap .blog_thumbnail {
        margin-bottom: 8px;
    }
    .archive_blog_wrap .blog_list {
        width: 100%;
        padding: 0 0 20px 0;
        border-right: 0;
        border-bottom: 1px solid #e5e5e5;
        display: flex;
        justify-content: space-between;
        margin-bottom: 20px;
    }
    .archive_blog_wrap .blog_list:last-child {
        padding: 0;
        border-bottom: none;
        margin-bottom: 0;
    }
    .archive_blog_wrap .blog_list p {
        line-height: 180%;
    }
    .archive_blog_wrap .blog_list .blog_thumbnail {
        width: 30%;
        height: 27.5vw;
    }
    .archive_blog_wrap .blog_list .blog_contents {
        width: 65%;
    }
    .archive_blog_wrap .blog_list .blog_title {
        font-size: 14px;
        margin-top: 2px;
        margin-bottom: 1px;
    }
    .archive_blog_wrap .blog_list .blog_date {
        margin-bottom: 4px;
    }
    .archive_blog_wrap .blog_list .blog_date span {
        font-size: 11px;
    }
/*/////////////////////////////////////////////////////

blog記事

/////////////////////////////////////////////////////*/
    #blog_btn {
        display: block;
    }
    #blog_btn a {
        width: 60%;
        margin: 10px auto;
        display: block;
    }
    /*記事内コンバージョンボタン*/
    #single_cv {
        margin: 40px auto;
    }
    #single_cv ul {
        display: block;
        margin: 0 auto;
    }
    #single_cv ul li {
        width: 60%;
        margin: 10px auto;
        display: block;
    }
    #single_cv a {
        display: block;
        padding: 10px 0;
    }
    #single_cv i {
        display: inline-block;
        font-size: 15px;
        padding-right: 10px;
    }
/*/////////////////////////////////////////////////////

サイトマップ

/////////////////////////////////////////////////////*/
    #sitemap #section_ttl p {
        width: 100%;
    }
    #sitemap_list {
        margin-bottom: 50px;
    }
    #sitemap_list ul {
        width: 100%;
    }
/*/////////////////////////////////////////////////////

キャンペーン

/////////////////////////////////////////////////////*/
    #campaign {
        margin-top: 30px;
        padding-bottom: 30px;
    }
    .campaign_wrap {
        width: 95%;
        margin: 0 auto;
    }
    #campaign_slider {
        width: 100%;
    }
    .campaign_list {
        margin: 0;
    }
    .campaign_list_img {
        width: 100%;
        height: auto;
    }
    .campaign_list_contents {
        margin-top: 20px;
        width: 100%;
    }
    .campaign_list_ttl {
        font-size: 16px;
        font-weight: bold;
    }
    .campaign_list_description {
        margin-top: 20px;
    }
    .campaign_read_more {
        margin-top: 20px;
        text-align: right;
    }
    .campaign_read_more span {
        font-size: 12px;
        color: #ccc;
    }
}
/* クーポンページ
--------------------------------------------------*/
#coupon_wrap {
    padding: 50px 0;
}
.coupon_box {
    margin-top: 30px;
    padding: 30px 80px;
    background: url(library/img/coupon_bg.png) left top no-repeat #fff;
}
.coupon_title {
    margin-bottom: 10px;
    padding-bottom: 5px;
    color: #1c2f67;
    border-bottom: 1px solid #e0e0e0;
    font-size: 18px;
}
.coupon_txt1 {
    font-size: 14px;
}
.coupon_txt2, .coupon_txt3, .coupon_txt4 {
    margin-top: 10px;
    padding: 5px 10px;
    background: #f5f4f3;
}
@media screen and (max-width:767px) {
    #coupon_wrap {
        padding: 40px 0 0;
    }
    .coupon_box {
        margin: 20px 30px 0;
        padding: 30px 30px 20px;
        background-size: 60px auto;
    }
    .coupon_title {
        font-size: 14px;
    }
    .coupon_txt1 {
        font-size: 12px;
    }
}
@media (max-width:1024px) {
    #about {
        background-attachment: scroll;
    }
}

/*DKダイニングJSボタン非表示*/
#dkp_top_nav {
    display: none;
    height: 0;
}
#dkp_top_nav_spacer {
    display: none;
    height: 0;
}
#dkp_vacancy_area_open_button_container {
    display: none;
    height: 0;
}
body #dkp_shop_vacancy_search_area {
    box-shadow: none;
}

/* 2022.01.07 [START]
--------------------------------- */
nav .header_href {
    display: none;
}
#fix_nav nav .header_href {
    display: flex;
}
.heading {
    display: flex;
    justify-content: space-between;
    padding: 0;
}
.heading p {
    margin: 5px 1rem;
}
.header_href {
    display: flex;
}
.header_href a {
    display: block;
    padding: 5px 0.9rem;
    font-size: 0.9rem;
    font-weight: bold;
    height: 100%;
}
.header_href a img {
    height: 0.9rem;
    margin-right: 0.5rem;
    vertical-align: text-bottom;
}
.header_href_reserve a {
    color: #fff;
    background-color: #997300;
}
.header_href_tel a {
    background-color: #133300;
  	color: #fff;
}
.header_href_dkpoint a.dkpoint {
    background-color: red;
    color: #fff;
}
.header_href_dkpoint a.dkpoint span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-size: 0.9rem;
    width: 1.2rem;
    height: 1.2rem;
    margin-right: 0.3rem;
    border-radius: 0.6rem;
    background: #ffffff;
    line-height: 1;
    color: #ff0000;
}
#fix_nav .header_href a {
    display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
    white-space: nowrap;
}
#fix_nav .header_href a img {
    display: block;
    margin: 0 auto 4px;
    height: 1.25rem;
}
@media (max-width:1280px) {
    #fix_nav header .header_nav_list a {
        padding: 20px 10px;
    }
    #fix_nav .header_href a {
        padding: 5px 0.7rem;
    }
}
.space_box {
    margin-bottom: 4rem;
}
.space_head {
    display: flex;
    justify-content: space-between;
    font-size: 1rem;
    font-weight: bold;
    padding-bottom: 0.5rem;
    border-bottom: 1px solid #e5e5e5;
    margin-bottom: 1rem;
}
.space_seat {
    font-size: 0.9rem;
}
.space_description {
    padding-bottom: 0.5rem;
    margin-bottom: 1rem;
}
.space_item {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.space_item_img {
    width: 32.333%;
    height: 288px;
}
.space_item_img:nth-child(3n+2) {
    transition-delay: 0.25s;
}
.space_item_img:nth-child(3n) {
    transition-delay: 0.50s;
}
.space_item_img img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}
.space_item::after {
    content: '';
    width: 32%;
    height: 0;
}
#space_page #section_ttl {
    border-bottom: none;
    margin-bottom: 2rem;
}
#food_page .menu_list_cat, #lunch_page .menu_list_cat {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
#food_page .menu_cat_ttl, #lunch_page .menu_cat_ttl {
    width: 100%;
    margin-top: 50px;
}
#food_page .menu_list, #lunch_page .lunch_list {
    width: 48%;
    display: block;
    justify-content: unset;
    border-bottom: none;
    padding-bottom: 0;
}
#lunch_page .lunch_list.have_noimg {
    width: 100%;
}
#food_page .menu_list.have_img .menu_list_img, #lunch_page .lunch_list .lunch_list_img {
    width: 100%;
    margin-bottom: 0.5rem;
}
#food_page .menu_list.have_img .menu_list_contents, #lunch_page .lunch_list .lunch_list_contents {
    width: 100%;
}
@media (max-width:1280px) {
    #fix_nav header .header_nav_list a {
        padding: 20px 15px;
    }
}
@media (max-width:767px) {
    .header_href, #fix_nav nav .header_href {
        display: none;
    }
    .space_head {
        font-size: 1rem;
        margin-bottom: 0.75rem;
    }
    .space_seat {
        font-size: 0.9rem;
    }
    .space_description {
        margin-bottom: 0.5rem;
    }
    .space_item {
        display: block;
    }
    .space_item_img {
        width: 100%;
        height: auto;
        margin-bottom: 1rem;
    }
    .space_item_img:nth-child(3n+2) {
        transition-delay: 0s;
    }
    .space_item_img:nth-child(3n) {
        transition-delay: 0s;
    }
    .space_item_img img {
        object-fit: unset;
        width: 100%;
        height: auto;
    }
    #food_page .menu_list_cat, #lunch_page .menu_list_cat {
        display: block;
    }
    #food_page .menu_list, #lunch_page .lunch_list {
        width: 100%;
    }
}
@media (max-width:374px) {
    .heading p {
        font-size: 0.666rem;
        margin: 5px 0.666rem;
    }
}

/* 2022.01.07 [END]
--------------------------------- */

/* 2023.08.23 [START]
--------------------------------- */
#sp_cv {
    display: none;
}
@media (max-width: 767px){
#sp_cv {
    display: block;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 1000;
}
#sp_cv ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
    background-color: #133300;
}
#sp_cv ul li:nth-child(1) {
    width: 100%;
}
#sp_cv a.dkpoint {
    font-size: 4vw;
    display: block;
    text-align: center;
    margin: 1.5vw;
    padding: 0.75vw;
    box-sizing: border-box;
    background-color: #fff;
    color: #133300;
}
#sp_cv a.dkpoint span {
    display: inline-flex;
    justify-content: center;
    align-items: center;
    font-size: 4vw;
    width: 6vw;
    height: 6vw;
    padding: 1vw;
    margin-right: 2vw;
    border-radius: 3vw;
    background: red;
    line-height: 1;
    color: #fff;
}
#sp_cv ul li:nth-child(2),
#sp_cv ul li:nth-child(4) {
    width: 25%;
}
#sp_cv ul li:nth-child(2) a,
#sp_cv ul li:nth-child(4) a {
    display: block;
    color: #fff;
    line-height: 1;
    text-align: center;
    padding: 1.5vw;
}
#sp_cv ul li:nth-child(2) a img,
#sp_cv ul li:nth-child(4) a img {
    height: 5vw;
    display: block;
    margin: 0 auto 2vw;
    filter: invert(1);
}
#sp_cv ul li:nth-child(2) a span,
#sp_cv ul li:nth-child(4) a span {
    font-size: 3.5vw;
}
#sp_cv ul li:nth-child(3) {
    width: 50%;
}
#sp_cv ul li:nth-child(3) a {
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 5vw;
    height: 100%;
    color: #997300;
    background-color: #ffffff;
    font-weight: bold;
    border-radius: 1vw;
    line-height: 1;
    border-bottom-left-radius: unset;
    border-bottom-right-radius: unset;
}
}
/* 2023.08.23 [END]
--------------------------------- */

/* 2024.01.26 */
.dk_member_banner{
    position: relative;
    width: 100%;
    z-index: 30;
    display: flex;
    background: #FFFFFF;
}
.dk_member_banner_link{
    position: fixed;
    top: 20%;
    right: 20px;
    width: 30%;
    display: flex;
}
.dk_member_banner_link img{
    width: 100%;
}
.dk_member_banner_close{
    position: fixed;
    top: 19%;
    right: 10px;
    width: 3%;
    cursor: pointer;
    display: flex;
}
.dk_member_banner_close img{
    width: 100%;
}
@media (max-width: 1024px) {
    .dk_member_banner_link {
        top: 10%;
        width: 25%;
    }
    .dk_member_banner_close {
        top: 9%;
    }
}
@media (max-width: 768px) {
    .dk_member_banner{
        justify-content: center;
        align-items: center;
    }
    .dk_member_banner_link{
        position: relative;
        top: 0;
        left: 0;
        width: 80%;
        margin: 10% 0;
    }
    .dk_member_banner_close{
        position: absolute;
        top: 10%;
        right: 5%;
        width: 10%;
    }
}
/* 2024.01.26 */
