:root {
	--kr-bg: #1A110A;
	--kr-text: #f5f5f5;
	--kr-gold: #C5A059;
	--kr-muted: rgba(255, 255, 255, 0.72);
	--kr-line: rgba(255, 255, 255, 0.24);
}

*,
*::before,
*::after {
	box-sizing: border-box;
}

html,
body {
	margin: 0;
	padding: 0;
}

body {
	background: var(--kr-bg);
	color: var(--kr-text);
	font-family: "Helvetica Neue", "Yu Gothic", "Hiragino Kaku Gothic ProN", sans-serif;
}

a {
	color: inherit;
	text-decoration: none;
}

.kr-header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 50;
	width: 100%;
	padding: 18px clamp(18px, 3vw, 44px);
	background: linear-gradient(to bottom, rgba(0, 0, 0, 0.54), rgba(0, 0, 0, 0.08) 72%, transparent);
}

.kr-header__inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 24px;
}

.kr-header__brand {
	display: inline-flex;
	align-items: center;
	flex-shrink: 0;
}

.kr-header__logo {
	display: block;
	width: clamp(44px, 5.5vw, 86px);
	height: auto;
	filter: drop-shadow(0 8px 18px rgba(0, 0, 0, 0.42));
	opacity: 0.96;
}

.kr-header__nav {
	margin-left: auto;
}

.kr-header__menu {
	display: flex;
	margin: 0;
	padding: 0;
	list-style: none;
	gap: clamp(10px, 1.35vw, 22px);
	font-size: clamp(10px, 0.84vw, 12px);
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.kr-header__menu a {
	position: relative;
	display: inline-flex;
	align-items: center;
	padding: 6px 0;
	color: rgba(255, 255, 255, 0.86);
	transition: color 220ms ease;
}

.kr-header__menu a::after {
	content: "";
	position: absolute;
	left: 0;
	bottom: 0;
	width: 100%;
	height: 1px;
	background: rgba(255, 255, 255, 0.72);
	transform: scaleX(0);
	transform-origin: left;
	transition: transform 220ms ease;
}

.kr-header__menu a:hover {
	color: var(--kr-gold);
}

.kr-header__menu a:hover::after {
	transform: scaleX(1);
	background: var(--kr-gold);
}

.kr-main {
	min-height: 100vh;
}

.kr-fv {
	position: relative;
	display: grid;
	--divider-size: clamp(96px, 10vw, 180px);
	grid-template-columns: 0.75fr var(--divider-size) 1.73fr;
	--divider-left: 44%;
	--divider-right: 44%;
	min-height: min(100vh, 900px);
	background: #ddd;
	overflow: hidden;
}

.kr-fv__split {
	position: relative;
}

.kr-fv__split--left {
	background-image: url("/keins/wp-content/uploads/2023/11/image-1.png");
	background-size: auto 100%;
	background-position: left center;
	background-repeat: no-repeat;
	background-color: #2C1F17;
}

.kr-fv__split--right {
	filter: saturate(0.88);
	overflow: hidden;
}

.kr-fv__bg {
	position: absolute;
	inset: 0;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: 78% center;
	will-change: transform, opacity;
}

.kr-fv__bg--1 {
	background-image: url("/keins/wp-content/uploads/2023/11/message_bg_pc.png");
	z-index: 1;
}

.kr-fv__bg--2 {
	background-image: url("/keins/wp-content/uploads/2023/11/PIC-662.png");
	z-index: 2;
	opacity: 0;
}

.kr-fv__overlay {
	display: none;
}

.kr-fv__divider {
	position: relative;
	background: var(--kr-bg);
	border-left: 1px solid var(--kr-gold);
	border-right: 1px solid var(--kr-gold);
}

.kr-fv__content {
	position: relative;
	z-index: 1;
	height: 100%;
	display: flex;
	flex-direction: column;
	justify-content: center;
	padding: 120px clamp(20px, 3vw, 40px) 40px;
}

.kr-fv__eyebrow {
	margin: 0 0 18px;
	font-size: 12px;
	letter-spacing: 0.24em;
	color: var(--kr-muted);
}

.kr-fv__catch {
	margin: 0 0 32px;
	font-size: clamp(19px, 1.4vw, 24px);
	line-height: 1.7;
	color: rgba(255, 255, 255, 0.86);
	white-space: nowrap;
	text-shadow: 0 10px 24px rgba(0, 0, 0, 0.42);
}

.kr-fv__textGroup {
	position: absolute;
	left: 50%;
	top: 48%;
	transform: translate(-50%, -50%);
	z-index: 4;
	width: min(92vw, 1260px);
	pointer-events: none;
	text-align: left;
}

.kr-fv__titleWrap {
	margin: 0 0 16px;
	font-family: "Times New Roman", serif;
	font-size: clamp(62px, 11vw, 150px);
	font-weight: 500;
	line-height: 0.92;
	letter-spacing: 0.015em;
	user-select: none;
}

.kr-fv__titleLayer {
	position: relative;
	display: block;
	will-change: transform, opacity;
}

.kr-fv__titleLayer--light {
	color: rgba(246, 246, 246, 0.96);
	text-shadow: 0 10px 34px rgba(0, 0, 0, 0.24);
}

.kr-fv__titleLayer--dark {
	display: none;
}

.kr-charWrap {
	display: inline-block;
	overflow: hidden;
	vertical-align: top;
	line-height: 1; /* Ensure overflow doesn't clip descenders if possible, or tweak */
	padding-bottom: 0.1em; /* give some room for descenders just in case */
	margin-bottom: -0.1em;
}

.kr-charInner {
	display: inline-block;
	will-change: transform, opacity;
}

.kr-fv__titleLayer.is-out {
	opacity: 0;
	transform: translateY(-12px) scale(1.02);
}

.kr-fv__links {
	margin: auto 0 0;
	padding: 0;
	list-style: none;
	display: grid;
	gap: 10px;
	font-size: 11px;
	letter-spacing: 0.16em;
}

.kr-fv__links a {
	color: rgba(255, 255, 255, 0.65);
	transition: color 200ms ease;
}

.kr-fv__links a:hover {
	color: var(--kr-gold);
}

.kr-fv__noise {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 70% 35%, rgba(255, 93, 63, 0.38) 0, transparent 13%),
		radial-gradient(circle at 64% 56%, rgba(255, 98, 98, 0.28) 0, transparent 12%);
	mix-blend-mode: screen;
}

