@charset "utf-8";


/* ---------------------------------------------------------
 * common
** --------------------------------------------------------- */
body {
	color: #333;
	font-size: 16px;
	font-family: '游明朝','Yu Mincho',YuMincho,'Hiragino Mincho Pro',serif;
	line-height: 1.6;
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
	body {
	}
}

:root {
	--vw: 1vw;
}


/* --------------- .wrapper --------------- */
.wrapper {
	max-width: 1140px;
	width: 100%;
	padding: 0 20px;
	margin: 0 auto;
}
.wrapper.w {
	max-width: 1220px;
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
}


/* --------------- .wrapper --------------- */
.YuGothic {
	font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
}
.YuGothic.bold,
.YuGothic .bold {
	font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
	font-weight: bold;
}



/* ---------------------------------------------------------
 * header
** --------------------------------------------------------- */
#header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 30;
	display: flex;
	justify-content: space-between;
	width: 100%;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.40) 0%, rgba(0, 0, 0, 0.00) 100%);
	pointer-events: none;
}
.h_logo {
	padding-left: 40px;
	padding-top: 30px;
	pointer-events: initial;
}
.h_logo img {
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
	.h_logo {
		padding-left: 15px;
		padding-top: 15px;
	}
	.h_logo img {
		width: 80px;
		height: 80px;
	}
}

/* .h_right */
.h_right {
	display: flex;
	padding-top: 35px;
	padding-right: 90px;
	pointer-events: initial;
}
.h_right a {
}
.h_right a img {
}
.h_right .top {
}
.h_right .menu {
	margin-left: 40px;
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
	.h_right {
		padding-top: 20px;
		padding-right: 20px;
	}
	.h_right a {
	}
	.h_right a img {
	}
	.h_right .top {
	}
	.h_right .menu {
		margin-left: 20px;
	}
}




/* ---------------------------------------------------------
 * footer
** --------------------------------------------------------- */
#footer {
	padding-top: 50px;
	padding-bottom: 30px;
	background-image: url("../img/menu_bg.jpg");
	background-position: center;
	background-size: cover;
}
#footer .wrapper {
	display: flex;
	justify-content: center;
	gap: calc(12000% / 1100);
}
#footer .left {
	padding-top: 20px;
}
#footer .left img {
	max-width: 100%;
}
#footer .right {
	flex-shrink: 0;
}
#footer table {
	width: 100%;
}
#footer th,
#footer td {
	padding: 20px 0;
}
#footer tr:not(:first-child) th,
#footer tr:not(:first-child) td {
	border-top: 1px solid rgba(34, 34, 34, 0.2);
}
#footer th {
	width: 120px;
}
#footer tr:first-child th {
	vertical-align: middle;
}
#footer td {
}
#footer td a {
	font-size: 30px;
	text-decoration: underline;
}
#footer td a:hover {
	text-decoration: none;
}
#footer td > div {
	display: flex;
	text-align: center;
}
#footer .lunch {
	padding-right: 30px;
	margin-right: 40px;
	border-right: 1px solid rgba(34, 34, 34, 0.2);
}
#footer .dinner {
}
#footer .subttl {
}
#footer .time {
}
#footer .fds {
	margin-top: 15px;
	padding: 20px;
	text-align: center;
	background-color: rgba(185, 93, 38, 0.12);
	border-radius: 5px;
}
#footer .fds img {
	max-width: 100%;
}
#footer .copy {
	margin-top: 60px;
	opacity: 0.5;
	font-size: 12px;
	text-align: center;
}
@media (max-width: 1099px) {
	#footer .wrapper {
		display: flex;
		justify-content: center;
		gap: calc(4000% / 1100);
	}
}
@media (max-width: 819px) {
	#footer td > div {
		display: block;
	}
	#footer .lunch {
		padding-right: 0;
		padding-bottom: 10px;
		margin-bottom: 10px;
		margin-right: 0;
		border-right: none;
		border-bottom: 1px solid rgba(34, 34, 34, 0.2);
	}
}
@media (max-width: 519px) {
	#footer .wrapper {
		display: block;
	}
	#footer .left {
		padding-top: 0;
		text-align: center;
	}
	#footer .left img {
		max-width: 127px;
	}
	#footer .right {
		flex-shrink: 0;
	}
	#footer .fds img {
		max-width: 70%;
	}
}




/* ---------------------------------------------------------
 * index
** --------------------------------------------------------- */
/* ---------- #fv ---------- */
#fv {
}
#fv img {
	width: 100%;
}
@media (max-width: 1239px) {
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
}


