/* 今池店 来店予約ページ */
:root {
	--imaike-brown: #24180e;
	--imaike-brown-2: #4b3725;
	--imaike-gold: #c28a2a;
	--imaike-gold-dark: #9a681c;
	--imaike-cream: #f9f4e8;
	--imaike-cream-2: #fffaf0;
	--imaike-line: #e6d7be;
	--imaike-green: #8cc63f;
	--imaike-text: #362719;
	--imaike-muted: #76634b;
	--imaike-shadow: 0 12px 34px rgba(36, 24, 14, .12);
}
body.is-imaike-reserve-page .st-footer__fix {
	display: none;
}
.imaikeReserve {
	color: var(--imaike-text);
	background: #fff;
	padding-bottom: 0;
}
.imaikeReserve a {
	transition: opacity .2s ease, transform .2s ease, box-shadow .2s ease;
}
.imaikeReserve a:hover {
	opacity: .86;
}
.imaikeReserveMv {
	position: relative;
	overflow: hidden;
	min-height: 560px;
	background: var(--imaike-cream-2);
}
.imaikeReserveMv__bg,
.imaikeReserveMv__bg img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	display: block;
}
.imaikeReserveMv__bg img {
	object-fit: cover;
	object-position: center center;
}
.imaikeReserveMv__inner {
	position: relative;
	z-index: 1;
	min-height: 560px;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
.imaikeReserveMv__txtbox {
	width: min(48%, 520px);
	padding: 54px 0 50px;
}
.imaikeReserve__label {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 32px;
	padding: 5px 18px;
	border: 1px solid var(--imaike-gold);
	border-radius: 999px;
	background: rgba(255,255,255,.86);
	color: var(--imaike-gold-dark);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: .08em;
	margin: 0 0 16px;
}
.imaikeReserveMv__ttl {
	font-size: clamp(34px, 4.1vw, 56px);
	line-height: 1.36;
	letter-spacing: .09em;
	font-weight: 600;
	color: var(--imaike-brown);
	margin: 0 0 18px;
}
.imaikeReserveMv__lead {
	font-size: 17px;
	line-height: 1.9;
	margin: 0;
}
.imaikeReserveMv__btns,
.imaikeReserveIntro__btns,
.imaikeReserveShop__btns,
.imaikeReserveBottomCta__btns {
	display: flex;
	flex-wrap: wrap;
	gap: 14px;
	margin-top: 28px;
}
.imaikeReserveMv__note {
	font-size: 13px;
	line-height: 1.7;
	color: var(--imaike-muted);
	margin: 18px 0 0;
}
.imaikeReserveBtn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 54px;
	padding: 13px 28px;
	border-radius: 999px;
	font-weight: 700;
	line-height: 1.4;
	text-align: center;
	letter-spacing: .04em;
}
.imaikeReserveBtn--primary {
	background: var(--imaike-gold);
	color: #fff;
	box-shadow: 0 4px 0 var(--imaike-gold-dark);
}
.imaikeReserveBtn--line {
	background: var(--imaike-green);
	color: #fff;
	box-shadow: 0 4px 0 #69a92d;
}
.imaikeReserveBtn--outline {
	background: #fff;
	color: var(--imaike-gold-dark);
	border: 1px solid var(--imaike-gold);
}
.imaikeReserveSec {
	padding: 76px 0;
}
.imaikeReserveSec--cream {
	background: var(--imaike-cream);
}
.imaikeReserveHeading {
	text-align: center;
	margin-bottom: 36px;
}
.imaikeReserveHeading--left {
	text-align: left;
	margin-bottom: 22px;
}
.imaikeReserveHeading__ja {
	font-size: clamp(26px, 3vw, 36px);
	line-height: 1.48;
	font-weight: 600;
	letter-spacing: .05em;
	color: var(--imaike-brown);
	margin: 0;
}
.imaikeReserveHeading__en {
	font-size: 14px;
	color: var(--imaike-gold);
	margin: 6px 0 0;
}
.imaikeReserveIntro {
	display: grid;
	grid-template-columns: 1fr 270px;
	gap: 28px;
	align-items: stretch;
}
.imaikeReserveIntro__main,
.imaikeReserveIntro__qr {
	background: #fff;
	border: 1px solid var(--imaike-line);
	box-shadow: var(--imaike-shadow);
}
.imaikeReserveIntro__main {
	padding: 42px 48px;
}
.imaikeReserveIntro__catch {
	font-size: 22px;
	line-height: 1.65;
	font-weight: 700;
	color: var(--imaike-brown);
	margin: 0 0 12px;
}
.imaikeReserveIntro__main p:not(.imaikeReserveIntro__catch) {
	margin: 0;
	line-height: 1.95;
}
.imaikeReserveIntro__qr {
	padding: 24px;
	text-align: center;
	background: #fffdf8;
}
.imaikeReserveIntro__qrTtl {
	font-weight: 700;
	color: var(--imaike-brown);
	margin: 0 0 12px;
}
.imaikeReserveIntro__qrImg {
	display: block;
	max-width: 178px;
	margin: 0 auto 12px;
	padding: 10px;
	background: #fff;
	border: 1px solid var(--imaike-line);
}
.imaikeReserveIntro__qrTxt {
	font-size: 13px;
	line-height: 1.7;
	color: var(--imaike-muted);
	margin: 0;
}
.imaikeReserveFeatureGrid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
}
.imaikeReserveFeature {
	background: #fff;
	border: 1px solid var(--imaike-line);
	box-shadow: 0 8px 22px rgba(36,24,14,.07);
}
.imaikeReserveFeature__img {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.imaikeReserveFeature__img img,
.imaikeReserveBring__img img,
.imaikeReserveShop__img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.imaikeReserveFeature__body {
	padding: 24px 22px 26px;
}
.imaikeReserveFeature__body h3 {
	font-size: 21px;
	line-height: 1.5;
	font-weight: 600;
	color: var(--imaike-brown);
	margin: 0 0 8px;
}
.imaikeReserveFeature__body p {
	font-size: 15px;
	line-height: 1.8;
	color: var(--imaike-muted);
	margin: 0;
}
.imaikeReserveFlow {
	counter-reset: step;
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 22px;
	list-style: none;
	padding: 0;
	margin: 0;
}
.imaikeReserveFlow__item {
	position: relative;
	background: #fff;
	border: 1px solid var(--imaike-line);
	padding: 28px 24px 30px;
	box-shadow: 0 8px 22px rgba(36,24,14,.06);
}
.imaikeReserveFlow__num {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 62px;
	height: 62px;
	background: var(--imaike-brown);
	color: #fff;
	font-size: 25px;
	line-height: 1;
	margin-bottom: 18px;
}
.imaikeReserveFlow__item h3 {
	font-size: 21px;
	font-weight: 600;
	color: var(--imaike-brown);
	margin: 0 0 8px;
}
.imaikeReserveFlow__item p {
	font-size: 15px;
	line-height: 1.85;
	color: var(--imaike-muted);
	margin: 0;
}
.imaikeReserveBring {
	display: grid;
	grid-template-columns: 46% 1fr;
	gap: 40px;
	align-items: center;
}
.imaikeReserveBring__img {
	aspect-ratio: 3 / 2;
	overflow: hidden;
	border: 1px solid var(--imaike-line);
	box-shadow: var(--imaike-shadow);
}
.imaikeReserveCheckList {
	list-style: none;
	padding: 0;
	margin: 0;
}
.imaikeReserveCheckList li {
	position: relative;
	padding-left: 26px;
	margin: 12px 0;
	line-height: 1.8;
}
.imaikeReserveCheckList li:before {
	content: "";
	position: absolute;
	left: 0;
	top: .72em;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--imaike-gold);
}
.imaikeReserveBring__note {
	font-size: 14px;
	color: var(--imaike-muted);
	margin: 18px 0 0;
}
.imaikeReserveShop {
	display: grid;
	grid-template-columns: 46% 1fr;
	gap: 34px;
	align-items: stretch;
	background: #fff;
	border: 1px solid var(--imaike-line);
	box-shadow: var(--imaike-shadow);
	padding: 30px;
}
.imaikeReserveShop__img {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
.imaikeReserveShop__info h3 {
	font-size: 27px;
	line-height: 1.45;
	font-weight: 600;
	color: var(--imaike-brown);
	margin: 0 0 16px;
}
.imaikeReserveDl {
	margin: 0;
}
.imaikeReserveDl .row {
	display: grid;
	grid-template-columns: 88px 1fr;
	gap: 12px;
	padding: 13px 0;
	border-bottom: 1px solid #eadbc1;
}
.imaikeReserveDl .row:first-child {
	padding-top: 0;
}
.imaikeReserveDl dt {
	font-weight: 700;
	color: var(--imaike-gold-dark);
}
.imaikeReserveDl dd {
	margin: 0;
}
.imaikeReserveMap {
	margin-top: 28px;
	border: 1px solid var(--imaike-line);
	line-height: 0;
}
.imaikeReserveMap iframe {
	width: 100%;
	height: 420px;
}
.imaikeReserveFaq {
	max-width: 900px;
	margin: 0 auto;
}
.imaikeReserveFaq__item {
	background: #fff;
	border: 1px solid var(--imaike-line);
	padding: 22px 26px;
	margin: 0 0 14px;
}
.imaikeReserveFaq__item dt {
	position: relative;
	font-weight: 700;
	line-height: 1.7;
	color: var(--imaike-brown);
	padding-left: 34px;
	margin-bottom: 8px;
}
.imaikeReserveFaq__item dt:before {
	content: "Q";
	position: absolute;
	left: 0;
	top: -2px;
	font-family: Georgia, serif;
	font-size: 24px;
	color: var(--imaike-gold);
}
.imaikeReserveFaq__item dd {
	position: relative;
	line-height: 1.85;
	color: var(--imaike-muted);
	padding-left: 34px;
	margin: 0;
}
.imaikeReserveFaq__item dd:before {
	content: "A";
	position: absolute;
	left: 0;
	top: -2px;
	font-family: Georgia, serif;
	font-size: 24px;
	color: var(--imaike-green);
}
.imaikeReserveBottomCta {
	background: linear-gradient(135deg, #fffdf8 0%, #f4e4c6 100%);
	border-top: 1px solid var(--imaike-line);
	text-align: center;
	padding: 58px 0 62px;
}
.imaikeReserveBottomCta h2 {
	font-size: clamp(28px, 3.2vw, 38px);
	line-height: 1.45;
	font-weight: 600;
	letter-spacing: .06em;
	color: var(--imaike-brown);
	margin: 0 0 10px;
}
.imaikeReserveBottomCta p {
	line-height: 1.8;
	margin: 0;
	color: var(--imaike-muted);
}
.imaikeReserveBottomCta__btns {
	justify-content: center;
}
.imaikeReserveSideBtn {
	position: fixed;
	right: 0;
	top: 48%;
	z-index: 25;
	writing-mode: vertical-rl;
	background: var(--imaike-gold);
	color: #fff;
	font-weight: 700;
	letter-spacing: .08em;
	line-height: 1.45;
	padding: 16px 10px;
	border-radius: 8px 0 0 8px;
	box-shadow: 0 8px 20px rgba(36,24,14,.18);
}
.imaikeReserveFixed {
	display: none;
}
@media (max-width: 960px) {
	.imaikeReserveMv,
	.imaikeReserveMv__inner {
		min-height: auto;
	}
	.imaikeReserveMv {
		padding-bottom: 32px;
	}
	.imaikeReserveMv__bg,
	.imaikeReserveMv__bg img {
		position: relative;
		height: auto;
	}
	.imaikeReserveMv__bg img {
		aspect-ratio: 4 / 3;
		object-position: center center;
	}
	.imaikeReserveMv__inner {
		display: block;
	}
	.imaikeReserveMv__txtbox {
		width: 100%;
		background: #fff;
		border: 1px solid var(--imaike-line);
		box-shadow: var(--imaike-shadow);
		padding: 28px 24px;
		margin-top: -38px;
	}
	.imaikeReserveMv__ttl {
		font-size: 32px;
	}
	.imaikeReserveMv__lead {
		font-size: 15px;
	}
	.imaikeReserveIntro,
	.imaikeReserveFeatureGrid,
	.imaikeReserveFlow,
	.imaikeReserveBring,
	.imaikeReserveShop {
		grid-template-columns: 1fr;
	}
	.imaikeReserveIntro__qr {
		display: none;
	}
	.imaikeReserveSideBtn {
		display: none !important;
	}
	.imaikeReserveFixed {
		display: flex;
		position: fixed;
		left: 0;
		right: 0;
		bottom: 0;
		z-index: 60;
		gap: 8px;
		padding: 8px 10px calc(8px + env(safe-area-inset-bottom));
		background: #fff;
		border-top: 1px solid var(--imaike-line);
		box-shadow: 0 -8px 24px rgba(36,24,14,.14);
	}
	.imaikeReserveFixed a {
		display: flex;
		align-items: center;
		justify-content: center;
		min-height: 52px;
		border-radius: 999px;
		font-size: 14px;
		font-weight: 700;
		line-height: 1.25;
		text-align: center;
	}
	.imaikeReserveFixed__tel {
		flex: .9;
		background: #fff;
		border: 1px solid var(--imaike-gold);
		color: var(--imaike-gold-dark);
	}
	.imaikeReserveFixed__reserve {
		flex: 1.35;
		background: var(--imaike-gold);
		color: #fff;
	}
	body.is-imaike-reserve-page {
		padding-bottom: 70px;
	}
}
@media (max-width: 750px) {
	.imaikeReserveSec {
		padding: 54px 0;
	}
	.imaikeReserveHeading {
		margin-bottom: 26px;
	}
	.imaikeReserveHeading__ja {
		font-size: 26px;
		text-align: left;
	}
	.imaikeReserveHeading__en {
		text-align: left;
	}
	.imaikeReserveIntro__main,
	.imaikeReserveShop,
	.imaikeReserveFaq__item {
		padding: 24px 20px;
	}
	.imaikeReserveIntro__catch {
		font-size: 19px;
	}
	.imaikeReserveBtn {
		width: 100%;
		min-height: 52px;
		padding-left: 20px;
		padding-right: 20px;
	}
	.imaikeReserveMv__btns,
	.imaikeReserveIntro__btns,
	.imaikeReserveShop__btns,
	.imaikeReserveBottomCta__btns {
		gap: 10px;
	}
	.imaikeReserveDl .row {
		grid-template-columns: 1fr;
		gap: 2px;
	}
	.imaikeReserveMap iframe {
		height: 320px;
	}
}

/* ----------------------------------------------------------
 * PC表示調整 2026-05
 * 店舗情報カードの画像はみ出し防止 / 追従予約ボタン拡大
 * ---------------------------------------------------------- */
@media (min-width: 961px) {
	.imaikeReserveShop {
		grid-template-columns: minmax(0, 46%) minmax(0, 1fr);
		gap: 34px;
		align-items: center;
		overflow: hidden;
	}
	.imaikeReserveShop__img,
	.imaikeReserveShop__info {
		min-width: 0;
		max-width: 100%;
	}
	.imaikeReserveShop__img {
		width: 100%;
		aspect-ratio: 4 / 3;
		overflow: hidden;
	}
	.imaikeReserveShop__img img {
		display: block;
		width: 100%;
		height: 100%;
		max-width: none;
		object-fit: cover;
	}
	.imaikeReserveShop__info {
		position: relative;
		z-index: 1;
		background: #fff;
		padding-left: 4px;
	}
	.imaikeReserveDl .row {
		grid-template-columns: 92px minmax(0, 1fr);
	}
	.imaikeReserveDl dd {
		word-break: keep-all;
		overflow-wrap: anywhere;
	}
	.imaikeReserveShop__btns {
		gap: 12px;
		margin-top: 24px;
	}
	.imaikeReserveShop__btns .imaikeReserveBtn {
		min-width: 152px;
	}
	.imaikeReserveSideBtn {
		top: 50%;
		transform: translateY(-50%);
		display: flex !important;
		align-items: center;
		justify-content: center;
		width: 58px;
		min-height: 136px;
		padding: 20px 12px;
		border-radius: 12px 0 0 12px;
		font-size: 15px;
		line-height: 1.45;
		letter-spacing: .1em;
		box-shadow: 0 10px 26px rgba(36,24,14,.22);
	}
}

@media (min-width: 961px) and (max-width: 1200px) {
	.imaikeReserveShop {
		grid-template-columns: minmax(0, 42%) minmax(0, 1fr);
		gap: 28px;
		padding: 28px;
	}
	.imaikeReserveShop__info h3 {
		font-size: 24px;
	}
	.imaikeReserveDl .row {
		grid-template-columns: 80px minmax(0, 1fr);
		gap: 10px;
		padding: 11px 0;
	}
	.imaikeReserveShop__btns .imaikeReserveBtn {
		min-width: 140px;
		padding-left: 22px;
		padding-right: 22px;
	}
}