.kr-fv__webgl {
	position: absolute;
	inset: 0;
	z-index: 1;
	pointer-events: none;
	opacity: 0.6;
}

.kr-footer {
	position: relative;
	z-index: 55;
	background: var(--kr-bg);
	color: #fff;
	padding: 40px 24px;
}

.kr-footer__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 24px;
	max-width: 1000px;
	margin: 0 auto;
}

.kr-footer__links {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: 20px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.kr-footer__links li {
	display: flex;
	align-items: center;
}

.kr-footer__links li:not(:last-child)::after {
	content: "";
	display: block;
	width: 1px;
	height: 14px;
	background-color: #fff;
	margin-left: 20px;
}

.kr-footer__links a {
	font-size: 11px;
	letter-spacing: 0.05em;
	transition: color 0.2s ease;
}

.kr-footer__links a:hover {
	color: var(--kr-gold);
}

.kr-footer__copy {
	margin: 0;
	font-size: 10px;
	letter-spacing: 0.05em;
	color: #fff;
}

.kr-footer__pagetop {
	position: absolute;
	right: clamp(16px, 4vw, 40px);
	top: 50%;
	transform: translateY(-50%);
	width: 48px;
	height: 48px;
	border-radius: 50%;
	background: #d9d9d9;
	color: #333;
	border: none;
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	transition: background-color 0.2s ease;
}

.kr-footer__pagetop:hover {
	background: #fff;
}

.kr-fallback {
	padding: 160px 24px 120px;
}

/* News Carousel */
.kr-fv__newsWrap {
	position: absolute;
	left: 0;
	bottom: clamp(12px, 3vw, 40px);
	z-index: 10;
	width: 100%;
	overflow: hidden;
	padding: 10px 0;
	pointer-events: none; /* So the wrapper itself doesn't block clicks */
}

.kr-fv__newsCarousel {
	display: flex;
	width: max-content;
	animation: scrollNews 45s linear infinite;
	pointer-events: auto; /* Re-enable for the items */
}

.kr-fv__newsCarousel:hover {
	animation-play-state: paused;
}

.kr-fv__newsItem {
	display: flex;
	align-items: center;
	gap: 16px;
	background: rgba(248, 248, 248, 0.98);
	color: #111;
	padding: 8px 16px 8px 8px;
	border-radius: 2px;
	margin-right: 16px;
	width: clamp(320px, 28vw, 480px);
	text-decoration: none;
	transition: opacity 0.2s ease, transform 0.2s ease;
	box-shadow: 0 4px 16px rgba(0, 0, 0, 0.2);
	backdrop-filter: blur(4px);
}

.kr-fv__newsItem:hover {
	opacity: 0.9;
	transform: translateY(-2px);
}

.kr-fv__newsThumb {
	flex-shrink: 0;
	width: 52px;
	height: 52px;
	object-fit: cover;
	background: #eee;
}

.kr-fv__newsThumb--empty {
	background: var(--kr-gold);
	opacity: 0.15;
}

.kr-fv__newsContent {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: 6px;
	overflow: hidden;
}

.kr-fv__newsTitle {
	margin: 0;
	font-size: clamp(12px, 1vw, 13px);
	font-weight: 500;
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.kr-fv__newsDate {
	margin: 0;
	font-size: 11px;
	color: #666;
	letter-spacing: 0.05em;
	font-family: "Helvetica Neue", Arial, sans-serif;
}

@keyframes scrollNews {
	0% {
		transform: translateX(0);
	}
	100% {
		transform: translateX(-50%);
	}
}

/* Message Section */
.kr-message {
	position: relative;
	padding: clamp(80px, 12vw, 160px) 0;
	background: var(--kr-bg);
	overflow: hidden;
}

.kr-message__inner {
	position: relative;
	max-width: 1440px;
	margin: 0 auto;
	display: flex;
	align-items: center;
	justify-content: flex-end;
}

.kr-message__imageWrap {
	position: relative;
	overflow: hidden;
}

.kr-message__imageWrap--main {
	width: 52%;
	aspect-ratio: 4/5;
	margin-right: 8%; /* Push slightly left from right edge to center-right it */
}

.kr-message__imageWrap--sub {
	position: absolute;
	right: 50%;
	bottom: -5%;
	width: 24%;
	aspect-ratio: 1/1;
	z-index: 2;
}

.kr-message__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	will-change: transform;
}

.kr-message__content {
	position: absolute;
	left: 10%;
	top: 50%;
	transform: translateY(-50%);
	z-index: 3;
	width: 40%;
}

.kr-message__title {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(28px, 3.2vw, 42px);
	font-weight: 500;
	letter-spacing: 0.15em;
	line-height: 1.6;
	margin: 0 0 36px;
	color: #fff;
	text-shadow: 0 4px 24px rgba(0,0,0,0.4);
}

.kr-message__text {
	font-size: clamp(14px, 1.1vw, 16px);
	line-height: 2.4;
	letter-spacing: 0.08em;
	color: rgba(255,255,255,0.9);
	margin: 0;
}

/* Ingredients Section */
.kr-ingredients {
	position: relative;
	background: var(--kr-bg);
	color: #fff;
	overflow: hidden;
	height: 100vh;
}

.kr-ingredients__header {
	position: absolute;
	top: clamp(60px, 8vw, 100px);
	left: clamp(24px, 6vw, 80px);
	z-index: 10;
}

.kr-ingredients__title {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(20px, 2.5vw, 32px);
	font-weight: 400;
	letter-spacing: 0.1em;
	margin: 0;
}

.kr-ingredients__scrollArea {
	width: 100%;
	height: 100%;
}

.kr-ingredients__list {
	display: flex;
	flex-wrap: nowrap;
	height: 100%;
	align-items: center;
	width: max-content;
	padding: 0 clamp(24px, 6vw, 80px);
}

.kr-ingredients__item {
	display: flex;
	align-items: center;
	width: 85vw;
	max-width: 1100px;
	margin-right: clamp(60px, 8vw, 120px);
	flex-shrink: 0;
	position: relative;
}

.kr-ingredients__item:last-child {
	margin-right: 0;
}

.kr-ingredients__imageWrap {
	width: 65%;
	aspect-ratio: 4/3;
	overflow: hidden;
}

.kr-ingredients__imageWrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	will-change: transform;
}

