@charset "utf-8";
@import url(https://fonts.googleapis.com/earlyaccess/sawarabimincho.css);
/* フォントを指定したいところで */

html {
    overflow-x: hidden;
    width: 100%;
}

body {
    font-size: 100%;
    font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝","Sawarabi Mincho",Verdana, serif;
    position: relative;
}


a:focus{
  outline: none;
}


.al_c {    text-align: center;}
.al_l {    text-align: left;}
.al_r {    text-align: right;}
.p_r {    position: relative;}
.pc,
.nav_wrap,
.nav_wrap_sp {display: none!important;}

.licknav_menu:after ,
.cf:after,
.clearfix:after { 
    visibility: hidden;
    display: block;
    content: " ";
    clear: both;
    height: 0;
}
.slicknav_menu ,
.clearfix {
  display: block;
}

*:after {
    display: block;
    clear: both;
}

element {
    zoom: 1;
}

/* clearfix IE6, 7 */

element:after {
    content: "";
}

/*------------------------------------------
 *	preloader
------------------------------------------*/

img {
    width: 100%;
}



a {
    color: #252730;
    } 

header {
    width: 100%;
    background-color: #fff;
    border-bottom: 1px solid;
}


h1 {
    display: block;
    float: left;
    width: 35%;
    margin-left: 5%;
}

.slicknav_nav {
}

ul.hd_prm {
    width: 50%;
    float: left;
    padding-top: 1rem;
    margin-left: 5%;
}


ul.hd_prm li {
    font-size: 86%;
    margin-left: 0.5rem;
}


ul.hd_prm li  small {
    font-size: 78%;
}

.slicknav_nav nav >ul {
       display: flex ;
    flex-direction: row ;
    flex-wrap: wrap ;
    justify-content: space-around ;
    align-items: center ;
}

.slicknav_nav nav > ul > li {
    width: 40%;
    margin: 0.5rem 0 0.5rem;
}
.slicknav_nav nav.bnr_try > ul > li     {
    margin: 0.5rem 0;
}
  



ul.sns {
    width: 70%;
    margin: 0 auto 0.5rem;
       display: flex ;
    flex-direction: row ;
    flex-wrap: wrap ;
    justify-content: space-around ;
    align-items: center ;
}

ul.sns li {
    width: 15%;
}

.slide {
}

#slide1 {
    width: 100%;
    height: 50vh;
    background: url(../images/top/1.jpg) no-repeat center / cover;
}

#slide2 {
    width: 100%;
    height: 50vh;
    background: url(../images/top/2.jpg) no-repeat center top / cover;
}

#slide3{
    width: 100%;
    height: 50vh;
    background: url(../images/top/3.jpg) no-repeat center top /  cover;
}

#slide4 {
    width: 100%;
    height: 50vh;
    background: url(../images/top/4.jpg) no-repeat center top / cover;
}

#slide5 {
    width: 100%;
    height: 50vh;
    background: url(../images/top/5.jpg) no-repeat center top / cover;
}
/*------------------------------------------
 *	main
------------------------------------------*/

main {
    background-image: url(../images/bg.png);
}

section {
}

h2 {
    margin: 1rem auto 2rem;
    width: 30%;
}

#about p {
    width: 86%;
    margin: 2rem auto;
    font-size: 120%;
    line-height: 1.6;
    font-weight: bold;    
}

.cs_wrap {
    padding: 5rem 0 0px;
    clear: both;
}

.cs_box {
    background-color: rgba(255, 255, 255, 0.6);
    position: relative;
    width: 100%;
    padding: 3rem 0 0;
    margin:0 auto 20px;
}

#a_couse .cs_txt {
    background: rgba(255, 255, 255, 0.6) url(../images/a_bg.png) no-repeat right bottom / cover;
    
}


#b_couse .cs_txt{
    background: rgba(255, 255, 255, 0.6) url(../images/b_bg.png) no-repeat right bottom / cover;
    
}
#c_couse .cs_txt{
    background: rgba(255, 255, 255, 0.6) url(../images/c_bg.png) no-repeat right bottom/  cover;
    
}