/* ---------- #lead ---------- */
#lead {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	height: 1040px;
	padding-bottom: 100px;
	background-image: url("../img/lead_bg.jpg");
	background-size: cover;
	background-position: center;
}
#lead h2 {
}
#lead p {
	margin-top: 90px;
	font-size: 18px;
	text-align: center;
	line-height: 2;
	letter-spacing: 3px;
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
	#lead {
		height: auto;
		padding-top: 80px;
		padding-bottom: 80px;
	}
	#lead h2 img {
		width: 194px;
	}
	#lead p {
		max-width: 80%;
		margin-top: 50px;
		margin-left: auto;
		margin-right: auto;
	}
}


/* ---------- #kodawari ---------- */
#kodawari {
}
#kodawari .first_bg {
	background-image: url("../img/kodawari01_bg.jpg");
	background-size: cover;
	background-position: top center;
}
#kodawari h2 {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 280px;
}
#kodawari h2 img {
	max-width: 100%;
}
#kodawari section {
	height: 625px;
	background-size: cover;
	background-position: top center;
}
#kodawari .wrapper {
	display: flex;
	align-items: center;
	height: 100%;
}
#kodawari .wrapper > div {
	text-align: center;
}
#kodawari .left {
}
#kodawari .right {
	margin-left: auto;
}
#kodawari h3 {
}
#kodawari p {
	margin-top: 50px;
	color: #fff;
	font-weight: bold;
	line-height: 2;
	letter-spacing: 2px;
}
#kodawari .soup {
	background-image: url("../img/kodawari02_bg.jpg");
}
#kodawari .chiyu {
	background-image: url("../img/kodawari03_bg.jpg");
}
#kodawari .tare {
	background-image: url("../img/kodawari04_bg.jpg");
}
@media (min-width: 1440px) {
	#kodawari .first_bg {
		background-position: top calc(0rem + ((1vw - 14.4px) * -20)) center;
	}
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
	#kodawari section {
		height: 450px;
	}
	#kodawari .first_bg h3 img {
		width: 162px;
	}
	#kodawari .soup h3 img {
		width: 180px;
	}
	#kodawari .chiyu h3 img {
		width: 198px;
	}
	#kodawari .tare h3 img {
		width: 228px;
	}
	#kodawari p {
		margin-top: 20px;
	}
	#kodawari p br {
		display: none;
	}
}


/* ---------- #oshinagaki ---------- */
#oshinagaki {
	padding-top: 100px;
	padding-bottom: 100px;
	background-image: url("../img/oshinagaki_bg.jpg");
	background-position: top center;
	background-size: cover;
	overflow: hidden;
}
#oshinagaki .wrapper {
	display: grid;
	grid-template-areas:
		".        head"
		"tsuke    head"
		"tsuke    nikomi"
		"side     nikomi"
		"btn_area btn_area";
	align-items: start;
}
#oshinagaki .head {
	grid-area: head;
	justify-self: end;
	display: flex;
	flex-direction: row-reverse;
}
#oshinagaki h2 {
}
#oshinagaki p {
	padding-top: 100px;
	padding-right: 100px;
	font-size: 20px;
	line-height: 2;
	letter-spacing: 3px;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
}
#oshinagaki .tsuke,
#oshinagaki .nikomi,
#oshinagaki .side {
}
#oshinagaki .tsuke {
	grid-area: tsuke;
	margin-top: 100px;
}
#oshinagaki .nikomi {
	grid-area: nikomi;
	justify-self: end;
	margin-top: -70px;
	margin-right: -60px;
}
#oshinagaki .side {
	grid-area: side;
	text-align: right;
}
#oshinagaki .tsuke a,
#oshinagaki .nikomi a,
#oshinagaki .side a {
	position: relative;
	display: block;
	padding-top: 100px;
}
#oshinagaki .tsuke a {
	padding-left: 20px;
}
#oshinagaki .nikomi a {
}
#oshinagaki .side a {
	display: inline-flex;
	justify-content: end;
	align-items: start;
	padding-top: 0;
}
#oshinagaki .tsuke .ttl,
#oshinagaki .nikomi .ttl,
#oshinagaki .side .ttl {
	position: absolute;
	top: 0;
	left: 0;
}
#oshinagaki .tsuke .ttl {
}
#oshinagaki .nikomi .ttl {
	left: -50px;
}
#oshinagaki .side .ttl {
	position: static;
	margin-right: -30px;
}
#oshinagaki .tsuke .img,
#oshinagaki .nikomi .img,
#oshinagaki .side .img {
	max-width: 100%;
}
#oshinagaki .tsuke .img {
}
#oshinagaki .nikomi .img {
}
#oshinagaki .side .img {
}
#oshinagaki .tsuke .link,
#oshinagaki .nikomi .link,
#oshinagaki .side .link {
	position: absolute;
}
#oshinagaki .tsuke .link {
	bottom: 65px;
	right: 190px;
}
#oshinagaki .nikomi .link {
	bottom: 80px;
	right: 80px;
}
#oshinagaki .side .link {
	bottom: 65px;
	right: 45px;
}
#oshinagaki .btn_area {
	grid-area: btn_area;
	text-align: center;
}
#oshinagaki .btn_area a {
}
#oshinagaki .btn_area img {
	max-width: 100%;
	border-radius: 7px;
	box-shadow: 0px 18px 43px 0px #B6A890;
}
@media (max-width: 1099px) {
	#oshinagaki .tsuke {
		width: calc(63300vw / 1100);
/*		margin-top: 100px;*/
	}
	#oshinagaki .nikomi {
		width: calc(50500vw / 1100);