.kr-ingredients__content {
	width: 45%;
	display: flex;
	flex-direction: column;
	gap: 24px;
	margin-left: -10%;
	position: relative;
	z-index: 2;
}

.kr-ingredients__itemName {
	display: flex;
	flex-direction: column;
	gap: 4px;
	margin: 0;
}

.kr-ingredients__itemNameJa {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(32px, 4vw, 48px);
	font-weight: 500;
	letter-spacing: 0.1em;
	text-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.kr-ingredients__itemNameEn {
	font-family: "Times New Roman", serif;
	font-size: clamp(48px, 6vw, 80px);
	font-weight: 400;
	letter-spacing: 0.05em;
	color: var(--kr-gold);
	text-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.kr-ingredients__itemText {
	font-size: clamp(15px, 1.2vw, 18px);
	line-height: 2;
	letter-spacing: 0.08em;
	color: rgba(255,255,255,0.9);
	margin: 0;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
}

@media (max-width: 980px) {
	.kr-header__menu {
		display: none;
	}

	.kr-fv {
		grid-template-columns: 1fr;
		min-height: 86vh;
	}

	.kr-fv__divider {
		display: none;
	}

	.kr-fv__split--left {
		background: transparent;
		grid-row: 1;
		grid-column: 1;
		z-index: 2;
	}

	.kr-fv__split--right {
		grid-row: 1;
		grid-column: 1;
		z-index: 1;
	}

	.kr-fv__content {
		padding-top: 110px;
	}

	.kr-fv__textGroup {
		left: 50%;
		top: 39%;
		width: 94vw;
	}

	.kr-fv__titleWrap {
		font-size: clamp(58px, 17vw, 112px);
	}

	.kr-fv__titleLayer--light {
		clip-path: none;
	}

	.kr-fv__titleLayer--dark {
		display: none;
	}

	.kr-fv__catch {
		font-size: 13px;
		white-space: nowrap;
	}

	.kr-footer {
		padding: 32px 16px;
		display: flex;
		flex-direction: column;
		gap: 24px;
	}

	.kr-footer__inner {
		gap: 32px;
	}

	.kr-footer__links {
		gap: 16px 24px;
	}

	.kr-footer__links li:not(:last-child)::after {
		display: none;
	}

	.kr-footer__pagetop {
		position: static;
		transform: none;
		margin: 0 auto;
	}

	.kr-message {
		padding: 60px 0 100px;
	}

	.kr-message__inner {
		flex-direction: column;
		align-items: flex-start;
	}

	.kr-message__imageWrap--main {
		width: 85%;
		margin-left: 0;
	}

	.kr-message__content {
		position: relative;
		left: auto;
		top: auto;
		transform: none;
		width: 100%;
		padding: 40px 24px;
	}

	.kr-message__title {
		font-size: clamp(26px, 8vw, 36px);
		margin-bottom: 24px;
	}

	.kr-message__imageWrap--sub {
		position: relative;
		right: auto;
		bottom: auto;
		width: 60%;
		margin-left: auto;
		margin-top: -20px;
	}

	.kr-ingredients {
		height: auto;
		padding: 60px 0;
	}

	.kr-ingredients__header {
		position: static;
		margin-bottom: 40px;
	}

	.kr-ingredients__list {
		flex-direction: column;
		width: 100%;
		padding: 0 24px;
		gap: 60px;
	}

	.kr-ingredients__item {
		width: 100%;
		max-width: 100%;
		margin-right: 0;
		flex-direction: column !important; /* Stack vertically, ignore reverse */
		gap: 0;
	}

	.kr-ingredients__imageWrap {
		width: 100%;
	}

	.kr-ingredients__content {
		width: 100%;
		margin-left: 0;
		margin-top: -12%;
		padding: 0 12px;
	}
}

/* ==========================================================================
   Gateau Chocolat Section
   ========================================================================== */
.kr-gateau {
	position: relative;
	padding: clamp(80px, 12vw, 160px) 0;
	min-height: 80vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
}

.kr-gateau__bgWrap {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
}

.kr-gateau__bgImage {
	position: absolute;
	top: -20%;
	left: -5%;
	width: 110%;
	height: 140%;
	object-fit: cover;
	will-change: transform;
}

.kr-gateau__overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: linear-gradient(to right, rgba(26, 17, 10, 0.8) 0%, rgba(26, 17, 10, 0.2) 100%);
	z-index: 1;
}

.kr-gateau__content {
	position: relative;
	z-index: 2;
	width: 90%;
	max-width: 800px;
	margin: 0 auto;
	color: #fff;
}

.kr-gateau__header {
	margin-bottom: clamp(40px, 6vw, 60px);
	text-align: center;
}

.kr-gateau__titleJa {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(32px, 5vw, 48px);
	font-weight: 500;
	letter-spacing: 0.1em;
	margin: 0 0 8px;
	text-shadow: 0 4px 20px rgba(0, 0, 0, 0.6);
}

.kr-gateau__titleEn {
	font-family: "Times New Roman", serif;
	font-size: clamp(16px, 2vw, 22px);
	font-weight: 400;
	letter-spacing: 0.15em;
	color: var(--kr-gold);
	margin: 0;
}

.kr-gateau__features {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: clamp(16px, 2.5vw, 24px);
	text-align: left;
	background: rgba(197, 160, 89, 0.6);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 1px solid rgba(255, 255, 255, 0.4);
	box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
	padding: clamp(32px, 5vw, 48px);
	color: #1A110A;
}

.kr-gateau__featureItem {
	display: flex;
	gap: 16px;
	font-size: clamp(15px, 1.2vw, 18px);
	line-height: 1.8;
	letter-spacing: 0.08em;
	border-bottom: 1px solid rgba(26, 17, 10, 0.15);
	padding-bottom: clamp(16px, 2.5vw, 24px);
	font-weight: 500;
}

.kr-gateau__featureItem:last-child {
	border-bottom: none;
	padding-bottom: 0;
}

.kr-gateau__featureNum {
	color: #fff;
	background: #1A110A;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	font-family: "Times New Roman", serif;
	font-size: 1em;
	font-weight: bold;
	flex-shrink: 0;
	margin-top: 2px;
}

@media (max-width: 980px) {
	.kr-gateau__overlay {
		background: linear-gradient(to bottom, rgba(26, 17, 10, 0.5) 0%, rgba(26, 17, 10, 0.9) 100%);
	}
	.kr-gateau__features {
		padding: 32px 24px;
	}
}

/* ==========================================================================
   Recommend Section
   ========================================================================== */
.kr-recommend {
	padding: clamp(80px, 12vw, 160px) 0 0 0;
	overflow: hidden;
}

.kr-recommend__header {
	text-align: center;
	margin-bottom: clamp(60px, 10vw, 100px);
}

.kr-recommend__titleJa {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 500;
	letter-spacing: 0.1em;
	margin: 0 0 8px;
}

.kr-recommend__titleEn {
	font-family: "Times New Roman", serif;
	font-size: clamp(16px, 2vw, 22px);
	font-weight: 400;
	letter-spacing: 0.15em;
	color: var(--kr-gold);
	margin: 0;
}

.kr-recommend__list {
	display: flex;
	flex-direction: column;
	gap: clamp(80px, 12vw, 160px);
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}

.kr-recommend__item {
	display: flex;
	align-items: center;
	position: relative;
	width: 100%;
}

.kr-recommend__item:nth-child(even) {
	flex-direction: row-reverse;
}

.kr-recommend__imageWrap {
	width: 60%;
	aspect-ratio: 4/3;
	overflow: hidden;
	position: relative;
}

.kr-recommend__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	will-change: transform;
}