.cs_box h3 {
    display: block;
    position: absolute;
    top: -4rem;
    left: 0;
    right: 0;
    margin: 0 auto;
    width: 6rem;
}

.cs_wrap:nth-child(even) h3 {
}

.cs_menu{
}

.cs_wrap:nth-child(even) .cs_menu {
}

.cs_menu h4 {
    font-size:140%;
    margin-bottom: 2rem;
    text-align: center;
}

.cs_menu .sp_menu_wrap {
    margin: 0 auto 1rem;
    border:4px double;
    width: 94%;
    padding: 1rem 0 0.5rem;
}

.cs_menu ul {
    margin-top: 0.5rem;
    list-style: disc;
    margin-left: 1.5rem;
}

.cs_menu ul li {
    margin-bottom: 0.5rem;
    font-size: 86%;
}

.cs_menu small {
    display: block;
    font-size: 66%;
   padding-left: 1%;
}

.cs_txt {
    text-align: center;
    padding: 2rem 4% 0;
}

.cs_txt p {
    font-size: 94%;
    text-align: left;
    margin-bottom: 4rem;
}
.cs_txt a {
    outline: none;
    -webkit-tap-highlight-color: transparent;
    text-decoration: none;
    width: 60%;
}
.cs_txt a img {
    width: 60%;
    padding: 0.5rem 0;
}

.btn {
    text-align: center;
    margin: 0 auto 1.5rem; 
    width: 85%;
    display: inline-block;
    font-size: 22px;
    line-height: 1.42;
    padding: 0.7em 1.4em;
    font-weight: bold;
    border-width: 3px;
    border-style: solid;
    background: transparent;
    border-radius: 0;
    cursor: pointer;
    user-select: none;
    vertical-align: bottom;
    position: relative;
    transform: translate(0.5em 0.5em);
    transition: transform 0.2s;
    text-decoration: none;
    color: #252730;
    border-color: #252730;
}


a.btn_s {
    margin: 0 3% 1.5rem; 
    width: 20%;
    float: left;
}

.btn:before {
    content: '';
    display: block;
    position: absolute;
    top: -5px;
    left: -25px;
    height: 100%;
    width: 100%;
    border-width: 1px;
    border-style: solid;
    transform: translate(0.6em, -0.3em);
    transition: transform 0.2s, background-color 0.2s;
}

.btn-black {
    background-color:  rgba(255, 255, 255, 0.8);
    
}

.btn:hover {
    border-width: 1px;
    transform: translate(-0.2em, -0.1em);
    background-color: rgba(46, 37, 48, 0.1);
    opacity: 1;
}


.btn-black:hover {
    background-color:  rgba(255, 255, 255, 0.8);
}
.btn:hover:before {
    border-width: 2px;
    transform: translate(1.4em, 0.8em);
    background-color: rgba(46, 37, 48, 0.2);
}

.btn:active {
    transform: translate(0, 0);
    transition-duration: 0.1s;
}

.btn:active:before {
    transition-duration: 0.1s;
    transform: translate(1.0em, 0.1em);
    background-color: rgba(46, 37, 48, 0.4);
}

#drink_option h2 {
    width: 60%;
}

.menu_box {    
    width: 100%;
    margin: 0.5rem auto 1rem;
}


.menu_box > ul > li {
    width: 90%;
    margin: 2rem auto;
}

.opt_menu {
    list-style: disc;
    margin-left: 1rem;
}

.opt_menu li {
    margin-bottom: 0.5rem
}

.menu_box ul  li.wine_menu { 
    width:94%; 
    clear: both;
    font-size: 90%;
}

.menu_box  h3 {
    font-size:140%;
    margin-bottom: 2.5rem;
    text-align: center;
}

.

.menu_box strong {
    font-weight: boSld;
    padding-left: 0.5rem;
}


.wine_menu h4 {
    padding: 1rem 0 0rem;
    font-size: 130%;
    font-weight: bold;
}
.wine_menu h5 {
    font-size: 121%;
    font-weight: bold;
    margin-bottom: 0.5rem;
}



.wine_menu dt {
    padding-top: 0.75rem;
    
}

.wine_menu dt:first-child {
}

