@charset "utf-8";

/* 共通スタイル
 * ************************************************** */
a,
a:focus,
.slick-slide,
area,
area:focus {
	outline: none;
}
a {
	-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 {
	opacity: 0.8;
}
img {
	max-width: 100%;
    vertical-align: bottom;
}
.gotop {
    display: block;
    width: 23px;
    position: fixed;
    right: 20px;
    bottom: 20px;
    line-height: 1;
}
.d_sp { display:none!important; }

/* kv
 * ************************************************** */
#kv {
	padding-top: 45px;
}
#kv h1 {
	margin: 0 auto 30px;
	width: 1024px;
	max-width: 92%;
}
#kv .presented {
	margin: 0 auto 30px;
	width: 1024px;
	max-width: 92%;
	text-align: right;
	font-size: 1.2rem;
	line-height: 1;
}
#kv .kv_img {
	display: flex;
	justify-content: center;
	align-items: flex-start;
	margin: 0 auto;
	width: 100%;
	max-width: 1200px;
}
#kv .kv_img img {
	width: 50%;
}

/* profile
 * ************************************************** */
#profile {
	position: relative;
}
#profile > img {
	position: absolute;
	top: -28px;
	left: -5.625%;
	width: 28.75%;
}
#profile .profile_txt {
	padding: 160px 0 190px 25%;
	font-size: 1.1rem;
}
#profile .profile_txt .name {
	color: #000;
	font-weight: 500;
}
#profile .profile_txt .name span:first-child {
	padding-right: 0.6em;
	font-size: 1.2rem;
}
#profile .profile_txt .name span:last-child {
	font-size: 1.7rem;
}

/* intro
 * ************************************************** */
#intro p,
#intro img {
	margin-bottom: 30px;
}
#intro .intro_img_wrap {
	display: flex;
	justify-content: center;
	align-items: flex-start;
}
#intro .intro_img_wrap img {
	width: 50%;
}
#intro .intro_note {
	margin: -20px 0 0;
	text-align: right;
	font-size: 0.8rem;
}

/* cont
 * ************************************************** */
/* cont_nav */
.cont_nav {
	margin-bottom: 70px;
}
.cont_nav ul {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.cont_nav ul li {
	width: 32%;
}
.cont_nav ul li a {
	position: relative;
	display: block;
	padding: 35px 0;
	width: 100%;
	text-align: center;
	font-size: 1.66rem;
	line-height: 1;
	color: #fff;
	text-decoration: none;
	font-weight: bold;
	border-radius: 80px;
}
.cont_nav ul li.nav_cont01 a {
	background: #f7931e;
}
.cont_nav ul li.nav_cont02 a {
	background: #009245;
}
.cont_nav ul li.nav_cont03 a {
	background: #c1272d;
}
#cont01 .cont_nav ul li.nav_cont01 a:before,
.cont_nav ul li.nav_cont01 a:hover:before,
#cont02 .cont_nav ul li.nav_cont02 a:before,
.cont_nav ul li.nav_cont02 a:hover:before,
#cont03 .cont_nav ul li.nav_cont03 a:before,
.cont_nav ul li.nav_cont03 a:hover:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -9px;
  border: 9px solid transparent;
  border-top: 15px solid;
}
.cont_nav ul li.nav_cont01 a:before {
	border-top-color: #f7931e!important;
}
.cont_nav ul li.nav_cont02 a:before {
	border-top-color: #009245!important;
}
.cont_nav ul li.nav_cont03 a:before {
	border-top-color: #c1272d!important;
}
/* cont */
.cont_a,
.cont_b,
.cont_a img,
.cont_c img {
	display: block;
	margin-bottom: 30px;
}
.cont_b img {
	display: block;
	margin: 0 auto 30px;
	width: 86%;
}
.cont_c {
	margin: 0 auto 30px;
	width: 77%;
}
.cont_ttl {
	position: relative;
	margin: 0 auto 20px;
	width: 660px;
}
.cont_ttl .name {
	font-size: 2.2rem;
	line-height: 1.5;
	font-weight: 500;
}
.cont_ttl .area {
	font-size: 1.2rem;
	line-height: 1.5;
	text-indent: -0.5em;
}
.cont_ttl .ttl_img,
.cont_ttl .ttl_balloon {
	position: absolute;
}
/* cont01 */
#cont01 .cont_ttl {
	padding-bottom: 260px;
}
#cont01 .cont_ttl .ttl_img {
	top: 20px;
	right: 0;
	width: 21.5152%;
}
#cont01 .cont_ttl .ttl_balloon {
	top: 100px;
	left: 0;
	width: 75.7576%;
}
/* cont02 */
#cont02 .cont_ttl {
	padding-bottom: 260px;
}
#cont02 .cont_ttl .ttl_img {
	top: 10px;
	right: 4%;
	width: 26%;
}
#cont02 .cont_ttl .ttl_balloon {
	top: 100px;
	left: 1%;
	width: 78%;
}
/* cont03 */
#cont03 {
	padding-bottom: 60px;
	border-bottom: 1px solid #4d4d4d;
}
#cont03 .cont_ttl {
	padding-bottom: 330px;
}
#cont03 .cont_ttl .name span {
	font-size: 50%;
}
#cont03 .cont_ttl .ttl_img {
	top: 100px;
	left: 0;
	width: 25.3%;
}
#cont03 .cont_ttl .ttl_balloon {
	top: 180px;
	right: 1%;
	width: 78.7%;
}