.kr-recommend__content {
	width: 50%;
	padding: clamp(32px, 5vw, 64px);
	position: relative;
	z-index: 2;
	margin-left: -10%;
}

.kr-recommend__item:nth-child(even) .kr-recommend__content {
	margin-left: 0;
	margin-right: -10%;
}

.kr-recommend__itemName {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(24px, 3vw, 36px);
	font-weight: 500;
	letter-spacing: 0.1em;
	margin: 0 0 24px;
	line-height: 1.4;
	text-shadow: 0 4px 20px rgba(0, 0, 0, 0.4);
}

.kr-recommend__itemText {
	font-size: clamp(14px, 1.1vw, 16px);
	line-height: 2;
	letter-spacing: 0.08em;
	color: rgba(255,255,255,0.85);
	margin: 0 0 32px;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
}

.kr-recommend__link,
.kr-recommend__viewAll {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: "Times New Roman", serif;
	font-size: 13px;
	letter-spacing: 0.2em;
	color: #fff;
	text-decoration: none;
	border: 1px solid #fff;
	border-radius: 50px;
	padding: 16px 48px;
	transition: all 0.3s ease;
	position: relative;
	overflow: hidden;
}

.kr-recommend__link:hover,
.kr-recommend__viewAll:hover {
	background: #fff;
	color: #1A110A;
}

