@charset "UTF-8";

/* ---------------------------------------------------
	header
---------------------------------------------------- */
.site-header {
	position: sticky;
	top: 0;
	z-index: 1000;
	background: #123330;
	font-size: min(2.4rem, 1.757vw);
	font-family: "Open Sans";
	color: #E4C48F;
}

.site-header__inner {
	display: flex;
	justify-content: center;
	align-items: center;
	height: 77.742px;
	margin: 0 auto;
	padding: 0 16px;
}

/* ── SPデフォルト：site-nav はドロワー（右出し） ── */
.site-nav {
	position: fixed;
	top: 0;
	right: 0;
	height: 100%;
	width: min(80vw, 320px);
	background: #123330;
	transform: translateX(100%);  /* ← 右端の外（画面外）に隠す */
	transition: transform 0.3s ease;
	z-index: 1001;
	padding-top: calc(var(--header-h) + 8px);
}

.site-nav.is-open{
	transform: translateX(0);
	background: #123330;
}

.site-nav__list {
	list-style: none;
	margin: 0;
	padding: 16px;
	padding-top: 40px;
	display: grid;
	gap: 8px;
}

.site-nav__list a {
	display: block;
	padding: 14px 12px;
	color: var(--fg);
	text-decoration: none;
	border-radius: 8px;
}

/* ハンバーガー（SP表示） */
.hamburger {
	display: inline-flex;
	flex-direction: column;
	align-items: center;
	gap: 4px;
	border: none;
	background: transparent;
	cursor: pointer;
	padding: 6px 8px;
	z-index: 9999;
}

.hamburger__bars {
	width: 28px;
	height: 20px;
	position: relative;
}

.hamburger__bars span {
	background: #E6C196;
	position: absolute;
	left: 0;
	right: 0;
	height: 2px;
	border-radius: 2px; 
	transition: transform .25s var(--ease), opacity .2s var(--ease), top .25s var(--ease);
}

.hamburger__bars span:nth-child(1){ top: 0; }
.hamburger__bars span:nth-child(2){ top: 9px; }
.hamburger__bars span:nth-child(3){ top: 18px; }
.hamburger__label {
	font-size: min(1.2rem, 3.191vw);
	line-height: 1;
	color: #E6C196;
	letter-spacing: .06em;
	transition: opacity 0.2s ease, visibility 0.2s ease;
}

/* 開いたとき「×」に変形 */
.hamburger[aria-expanded="true"] .hamburger__bars span:nth-child(1){ top: 9px; transform: rotate(45deg); }
.hamburger[aria-expanded="true"] .hamburger__bars span:nth-child(2){ opacity: 0; }
.hamburger[aria-expanded="true"] .hamburger__bars span:nth-child(3){ top: 9px; transform: rotate(-45deg); }
.hamburger[aria-expanded="true"] .hamburger__label {
	opacity: 0;
	visibility: hidden;
}

/* オーバーレイ */
.overlay{
	position: fixed;
	inset: 0;
	background: rgba(0, 0, 0, 0.8);
	z-index: 1000;
}

@media (min-width: 768px){
	.site-nav{
		position: static;
		transform: none;
		width: auto;
		padding-top: 0;
	}
	.site-nav__list{
		display: flex; gap: 20px; padding: 0;
	}
	.hamburger{ display: none; }
	.overlay{ display: none !important; }
}

@media (prefers-reduced-motion: reduce){
	.site-nav {
		transition: none;
	}
	.hamburger__bars span {
		transition: none;
	}
}

@media screen and (max-width: 768px) {
	.site-header {
		position: sticky;
		top: 0;
		z-index: 1000;
		background: #123330;
		font-size: min(2rem, 5.319vw);
		font-family: "Open Sans";
		color: #E4C48F;
	}
	.site-header {
		width: 64px;
		position: fixed;
		right: 0;
	}
	.site-header__inner {
		height: 64px;
	}
	.site-nav__list li {
		border-bottom: 2px solid #E4C48F;
	}
	.site-nav__list li:last-child {
		border-bottom: none;
	}
}

/* ---------------------------------------------------
	footer
---------------------------------------------------- */
.footer {
	color: #606060;
	padding: 3em 50px 0;
}

.footer .list {
	margin: 0 auto 2rem;
	max-width: 750px;
	letter-spacing: -0.005em;
}

@media screen and (max-width: 768px) {
	.footer {
		padding: 2em 3.2vw 0;
	}

	.footer .list {
		margin-bottom: 0;
	}
}

