@charset "UTF-8";


/* reset  -------------------------------- */
html,body,div,span,object,iframe,h1,h2,h3,h4,h5,h6,p,blockquote,pre,abbr,address,cite,code,del,dfn,em,img,ins,kbd,q,samp,small,strong,sub,sup,var,b,i,dl,dt,dd,ol,ul,li,fieldset,form,label,legend,table,caption,tbody,tfoot,thead,tr,th,td,article,aside,canvas,details,figcaption,figure,footer,header,hgroup,menu,nav,section,summary,time,mark,audio,video{margin:0;padding:0;border:0;outline:0;font-size:100%;vertical-align:top;background:transparent;}body{line-height:1;}article,aside,details,figcaption,figure,footer,header,hgroup,menu,nav,section{display:block;}nav ul{list-style:none;}blockquote,q{quotes:none;}blockquote:before,blockquote:after,q:before,q:after{content:none;}a{margin:0;padding:0;font-size:100%;vertical-align:baseline;background:transparent;}ins{background-color:#ff9;color:#222;text-decoration:none;}mark{background-color:#ff9;color:#222;font-style:italic;font-weight:bold;}del{text-decoration:line-through;}abbr[title],dfn[title]{border-bottom:1px dotted;cursor:help;}table{border-collapse:collapse;border-spacing:0;}hr{display:block;height:1px;border:0;border-top:1px solid #ccc;margin:1em 0;padding:0;}input,select{vertical-align:middle;}
a {
	text-decoration: none;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a:hover { cursor: pointer; }
ul, li { list-style: none;}
img { max-width: 100%; height: auto; }
img[src$=".svg"] { width: 100%; }
a:focus { outline: none; }
body, h1, h2, h3, h4 { font-weight: normal; }
* {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

/* clearfix ----------------------*/
.clearfix { zoom: 1; }
.clearfix:after { content: ""; display: block; clear: both; }

/* img hover ----------------------*/
a img {
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
a:hover img {
	opacity: 0.3;
    filter: alpha(opacity=30);
    -moz-opacity: 0.3;
}

/* color ----------------------*/

body { color: #7d645a; }

/* font* ----------------------*/

body {
	font-family: 'Noto Sans JP', sans-serif; /*20220127*/	
	font-weight: 400;
	-webkit-font-feature-settings: 'palt' 1;
	font-feature-settings: 'palt' 1;
	letter-spacing: 0.1rem;
	
	text-align: justify; text-justify: inter-ideograph !important;
}
@media screen and (max-width: 600px) { body  {letter-spacing: 0rem; } }

.win body { }
.mac body { }

/* font-size ----------------------*/
html { font-size: 62.5%;  }

/* image ----------------------*/
.image_mobile { display: none; }
@media screen and (max-width: 600px) {
	.image_mobile { display: block; }
	.image_pc { display: none; }
}

/* share  ---------------------- */
.share_box { margin: 0 -15px; }
.share { display: table; width: 100%; table-layout: fixed; *overflow:auto; }
.share section { display: table-cell; vertical-align: top; *float:left; padding: 0 15px 30px 15px; }
@media screen and (max-width: 1200px) {
	.share_box { margin: 0 -10px; }
	.share section { padding: 0 10px; }
}
@media screen and (max-width: 600px) {
	.share, .share section { display: block; }
	.share_box { margin: 0; }
	.share section { padding: 0 0 30px 0;  }
}

/* space ---------------------- */
.space_topbottom { padding: 30px 0; }
.space_top { padding: 30px 0 0 0; }
.space_bottom { padding: 0 0 30px 0; }

/* DESIGN ---------------------------------------------------------------------
----------------------------------------------------------------------------- */

/* z-index ---------------------- */

article, footer  { z-index: 0; }
.mobile_nav { z-index: 99; }
header { z-index: 100; }
#menuButton { z-index: 101; }

/* layout ---------------------- */

.contents { max-width: 1200px; padding: 0 20px; margin: 0 auto; }
.contents_center { max-width: 700px; padding: 0 20px; margin: 0 auto; }
.base_color { /*background: #fff;*/ }
.link_point { margin: -70px 0 0 0; padding: 70px 0 0 0; }
.line_gray { display: block; width: 100%; height: 1px; background: #ed7700; margin: 70px 0; }
@media screen and (max-width: 1000px) {
	article { /*padding: 50px 0 0 0;*/ }
	.link_point { margin: -50px 0 0 0; padding: 50px 0 0 0; }
	.line_gray { margin: 50px 0; }
}

/* header ----------------------*/

.header {
	width: 100%; height: 70px; background: #7d645a; display: block;
	position: fixed; top: -65px; left: 0;
	border-bottom: solid 2px #fff;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
.header_title { display: block; position: absolute; left: 40px; top: 10px; width: 145px; }
.header.scrolled {
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	position: fixed; top: 0; left: 0;
}
@media screen and (max-width: 1000px) {
	.header { height: 50px; position: fixed; top: -45px; left: 0; }
	.header_title { display: block; position: absolute; left: 25px; top: 7px; width: 110px; }
}

/* header_nav pc ----------------------*/

@media screen and (min-width: 1001px) {
	
.header_nav { position: absolute; right: 30px; top: 0px; }
.header_nav li { float: left; }
.header_nav li a  {
	display: block; padding: 0 20px; color: #fff;
	font-size: 1.4rem; height: 70px; line-height: 70px;
	position: relative;
} 
.header_nav li a:after {
	display: block; width: 0; height: 2px; background: #ed7700;
	content: ""; position: absolute; left: 0; right: 0; bottom: 20px; margin: auto;
	-webkit-transition: all 0.3s ease;
	-moz-transition: all 0.3s ease;
	-o-transition: all 0.3s ease;
	transition: all 0.3s ease;
}
.header_nav li a:hover:after {
	display: block; width: 80%; height: 2px; background: #ed7700;
	content: ""; position: absolute; left: 0; right: 0; bottom: 20px; margin: auto;
}

}

/* header_nav mobile ----------------------*/

#menuButton { display: none; }
@media screen and (max-width: 1000px) {
#menuButton {
	display: block;
	width: 42px; height:42px;
	position: absolute; top: 4px; right: 20px;
}
#menuButton span {
    display: block; background: #fff;
    width: 24px; height: 2px;
    position: absolute; left: 9px;
    -webkit-transition: all 0.5s;
    -moz-transition: all 0.5s;
	transition: all 0.5s;
}
#menuButton span:first-child { top: 12px; background: #fff; }
#menuButton span:nth-child(2) { margin-top: -1px; top: 50%; }
#menuButton span:last-child { bottom: 12px; }
#menuButton.active span:first-child {
    -webkit-transform: translateY(8px) rotate(45deg);
    -moz-transform: translateY(8px) rotate(45deg);
    -ms-transform: translateY(8px) rotate(45deg);
    transform: translateY(8px) rotate(45deg);
}
#menuButton.active span:nth-child(2) { opacity: 0; }
#menuButton.active span:last-child {
    -webkit-transform: translateY(-8px) rotate(-45deg);
    -moz-transform: translateY(-8px) rotate(-45deg);
    -ms-transform: translateY(-8px) rotate(-45deg);
    transform: translateY(-8px) rotate(-45deg);
}
.header_nav, .header_nav_active { transition: all 0.5s ease; }
.header_nav {
	position: fixed; top: 0; left: 100%;
	background: #23322d; padding: 100px 0;
	width: 100%; height: 100%; overflow: auto;
}
.header_nav_active { position: fixed; top: 0; left: 0; }
.header_nav ul li { border-top: solid 1px #ed7700; }
.header_nav ul li:last-child { border-bottom: solid 1px #ed7700; }
.header_nav li a  {
	display: block; color: #fff;
	font-size: 2rem; padding: 15px 30px;
} 
.header_nav li a:hover { color: #ed7700; }
	
}


/* footer  ---------------------- */

.footer { text-align: center; }
.footer_back { background: #7d645a; padding: 0 0 300px 0; }

.footer_copy, .footer_phone { color: #fff; text-align: center; }
.footer_copy {
	font-size: 1.6rem; line-height: 200%;
	padding: 20px 0 0 0;
}
.footer_copy span { display: block; }
.footer_copy br { display: none; }
.footer_phone p {
	font-size: 2.4rem; line-height: 50px; height: 50px;
	font-family: Arial, Helvetica, sans-serif;
	letter-spacing: 1px;
}
.footer_phone p img { width: 24px; margin: 13px 7px; }
@media screen and (max-width: 600px) {
	.footer_copy br { display:  block; } .footer_phone { display:  none; }
	.footer_copy { font-size: 1.4rem; }
}

.footer_nav ul { letter-spacing: -0.4em; padding: 50px 0 0 0; }
.footer_nav li {
	display: inline-block; letter-spacing: normal;
	font-size: 1.2rem; line-height: 160%;
}
.footer_nav li a  { color: #fff; padding: 0 10px; } .footer_nav li a:hover { color: #fff; }
.footer_copyright {
	font-size: 1rem; color: #fff; padding: 20px 0 0 0;
	font-family: Arial, Helvetica, sans-serif;
}
@media screen and (max-width: 600px) {
	.footer { text-align: left; }
	.footer_nav li {
		display: block; width: 50%; float: left; font-size: 1.4rem;
		border-bottom: solid 1px #fff;
	}
	.footer_nav li a { display: block; padding: 10px 0; }
	.footer_copyright { padding: 30px 0 0 0; }
}

/* mobile_nav (phone) ---------------------- */

.mobile_nav { display: none; }
@media screen and (max-width: 600px) {
.mobile_nav {
	display: block; position: fixed; bottom: 0; left: 0;
	background: #fff; width: 100%; height: 50px;
}
.mobile_nav p {
	display: block; text-align: center;
	font-size: 1.2rem; line-height: 50px; height: 50px;
}
.mobile_nav p a { color: #7d645a; }
.mobile_nav p a img { width: 22px; margin: 14px 4px; }
.mobile_nav p a:hover img {
	opacity: 1;
    filter: alpha(opacity=100);
    -moz-opacity: 1;
}
.mobile_nav p a strong { font-size: 2rem; font-family: Arial, Helvetica, sans-serif; }
}


/*google_map*/

.google_map {
	position: relative; padding-bottom: 30%; height: 0; overflow: hidden;
}
.google_map iframe {
	position: absolute; top: 0; left: 0;
	width: 100% !important; height: 100% !important;
}
@media only screen and (max-width: 600px) { .google_map { padding-bottom: 100%; } }


/* top_main ---------------------- */

.top_main {
	display: block; width: 100%; height: 100vh;
	background: url(../images/top_main_pc.jpg) no-repeat center;
	background-size: cover;
	position: relative;
	animation-name: motion00;
	animation-duration: 1s;
}
@media only screen and (max-width: 600px) { .top_main { margin-top: -50px; } }

/*クラフトビール専門店*/
.top_point01 {
	width: 200px; height: 200px;
	position: absolute; bottom: 15%; right: 20%;
	animation-name: motion01;
	animation-duration: 1s;
}
@media only screen and (min-width: 1400px) { .top_point01 { width: 220px; height: 220px; } }
/*OPEN*/
.top_point02 {
	width: 288px; height: 170px;
	position: absolute; bottom: 5%; left: 3%;
	animation-name: motion02;
	animation-duration: 1.2s;
}
@keyframes motion00 {
	0% { transform: scale(1.5, 1.5); opacity: 0 }
	100% { transform: scale(1, 1); opacity: 1; }
}
@keyframes motion01 {
	0% { transform: scale(0.5, 0.5); opacity: 0; }
	70% { transform: scale(0.5, 0.5); opacity: 0; }
	100% { transform: scale(1, 1); opacity: 1; }
}
@keyframes motion02 {
	0% { transform: scale(0.5, 0.5); opacity: 0; }
	60% { transform: scale(0.5, 0.5); opacity: 0; }
	80% { transform: scale(1, 1); opacity: 1; }
	100% { transform: scale(1, 1); opacity: 1; }
}
@media only screen and (max-width: 800px) {
	.top_point01 { width: 170px; height: 170px; position: absolute; top: auto; bottom: 20%; right: 10%; }
	.top_point02 { width: 200px; height: 118px; position: absolute; bottom: 15px; left: 15px; }	
}
@media only screen and (max-width: 600px) {
	.top_point01 { width: 130px; height: 130px; position: absolute; bottom: 15%; right: 5%; }	
	.top_point02 { width: 170px; height: 100px; position: absolute; bottom: 60px; left: 15px; }	
}




/* contents  ---------------------- */

/* copy */
.contents_title {
	font-size: 2.4rem; text-align: center;
	color: #5f4034; width: 100%;
	font-weight: 700;
	line-height: 70px; height: 70px;
	background: url(../images/contents_title_pc.jpg) no-repeat;
	background-size: 100% 100%;
}
.contents_title br { display: none; }
@media screen and (max-width: 1000px) {
	.contents_title {
		display: block; padding: 30px 0;
		line-height: 160%; height: auto;
	}
	.contents_title br { display: block; }
}
@media screen and (max-width: 600px) {
	.contents_title {
		font-size: 2.2rem;
		background: url(../images/contents_title_mobile.jpg) no-repeat;
		background-size: 100% 100%;
	}
}

.body_title { font-size: 3rem; line-height: 160%; font-weight: 700; }
.body_copy { font-size: 1.7rem; line-height: 220%; }
.body_copy_mini { font-size: 1.4rem; line-height: 180%; }
.body_title, .body_copy, .body_copy_mini { padding: 0 0 20px 0; text-align: justify; }
@media screen and (max-width: 600px) { 
	.body_title { font-size: 2.4rem; }
	.body_title span { display: inline-block; }
	.body_copy { font-size: 1.4rem; }
	.body_copy_mini { font-size: 1.2rem; }
}

/*gallery*/

.gallery { margin: 20px 0 0 0; text-align: center; }
.gallery a {
	display: inline-block; width: 20%; border: solid 5px #fff;
	border-radius: 20px; overflow: hidden;
}
@media screen and (max-width: 600px) { .gallery a { width: 30%; } }

/*radius_image*/
.radius_image { border-radius: 20px; overflow: hidden; margin: 0 0 25px 0; }

/*price_table*/
.price_table { width: 100%; margin: 0 0 20px 0; border-collapse: separate; }
.price_table caption, .price_table th, .price_table td {
	font-size: 1.6rem; line-height: 160%; padding: 30px; text-align: left; border: solid 1px #fff;
}
.price_table tr:first-child th, .price_table tr:first-child td { padding: 10px 30px; }
.price_table caption { text-align: center; background: #f0f0f0; border-radius: 20px; }
.price_table tr:first-child td { opacity:0.5; }
.price_table th { background: #ccc;  }
.price_table td { background: #f0f0f0; }
.price_table tr:first-child th, .price_table tr:first-child td { background: none; }
.price_table01 { border-radius: 20px 0 0 0; }
.price_table02 { border-radius: 0 20px 0 0; }
.price_table03 { border-radius: 0 0 0 20px; }
.price_table04 { border-radius: 0 0 20px 0; }
@media screen and (max-width: 600px) {
	.price_table caption, .price_table th, .price_table td { font-size: 1rem; padding: 20px 10px; }
	.price_table caption, .price_table th { font-weight: 700; }
	.price_table01 { border-radius: 10px 0 0 0; }
	.price_table02 { border-radius: 0 10px 0 0; }
	.price_table03 { border-radius: 0 0 0 10px; }
	.price_table04 { border-radius: 0 0 10px 0; }
	.price_table caption { border-radius: 10px; }
}

/*company*/

.company_contents { padding: 80px 0; }
@media screen and (max-width: 600px) { .company_contents { padding: 50px 0; } }
.table01 { width: 100%; border-bottom: solid 1px #7d645a; }
.table01 dt { width: 30%; } .table01 dd { width: 70%; }
.table01 dt, .table01 dd {
	font-size: 1.3rem; line-height: 160%; font-weight: normal;
	padding: 20px 0;
	float: left; border-top: solid 1px #7d645a
}
.table01 dd a { color: #7d645a; } .table01 dd  a:hover { color: #ccc; }
@media screen and (max-width: 600px) {
	.table01 dt { width: 20%; } .table01 dd { width: 80%; }
	.table01 dt, .table01 dd { font-size: 1rem; padding: 10px 0; }
}

.profile_image { width: 350px; }
.shop_banner { width: 200px; padding: 10px 0; }
.shop_banner img { padding: 0 0 10px 0; }
@media screen and (max-width: 600px) {  .profile_image { width: 100%; } }

/*craftbeer*/

.craftbeer_back {
	/*background: #eae0d0;*/
	background: #23322d; color: #fff;
	padding: 30px 50px; margin: 2px 0; text-align: center;
}
.craftbeer {  }
.craftbeer section {
	float: left; padding: 15px; margin: 0 0 20px 0; width: 25%;
	text-align: center;
}
.craftbeer_image { position: relative; }
.craftbeer_image_logo {
	width: 30%; height: 30%;
	position: absolute; left: -10px; top: 0; bottom: 0; margin: auto;
}
.craftbeer_title { font-size: 2rem; line-height: 160%; padding: 20px 0 10px 0; color: #fff; }
.craftbeer_copy { font-size: 1.4rem; line-height: 220%; padding: 0 0 15px 0; }
.craftbeer_copy_mini { font-size: 1.4rem; line-height: 220%; text-align: center; }
.craftbeer_data {
	font-size: 1.2rem; line-height: 220%; padding: 0; color: #ed7700; /*background: #fff;*/
	border-top: dotted 1px #ed7700;
	border-bottom: dotted 1px #ed7700;
}
.craftbeer_title, .craftbeer_copy, .craftbeer_copy_mini, .craftbeer_data { opacity: 0.8; }
@media screen and (max-width: 1000px) {
	.craftbeer section { width: 50%; }
	.craftbeer_title { font-size: 1.8rem; }
	.craftbeer_copy { font-size: 1.2rem; }
	.craftbeer_copy_mini { text-align: justify; text-justify: inter-ideograph !important; }
	.craftbeer_copy_mini br { display: none; }
}
@media screen and (max-width: 600px) {
	.craftbeer_back { padding: 30px 20px; }
	.craftbeer section { width: 100%; }
	.craftbeer_image { padding: 0 20px; }
}

/*feature*/

.feature01 { border: solid 1px #fff; margin: 0 -2px; }
.feature01_image { float: left; width: 50%; position: relative; border: solid 1px #fff; }
@media screen and (max-width: 1000px) { .feature01_image { width: 100%; } }

.feature01_copy {
	position: absolute; bottom: 40px; right: 20px;
	color: #fff; text-align: right;
}
.feature01_copy h1 { font-size: 2.2rem; line-height: 160%; padding: 0 10px 20px 0; }
.feature01_copy p { font-size: 1.5rem; line-height: 220%; }
.feature02 { margin: 80px 0; }
.feature02_image { max-width: 400px; margin: 0 auto; }
@media screen and (max-width: 600px) { 
	.feature01_copy {
	position: relative; bottom: auto; right: auto;
	text-align: left; padding: 20px; margin: 2px 0 0 0; background: #23322d;
	}
	.feature01_copy h1, .feature01_copy p { opacity: 0.8; }
	.feature02 { margin: 50px 0; }
}

/*menu*/

.menu_copy {
	position: absolute; top: 0; left: 0; right: 0; bottom: 0; margin: auto;
	width: 100%; height: 125px;
	color: #fff; text-align: center;
}
.menu_copy p { font-size: 1.2rem; line-height: 220%; }

/*link button*/

.link01 { margin: 20px 0; display: inline-block; width: 260px; }
.link01 a {
	display: block; position: relative; font-weight: 700;
	border: solid 2px #fff;
	-webkit-border-radius: 130px; -moz-border-radius: 130px; border-radius: 30px;
	font-size: 1.6rem; text-align: left; line-height: 60px; height: 60px;
	color: #fff; padding: 0 30px;
}
.link01 a:after {
	content: "";
	position: absolute; top: 0; bottom: 0; right: 25px; margin: auto;
	display: block; width: 10px; height: 10px; 
	border-right: 2px solid #fff; border-bottom: 2px solid #fff; 
	-ms-transform: rotate(-45deg); -moz-transform: rotate(-45deg); -webkit-transform: rotate(-45deg);
	-o-transform: rotate(-45deg); transform: rotate(-45deg);
}
.link01 a:hover { background-color: rgba(255,255,255,0.2); }

/*whats_craftbeer*/

.whats_craftbeer {
	border: solid 1px #ed7700;
	border-radius: 15px;
	padding: 20px 20px 0 20px; margin: 80px 0;
}
.whats_craftbeer h3 { font-size: 1.6rem; font-weight: 700; padding: 0 0 10px 0; }
@media screen and (max-width: 600px) {  .whats_craftbeer { margin: 50px 0; } }