.kr-recommend__footer {
	text-align: center;
	margin-top: clamp(80px, 12vw, 120px);
	margin-bottom: clamp(60px, 10vw, 100px);
}

/* Online Shop Special Layout */
.kr-recommend__item--online {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: calc(clamp(80px, 12vw, 160px) + 6vw) 24px;
	overflow: hidden;
	min-height: 60vh;
	clip-path: polygon(0 6vw, 100% 0, 100% calc(100% - 6vw), 0 100%);
	margin-top: -6vw;
	z-index: 5;
}

.kr-recommend__item--online .kr-recommend__imageWrap {
	position: absolute;
	top: -15%;
	left: 0;
	width: 100%;
	height: 130%;
	z-index: 0;
}

.kr-recommend__item--online .kr-recommend__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.kr-recommend__overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: rgba(26, 17, 10, 0.6);
	z-index: 1;
}

.kr-recommend__item--online .kr-recommend__content {
	width: 100%;
	max-width: 680px;
	margin: 0 auto !important;
	text-align: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	padding: clamp(40px, 6vw, 64px);
	z-index: 2;
}

@media (max-width: 980px) {
	.kr-recommend__item:not(.kr-recommend__item--online),
	.kr-recommend__item:nth-child(even):not(.kr-recommend__item--online) {
		flex-direction: column;
	}

	.kr-recommend__item:not(.kr-recommend__item--online) .kr-recommend__imageWrap {
		width: 100%;
	}

	.kr-recommend__item:not(.kr-recommend__item--online) .kr-recommend__content {
		width: 90%;
		margin: -10% auto 0 !important;
		padding: 32px 24px;
	}
}