.wine_menu dd {
    border-bottom: 1px dotted;
    font-size: 106%;
    line-height: 1.7s;
    padding: 0.6rem 0 0.5rem;
    font-weight: bolder;
}


.sp_ml1r {
    margin-left: 1rem;
}


.menu_box ul.lo_time {
    font-size: 20px;
    font-weight: bold;
    margin-top: 50px;
    border: 5px double;
}

#ftmap {
	width: 100%;
	height: 40vh;
}



.acs_wrap {
    background-color: rgba(255, 255, 255, 0.8);
    padding: 0 0 2rem;
    margin-bottom: 2rem;
}


.acs_box {
}
.acs_box p {
    font-size: 100%;
    padding: 0 10%;
    text-align: center;
    line-height: 1.4;
}

p.map_to {
    margin-bottom: 1.5rem;
}
.acs_box a {
    color:#790000;
    text-decoration: none;
    font-weight: bold;
    font-size: 112%;
    padding: 0 2%;
}

.acs_box a:hover {
    color:#000;
    text-decoration: underline;
}

button, input, select, textarea {
  font-family : inherit;
  font-size   : 100%;
}


form th span {
    font-size: 76%;
    display: inline-block;
    background-color: #790000;
    padding: 0.5rem 1% 0.4rem;
    color: #fff;
    margin-left: 0.8rem;
    line-height: 1.0;
    border: 1px solid ;
}


#mfp_confirm_table,
form table {
    margin:1rem auto;
    font-size: 96%;
    width: 90%;
}
#mfp_confirm_table th ,
form th {
    display: block;
    background-color: #939393;
      border: 3px solid #fff;
    width: 100%;
    padding: 1rem 1%;
    text-align: center;
    vertical-align: top;
}

#mfp_confirm_table td,
form td {
    display: block;
    background-color: #fff;
      border: 3px solid #fff;
    width: 100%;
}


#mfp_confirm_table td {
    padding: 0.5rem;
}
 div#mfp_overlay_inner h4 {
     text-align: center;
     font-size: 150%;
}

input {
    width: 100%;
   background-color: transparent;
    font-size: 100%;
    border: none;
    padding: 1rem 2%;
}


label {
    padding-top: 1rem;
    display: inline-block;
    width: 46%;
    float: left;
    margin-left: 2%;
}

input[type=radio] {
width: auto;
    margin-right: 1rem;
}



textarea {
    width: 100%!important;
   background-color: transparent;
    font-size: 100%;
    border: none;
    padding: 1rem 2%;
	height: 20vh!important;
}

.omega {
    width: 100%;
    text-align: center;
    margin: 0 auto;
}

form .btn {
    margin: 1rem 0 5rem;
}

/*------------------------------------------
footere
------------------------------------------*/

#sns {
    margin: 1rem 0;
}


footer {   
    padding: 0.5rem 2% 5rem;
}

footer p {
    text-align: center;
    margin: 1rem 0 0.5rem;
    font-size: 76%; 
}

a.ft_bnr img {
    width: 50%;
    display: block;
    margin: 0.5rem auto;
}

.menu_fixed {
    position: fixed;
    width: 100%;
    z-index: 9;
    height: auto;
    background-color: rgba(255, 255, 255,0.8);
    border-top: 1px solid;
    bottom: 0;
    left: 0;
}

.menu_fixed > ul > li {
    text-align: center;
    float: left;
    box-sizing: border-box;
    border-right: 1px dotted;
    width: 25%;
    padding-top: 0.2rem;
}

.menu_fixed a {
    color: #000;
    text-decoration: none;
    font-size: 86%;
    font-weight: bold;
}
.menu_fixed > ul > li img{
    width: 50%;
}
/*------------------------------------------
footere
------------------------------------------*/

.th_txtbox {
    min-height: 60vh;
    text-align: center;
    font-size: 16px;
   width: 94%;
    margin: 0 auto;
    line-height: 1.5;
    
}

#thanks h2 { 
    margin-top: 0;
    text-align: center;
    padding-top: 2rem;
    font-size: 116%;
    width: 80%;
    line-height: 1.5;
}
.th_txtbox .btn {
    margin: 5rem auto;
    }


#thanks footer {   
    padding: 0.5rem 2% 0rem;
}