/*
	footer__logo
------------------------------ */
.footer__logo {
	margin: 4em auto;
	max-width: 825px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.footer__logo li.sakura {
	width: 20.60606%;
}

.footer__logo li.takanawa {
	width: 21.69697%;
}

.footer__logo li.hanakohro {
	width: 13.57576%;
}

.footer__logo li.shintakanawa {
	width: 22.06061%;
}

@media screen and (max-width: 768px) {
	.footer__logo {
		margin-bottom: 2.5em;
		flex-wrap: wrap;
		justify-content: center;
	}

	.footer__logo li {
		margin-top: 2em;
		width: 50% !important;
		text-align: center;
	}

	.footer__logo li.sakura img {
		width: 39.56723vw;
	}

	.footer__logo li.takanawa img {
		width: 41.72987vw;
	}

	.footer__logo li.hanakohro img {
		width: 26.16739vw;
	}

	.footer__logo li.shintakanawa img {
		width: 42.41227vw;
	}
}

/*
	hotelNav
------------------------------ */
.footer__hotelNav {
	line-height: 1;
	color: rgb(var(--blk));
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.footer__hotelNav li {
	margin: 0 0 1rem;
	text-indent: 0;
	display: flex;
	position: relative;
}

.footer__hotelNav li:first-of-type::before,
.footer__hotelNav li::after {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
}

.footer__hotelNav li:first-of-type::before {
	left: 0;
	content: "|";
}

.footer__hotelNav li::after {
	right: 0;
	content: "|";
}

.footer__hotelNav li a {
	padding: 0 1em;
	color: rgb(var(--blk));
	text-decoration: none;
	display: inline-block;
}

.footer__hotelNav li a:hover {
	text-decoration: underline;
	opacity: 1;
}

@media screen and (max-width: 768px) {
	.footer__hotelNav {
		text-align: center;
	}

	.footer__hotelNav li:first-of-type::before,
	.footer__hotelNav li::after {
		content: "";
	}

	.footer__hotelNav li {
		margin-bottom: 1rem;
		justify-content: center;
	}

	.footer__hotelNav li a {
		font-size: 3.2vw;
		letter-spacing: -0.005em;
		display: inline-block;
		position: relative;
	}

	.footer__hotelNav li a::before,
	.footer__hotelNav li a::after {
		position: absolute;
		top: 50%;
		transform: translateY(-50%);
		content: "|";
	}

	.footer__hotelNav li:first-of-type a::after,
	.footer__hotelNav li:last-of-type a::before {
		content: "";
	}

	.footer__hotelNav li a::before {
		left: 0;
	}

	.footer__hotelNav li a::after {
		right: 0;
	}
}

/*
	copy
------------------------------ */
.copy {
	padding: 2rem 0 3rem;
	color: rgba(var(--blk), 0.5);
	font-size: 12px;
	text-align: center;
}

@media screen and (max-width: 768px) {
	.copy {
		font-size: 2.93333vw;
	}
}

/* ----------------------------------------------------
	nav
---------------------------------------------------- */
.toggle {
	display: none;
}

@media screen and (max-width: 768px) {
	.toggle {
		background: rgba(38, 49, 81, 0.8);
		width: 64px;
		height: 64px;
		display: block;
		position: fixed;
		top: 0;
		right: 0;
		z-index: 1000;
	}

	.toggle__inner {
		width: 100%;
		height: 100%;
		position: relative;
		cursor: pointer;
	}

	.toggle__inner--item {
		background: rgb(var(--wht));
		width: 60%;
		height: 2px;
		display: block;
		position: absolute;
		left: 50%;
		transition: all 0.6s;
	}

	.toggle__inner--item:nth-child(1) {
		top: 20px;
		transform: translateX(-50%);
	}

	.toggle__inner--item:nth-child(2) {
		opacity: 1;
		top: 50%;
		transform: translate(-50%, -50%);
	}

	.toggle__inner--item:nth-child(3) {
		bottom: 20px;
		transform: translateX(-50%);
	}

	/* is-open */
	.is-open .toggle {
		background: none;
	}

	.is-open .toggle__inner--item {
		background: rgb(var(--wht));
		transform-origin: 0 0;
	}

	.is-open .toggle__inner--item:nth-child(1) {
		top: 50%;
		transform: rotate(45deg) translate(-50%, -50%);
	}

	.is-open .toggle__inner--item:nth-child(2) {
		width: 0;
	}

	.is-open .toggle__inner--item:nth-child(3) {
		top: 50%;
		bottom: auto;
		transform: rotate(-45deg) translate(-50%, -50%);
	}
}

/*
	js-restaurant-slide
------------------------------ */
/* スライダー基本 */
.js-restaurant-slider {
	position: relative; /* ドットを中に重ねるため */
	overflow: hidden;   /* はみ出し対策 */
}
.js-restaurant-slider .slick-slide img{
	display: block;
	width: 100%;
	height: auto;
	object-fit: cover;
}

/* ドット（右下に配置） */
.js-restaurant-slider .slick-dots{
	width: auto;
	position: absolute;
	right: 0;
	bottom: -2px;
	margin: 0;
	padding: 0;
	list-style: none;
	border-radius: 999px;
	/* backdrop-filter: blur(2px); */
}
.js-restaurant-slider .slick-dots li{
	width: 18px;
	height: 18px;
	margin: 0;
}
.js-restaurant-slider .slick-dots button{
	padding: 0;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #D9D9D9;
	border: none;
	text-indent: -9999px;
	overflow: hidden;
	cursor: pointer;
	opacity: 1;
}
.js-restaurant-slider .slick-dots .slick-active button{
	opacity: 1;
	background: #E6C196;
}

/* 矢印を使う場合（今回は非表示だが一応スタイル例） */
.js-restaurant-slider .slick-prev,
.js-restaurant-slider .slick-next{
	z-index: 2;
}

.slick-dotted.slick-slider {
    margin-bottom: 0;
}

.cake .js-restaurant-slider .slick-dots{
	right: 43%;
	bottom: 0;
}

@media screen and (max-width: 768px) {
	.js-restaurant-slider .slick-dots li {
		width: 14px;
		height: 16px;
	}
	.js-restaurant-slider .slick-dots button {
		width: 8px;
		height: 8px;
	}
	.cake .js-restaurant-slider .slick-dots{
		right: 36%;
	}
}