/*		margin-top: -70px;*/
/*		margin-right: -60px;*/
	}
}
@media (max-width: 519px) {
	#oshinagaki {
/*		padding-top: 100px;*/
/*		padding-bottom: 100px;*/
		background-image: url("../img/oshinagaki_bg.jpg"), url("../img/menu_bg.jpg");
		background-position: top left, top center;
		background-repeat: no-repeat, repeat;
		background-size: calc(144000% / 812), auto 100%;
	}
	#oshinagaki .wrapper {
		display: block;
	}
	#oshinagaki .head {
		justify-content: center;
	}
	#oshinagaki h2 {
	}
	#oshinagaki h2 img {
		width: 89px;
	}
	#oshinagaki p {
/*		padding-top: 100px;*/
		padding-right: 30px;
/*		font-size: 20px;*/
/*		line-height: 2;*/
/*		letter-spacing: 3px;*/
	}
	#oshinagaki .tsuke {
		width: 100%;
		margin-top: 20px;
	}
	#oshinagaki .nikomi {
		width: 100%;
		margin-top: 20px;
		margin-right: 0px;
	}
	#oshinagaki .side {
		margin-top: 30px;
	}
	#oshinagaki .tsuke a,
	#oshinagaki .nikomi a,
	#oshinagaki .side a {
		padding-top: 70px;
	}
	#oshinagaki .side a {
		justify-content: start;
		padding-top: 0;
	}
	#oshinagaki .tsuke .ttl,
	#oshinagaki .nikomi .ttl,
	#oshinagaki .side .ttl {
		top: 0;
		left: 0;
	}
	#oshinagaki .tsuke .ttl {
		width: 91px;
	}
	#oshinagaki .nikomi .ttl {
		width: 90px;
	}
	#oshinagaki .side .ttl {
		width: 59px;
	}
	#oshinagaki .tsuke .img,
	#oshinagaki .nikomi .img {
		margin-left: 80px;
	}
	#oshinagaki .tsuke .img {
	}
	#oshinagaki .nikomi .img {
		width: 82%;
		margin-left: 95px;
	}
	#oshinagaki .side .img {
	}
	#oshinagaki .tsuke .link,
	#oshinagaki .nikomi .link,
	#oshinagaki .side .link {
		bottom: 0;
		right: 0;
	}
	#oshinagaki .side .link {
		bottom: 30px;
	}
}


/* ---------- #shop ---------- */
#shop {
	padding-top: 80px;
	padding-bottom: 100px;
	background-image: url("../img/shop_bg.jpg");
	background-position: bottom center;
	background-size: cover;
	color: #fff;
}
#shop h2 {
}
#shop .content {
	display: flex;
	justify-content: space-between;
	gap: calc(8000% / 1100);
	margin-top: 60px;
}
#shop .left {
	width: calc(52000% / 1100);
}
#shop table {
	width: 100%;
}
#shop th,
#shop td {
}
#shop tr:not(:first-child) th,
#shop tr:not(:first-child) td {
	padding-top: 40px;
}
#shop th {
	width: 130px;
	font-size: 18px;
	font-weight: normal;
}
#shop td {
}
#shop td > div {
	position: relative;
	padding: 3px 10px;
	margin-bottom: 5px;
}
#shop td > div:last-child {
	margin-top: 20px;
}
#shop td > div::before {
	content: "";
	position: absolute;
	z-index: 1;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
	background-color: rgba(66, 73, 88, 0.3);
	border-radius: 4px;
	mix-blend-mode: multiply;
}
#shop td .inner {
	position: relative;
	z-index: 2;
}
#shop td span {
	font-size: 20px;
}
#shop .right {
	width: calc(50000% / 1100);
}
#shop iframe {
	width: 100%;
	height: 100%;
}
@media (max-width: 1099px) {
}
@media (max-width: 519px) {
	#shop h2 img {
		width: 146px;
	}
	#shop .content {
		display: block;
	}
	#shop .left {
		width: 100%;
	}
	#shop .right {
		width: 100%;
		margin-top: 30px;
	}
	#shop iframe {
		width: 100%;
		height: 250px;
	}
}