/* ==========================================================================
   Shop List & News Section
   ========================================================================== */
.kr-shop-news-wrapper {
	background: #b59c70; /* Intermediate desaturated gold */
	clip-path: polygon(0 6vw, 100% 0, 100% 100%, 0 100%);
	margin-top: -6vw;
	padding-top: 6vw;
	position: relative;
	z-index: 6;
}

.kr-shop,
.kr-news {
	padding: clamp(60px, 8vw, 120px) 0;
	background: transparent;
	color: #fff;
}

.kr-shop {
	padding-bottom: 0;
}

.kr-news {
	padding-top: clamp(60px, 8vw, 120px);
	background: var(--kr-bg);
}

.kr-shop__header,
.kr-news__header {
	text-align: center;
	margin-bottom: clamp(40px, 6vw, 80px);
}

.kr-shop__titleJa {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(28px, 4vw, 40px);
	font-weight: 500;
	letter-spacing: 0.1em;
	margin: 0 0 8px;
}

.kr-shop__titleEn,
.kr-news__titleEn {
	font-family: "Times New Roman", serif;
	font-size: clamp(32px, 5vw, 56px);
	font-weight: 400;
	letter-spacing: 0.15em;
	margin: 0;
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

/* Shop List Grid */
.kr-shop__grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 24px;
	max-width: 1000px;
	margin: 0 auto;
	padding: 0 24px;
}

.kr-shop__item {
	display: block;
	position: relative;
	text-decoration: none;
	color: #fff;
	overflow: hidden;
}

.kr-shop__imageWrap {
	width: 100%;
	aspect-ratio: 16/9;
	overflow: hidden;
}

.kr-shop__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.kr-shop__item:hover .kr-shop__image {
	transform: scale(1.05);
}