/* restaurant
 * ************************************************** */
#restaurant > div {
	margin: 0 auto 60px;
	width: 650px;
}
#restaurant .restaurant03 {
	margin-bottom: 0;
}
#restaurant .restaurant_img {
	display: block;
	margin: 0 auto;
	width: 86%;
}
#restaurant .name {
	margin: 15px auto 10px;
	font-size: 2.2rem;
	text-align: center;
	font-weight: 500;
}
#restaurant .name span {
	font-size: 50%;
}
#restaurant .area {
	display: block;
	margin: 0 auto 20px;
	padding: 0.5em 0;
	width: 240px;
	text-align: center;
	font-weight: bold;
	color: #fff;
	font-size: 1.2rem;
	line-height: 1;
	background: #4d4d4d;
}
#restaurant .restaurant_info {
	margin: 20px auto 30px;
	font-size: 0.88rem;
}
#restaurant .restaurant_info .tel a {
	display: block;
	margin-bottom: 8px;
	font-size: 1.1rem;
	text-decoration: none;
	color: #4d4d4d;
	letter-spacing: 0;
}
#restaurant .restaurant_btn {
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
}
#restaurant .restaurant_btn a {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 33.3333%;
	height: 60px;
}
#restaurant .restaurant_btn a.btn_tel {
	background: #8c6239;
}
#restaurant .restaurant_btn a.btn_tel img {
	width: 31.4815%;
}
#restaurant .restaurant_btn a.btn_map {
	background: #d4145a;
}
#restaurant .restaurant_btn a.btn_map img {
	width: 37.037%;
}
#restaurant .restaurant_btn a.btn_insta {
	background: #29abe2;
}
#restaurant .restaurant_btn a.btn_insta img {
	width: 75%;
}

/* home
 * ************************************************** */
#home {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 20px 5% 30px;
	font-size: 0.9rem;
	border-top: 1px solid #231815;
	border-bottom: 1px solid #231815;
}
#home > img {
	width: 21%;
}
#home .txt {
	width: 72.2%;
}
#home .txt h2 {
	margin-bottom: 20px;
	width: 55.7%;
}

/* stop
 * ************************************************** */
#stop {
	margin: 0 auto 60px;
	padding: 40px;
	border: 1px solid #4d4d4d;
	width: 600px;
}
#stop h2 {
	margin-bottom: 10px;
	color: #ed1c24;
	font-size: 1.22rem;
	text-align: center;
	font-weight: bold;
}
#stop p {
	text-align: center;
}

/* notes
 * ************************************************** */
#notes {
	margin-bottom: 80px;
	font-size: 0.88rem;
}