/* ---------- #shimai ---------- */
#shimai {
	padding-top: 80px;
	padding-bottom: 100px;
	background-image: url("../img/shimai_bg.jpg");
	background-position: center;
	background-size: cover;
}
#shimai .wrapper {
	display: flex;
	justify-content: space-between;
	gap: 30px;
}
#shimai h2 {
	padding-right: 40px;
}
#shimai .kuchibashi,
#shimai .tenho {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	width: calc(48000% / 1100);
	padding: 50px 40px;
	margin-top: 40px;
	background-color: rgba(255, 255, 255, 0.6);
	border-radius: 10px;
	box-shadow: 2px 24px 31px 0px rgba(94, 39, 0, 0.16);
	backdrop-filter: blur(3px);
	text-align: center;
}
#shimai .kuchibashi {
}
#shimai .tenho {
}
#shimai .img {
}
#shimai .img img {
}
#shimai .tel {
	margin-bottom: 25px;
}
#shimai .tel a {
	font-size: 28px;
	text-decoration: underline;
}
#shimai .tel a:hover {
	text-decoration: none;
}
#shimai .tbl_ttl {
	margin-top: auto;
	padding: 2px 5px;
	background-color: rgba(185, 93, 38, 0.2);
	border-radius: 3px;
}
#shimai dl {
	display: flex;
	justify-content: space-between;
	margin-top: 10px;
}
#shimai dl > div {
	padding: 0 5px;
}
#shimai dl > div:first-child {
	width: calc(23700% / 400);
}
#shimai dl > div:last-child {
	width: calc(16300% / 400);
	border-left: 1px solid rgba(34, 34, 34, 0.2);
}
#shimai dt {
	padding-bottom: 5px;
	margin-bottom: 5px;
	border-bottom: 1px solid rgba(34, 34, 34, 0.2);
}
#shimai dd {
}
#shimai dd > div {
	display: flex;
	justify-content: space-around;
}
#shimai dd > div > div {
}
#shimai .subttl {
	font-size: 14px;
}
#shimai .time {
}
@media (max-width: 1099px) {
	#shimai .wrapper {
		gap: 20px;
	}
	#shimai h2 {
		padding-right: 10px;
	}
	#shimai .kuchibashi,
	#shimai .tenho {
		padding: 30px 20px;
/*		margin-top: 40px;*/
	}
}
@media (max-width: 819px) {
	#shimai .wrapper {
		flex-wrap: wrap;
		gap: 0;
	}
	#shimai .kuchibashi,
	#shimai .tenho {
		width: calc(100% - 66px);
		margin-left: auto;
	}
	#shimai .tenho .tbl_ttl {
		margin-top: 25px;
	}
}
@media (max-width: 519px) {
	#shimai h2 img {
		width: 42px;
	}
	#shimai .kuchibashi,
	#shimai .tenho {
		padding: 15px 10px;
	}
	#shimai dl {
		display: block;
	}
	#shimai dl > div {
		padding: 0 10px;
	}
	#shimai dl > div:first-child {
		width: 100%;
	}
	#shimai dl > div:last-child {
		width: 100%;
		border-left: none;
		margin-top: 10px;
		padding-top: 10px;
		border-top: 1px solid rgba(34, 34, 34, 0.2);
	}
	#shimai dt {
		border-bottom: 1px dotted rgba(34, 34, 34, 1);
	}
}