.kr-shop__content {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	padding: 24px;
	background: linear-gradient(to top, rgba(0,0,0,0.7) 0%, rgba(0,0,0,0) 100%);
}

.kr-shop__itemName {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: clamp(16px, 1.5vw, 20px);
	font-weight: 500;
	letter-spacing: 0.1em;
	margin: 0;
}

.kr-shop__footer {
	text-align: center;
	margin-top: clamp(60px, 8vw, 100px);
	padding-bottom: clamp(60px, 8vw, 100px);
}

.kr-news__footer {
	text-align: center;
	margin-top: clamp(60px, 8vw, 100px);
}

/* News List (Horizontal scroll/flex like the image) */
.kr-news__list {
	display: flex;
	gap: 24px;
	overflow-x: auto;
	padding: 0 clamp(24px, 5vw, 60px);
	scroll-snap-type: x mandatory;
	-ms-overflow-style: none;  /* IE and Edge */
	scrollbar-width: none;  /* Firefox */
}

.kr-news__list::-webkit-scrollbar {
	display: none;
}

.kr-news__item {
	display: flex;
	flex-direction: column;
	flex: 0 0 calc(25% - 18px);
	min-width: 280px;
	text-decoration: none;
	color: #fff;
	scroll-snap-align: start;
	will-change: transform, opacity;
}

.kr-news__imageWrap {
	width: 100%;
	aspect-ratio: 4/3;
	margin-bottom: 24px;
	overflow: hidden;
}

.kr-news__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.6s ease;
}

.kr-news__item:hover .kr-news__image {
	transform: scale(1.05);
}

.kr-news__content {
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	flex-grow: 1;
}

.kr-news__itemTitle {
	font-family: "Mincho", "Yu Mincho", "Hiragino Mincho ProN", serif;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.05em;
	margin: 0 0 24px;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.kr-news__itemDate {
	font-family: "Times New Roman", serif;
	font-size: 12px;
	letter-spacing: 0.1em;
	border-bottom: 1px solid rgba(255, 255, 255, 0.3);
	padding-bottom: 8px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.kr-news__arrow {
	opacity: 0.6;
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.kr-news__item:hover .kr-news__arrow {
	transform: translateX(4px);
	opacity: 1;
}

@media (max-width: 980px) {
	.kr-shop__grid {
		grid-template-columns: 1fr;
	}
	
	.kr-news__item {
		flex: 0 0 85%;
	}
}

/* ==========================================================================
   Photo Gallery Section
   ========================================================================== */
.kr-gallery {
	background: #1A110A;
	padding: clamp(60px, 8vw, 120px) 0;
	overflow: hidden;
}

.kr-gallery__grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: clamp(8px, 1.5vw, 24px);
	max-width: 1400px;
	margin: 0 auto;
	padding: 0 clamp(8px, 1.5vw, 24px);
}

.kr-gallery__item {
	position: relative;
	width: 100%;
	aspect-ratio: 1 / 1;
	overflow: hidden;
	display: flex;
	align-items: center;
	justify-content: center;
}

.kr-gallery__item--txt {
	background: transparent;
}

.kr-gallery__text {
	font-family: "Times New Roman", serif;
	font-size: clamp(24px, 4vw, 48px);
	font-style: italic;
	letter-spacing: 0.1em;
	color: var(--kr-gold);
	text-transform: uppercase;
}

.kr-gallery__imageWrap {
	width: 100%;
	height: 120%; /* Extended height for parallax */
	position: absolute;
	top: -10%;
	left: 0;
}

.kr-gallery__image {
	width: 100%;
	height: 100%;
	object-fit: cover;
	will-change: transform;
}

@media (max-width: 768px) {
	.kr-gallery__grid {
		grid-template-columns: repeat(2, 1fr);
	}
	/* Hide the text items on mobile if you want a clean 2-column image grid, or adjust layout */
	.kr-gallery__item--txt {
		display: none;
	}
	.kr-gallery__item:nth-child(4), /* cafe */
	.kr-gallery__item:nth-child(5), /* PIC-59 */
	.kr-gallery__item:nth-child(6)  /* PIC-41 */ {
		/* Adjust if needed to not break the 2-column layout */
	}
}