/* ---------------------------------------------------------
 * menu.html
** --------------------------------------------------------- */
#menu_fv {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-top: 140px;
	padding-bottom: 90px;
	background-image: url("../img/menu_fv.jpg");
	background-position: center;
	background-size: cover;
}
#menu_fv img {
	margin-right: -20px;
}
#menu {
	padding-bottom: 120px;
	background-image: url("../img/menu_bg.jpg");
	background-size: 100% auto;
	background-position: top center;
	border-bottom: 1px solid #CFB99C;
}
#menu .contents {
	flex-shrink: 0;
	max-width: 410px;
	width: 100%;
	padding: 0 20px;
}
#menu h3 {
	margin-bottom: 30px;
	text-align: center;
}
#menu ul {
}
#menu li {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 13px 11px;
	border-bottom: 1px solid #B0A386;
}
#menu li.bbn {
	border-bottom: none;
}
#menu li .name {
	font-size: 18px;
}
#menu li .name .detail {
	font-size: 14px;
}
#menu li .price {
	font-size: 20px;
}
#menu li .price span {
	font-size: 14px;
}
@media (max-width: 1099px) {
}
@media (max-width: 899px) {
	#menu_fv {
		padding-top: 100px;
		padding-bottom: 50px;
	}
	#menu_fv img {
		margin-right: -20px;
	}
}
@media (max-width: 519px) {
	#menu_fv {
		padding-top: 60px;
		padding-bottom: 30px;
	}
	#menu_fv img {
		width: 90px;
		margin-right: -15px;
	}
}


/* ---------- #tsuke ---------- */
#tsuke {
	display: flex;
	padding-top: 110px;
	background-image: url("../img/menu_tsuke_bg.png");
	background-repeat: no-repeat;
	background-position: right top;
}
#tsuke .img {
/*	align-self: flex-end;*/
	width: calc(79800% / 1440);
	padding-top: 50px;
}
#tsuke .img img {
	width: 100%;
}
#tsuke .contents {
	margin-left: calc(10000% / 1440);
}
#tsuke h3 {
}
#tsuke ul {
}
@media (max-width: 1099px) {
	#tsuke .contents {
		margin-left: calc(5000% / 1440);
	}
}
@media (max-width: 899px) {
	#tsuke {
		flex-direction: column-reverse;
		align-items: center;
	}
	#tsuke .img {
		width: 100%;
/*		padding-top: 50px;*/
	}
	#tsuke .contents {
		margin-left: 0;
	}
}
@media (max-width: 519px) {
	#tsuke {
		padding-top: 70px;
	}
	#tsuke h3 img {
		width: 127px;
	}
}


/* ---------- #nikomi ---------- */
#nikomi {
	display: flex;
	flex-direction: row-reverse;
	padding-top: 120px;
	background-image: url("../img/menu_nikomi_bg.png");
	background-repeat: no-repeat;
	background-position: left top;
}
#nikomi .img {
/*	align-self: flex-end;*/
	width: calc(79800% / 1440);
	padding-top: 50px;
}
#nikomi .img img {
	width: 100%;
}
#nikomi .contents {
	margin-right: calc(10000% / 1440);
}
#nikomi h3 {
}
#nikomi .subttl {
	padding: 8px;
	border-radius: 5px;
	font-size: 20px;
	text-align: center;
}
#nikomi .shoyu {
	background-color: rgba(185, 93, 38, 0.12);
}
#nikomi .shio {
	background-color: rgba(24, 41, 98, 0.12);
}
#nikomi ul {
}
@media (max-width: 1099px) {
	#nikomi .contents {
		margin-right: calc(5000% / 1440);
	}
}
@media (max-width: 899px) {
	#nikomi {
		flex-direction: column-reverse;
		align-items: center;
	}
	#nikomi .img {
		width: 100%;
/*		padding-top: 50px;*/
	}
	#nikomi .contents {
		margin-right: 0;
	}
}
@media (max-width: 519px) {
	#nikomi {
		padding-top: 80px;
	}
	#nikomi h3 img {
		width: 177px;
	}
}


/* ---------- #side ---------- */
#side {
	display: flex;
	justify-content: space-between;
	margin-top: 120px;
}
#side .left,
#side .right {
	width: calc(43600% / 1440);
	padding-top: 50px;
}
#side .left img,
#side .right img {
	width: 100%;
}
#side .contents {
}
#side h3 {
	margin-bottom: -30px;
}
#side ul {
}
@media (max-width: 1099px) {
}
@media (max-width: 719px) {
	#side {
		justify-content: center;
	}
	#side .left,
	#side .right {
		display: none;
	}
}
@media (max-width: 519px) {
	#side {
		margin-top: 70px;
	}
	#side h3 img {
		width: 185px;
	}
}