/* ============================================================
   LuxuriousView — Cinematic Dark visual system
   tokens / typography / components
   ============================================================ */

/* Metric-adjusted fallbacks to suppress FOUT layout shift.
   Values calibrated to Times New Roman / Yu Mincho (Windows primary),
   acceptable on Mac (Times / Hiragino Mincho) with minor residual shift. */

@font-face {
	font-family: "Cormorant Fallback";
	src: local("Times New Roman"), local("Times"), local("serif");
	size-adjust: 96%;
	ascent-override: 90%;
	descent-override: 24%;
	line-gap-override: 0%;
	font-style: normal;
}

@font-face {
	font-family: "Cormorant Fallback";
	src: local("Times New Roman"), local("Times"), local("serif");
	size-adjust: 96%;
	ascent-override: 90%;
	descent-override: 24%;
	line-gap-override: 0%;
	font-style: italic;
}

@font-face {
	font-family: "Noto Serif JP Fallback";
	src: local("Yu Mincho"), local("Hiragino Mincho ProN"), local("serif");
	size-adjust: 100%;
	ascent-override: 88%;
	descent-override: 22%;
	line-gap-override: 0%;
}

:root {
	/* surface */
	--bg: #0a0e13;
	--bg-soft: #131820;
	--bg-card: #181e26;
	--bg-elevated: #1d242d;

	/* ink */
	--text: #f0e8dc;
	--text-soft: #b8b0a6;
	--text-muted: #7a8089;

	/* brand */
	--accent: #c9a262;
	--accent-bright: #e8d4a8;
	--accent-deep: #8c6f3e;

	/* line */
	--border: #232932;
	--border-soft: #1a1f27;
	--border-accent: rgba(201, 162, 98, 0.32);

	/* typography */
	--font-display: "Cormorant Garamond", "Cormorant Fallback", "Times New Roman", serif;
	--font-jp: "Noto Serif JP", "Noto Serif JP Fallback", "Yu Mincho", serif;
	--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "Noto Sans JP", sans-serif;

	/* scale */
	--max-w: 920px;
	--max-w-prose: 680px;
	--max-w-wide: 1240px;

	/* motion */
	--ease-out: cubic-bezier(0.22, 1, 0.36, 1);
	--ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
}

* {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	scroll-behavior: smooth;
}

body {
	background: var(--bg);
	color: var(--text);
	font-family: var(--font-jp);
	font-weight: 300;
	line-height: 1.9;
	font-feature-settings: "palt";
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	overflow-x: hidden;
}

img {
	max-width: 100%;
	display: block;
}

a {
	color: var(--text);
	transition: color 0.25s var(--ease-out);
}

a:hover {
	color: var(--accent-bright);
}

::selection {
	background: var(--accent);
	color: var(--bg);
}

/* ============================================================
   Site chrome — pr banner / header / footer
   ============================================================ */

.pr-banner {
	background: var(--bg-soft);
	border-bottom: 1px solid var(--border-soft);
	color: var(--text-muted);
	font-family: var(--font-sans);
	font-size: 0.78rem;
	letter-spacing: 0.12em;
	padding: 0.55rem 1rem;
	text-align: center;
}

.pr-banner strong {
	color: var(--accent);
	font-weight: 600;
	letter-spacing: 0.18em;
	margin-right: 0.6em;
}

header.site-header {
	border-bottom: 1px solid var(--border-soft);
	padding: 1.4rem 1.25rem;
	text-align: center;
}

header.site-header .brand {
	color: var(--text);
	display: inline-block;
	font-family: var(--font-display);
	font-size: 1.9rem;
	font-weight: 500;
	letter-spacing: 0.13em;
	text-decoration: none;
	text-transform: uppercase;
}

header.site-header .brand::after {
	background: var(--accent);
	content: '';
	display: block;
	height: 1px;
	margin: 0.55rem auto 0;
	width: 2.4rem;
}

header.site-header .brand:hover {
	color: var(--accent);
}

header.site-header .tagline {
	color: #b6c0cc;
	display: block;
	font-size: 0.74rem;
	letter-spacing: 0.14em;
	margin-top: 0.55rem;
}

footer.site-footer {
	border-top: 1px solid var(--border-soft);
	color: var(--text-muted);
	font-family: var(--font-sans);
	font-size: 0.82rem;
	margin-top: 5rem;
	padding: 2.5rem 1rem 2rem;
	text-align: center;
}

footer.site-footer nav {
	margin-bottom: 1.2rem;
}

footer.site-footer nav a {
	color: var(--text-soft);
	letter-spacing: 0.05em;
	margin: 0 0.85em;
	text-decoration: none;
}

footer.site-footer nav a:hover {
	color: var(--accent);
}

footer.site-footer .copyright {
	font-family: var(--font-display);
	font-size: 0.85rem;
	letter-spacing: 0.12em;
}

/* ============================================================
   Cinematic hero (place pages)
   ============================================================ */

.hero-cinematic {
	position: relative;
	width: 100%;
	height: clamp(420px, 78vh, 720px);
	overflow: hidden;
	background: var(--bg);
}

.hero-cinematic__media {
	position: absolute;
	inset: 0;
	overflow: hidden;
}

.hero-cinematic__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transform: scale(1.04);
	animation: heroZoom 18s var(--ease-out) forwards;
}

.hero-cinematic__media::after {
	background: var(--bg);
	bottom: -1px;
	content: "";
	height: 2px;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	z-index: 3;
}

.hero-cinematic__content {
	background: linear-gradient(
		to top,
		rgba(10, 14, 19, 0.78) 0%,
		rgba(10, 14, 19, 0.55) 35%,
		rgba(10, 14, 19, 0.2) 75%,
		rgba(10, 14, 19, 0) 100%
	);
	bottom: 0;
	left: 0;
	padding: clamp(3.5rem, 8vw, 6rem) clamp(1.25rem, 5vw, 3rem) clamp(2.5rem, 8vh, 5rem);
	position: absolute;
	right: 0;
	z-index: 2;
}

.hero-cinematic__title {
	color: var(--text);
	font-weight: 300;
	letter-spacing: 0;
	line-height: 1.15;
	margin-bottom: 1.5rem;
	max-width: 900px;
	text-shadow: 0 2px 24px rgba(0, 0, 0, 0.5);
}

.hero-cinematic__title-en {
	display: block;
	font-family: var(--font-display);
	font-size: clamp(2.4rem, 6.5vw, 4.6rem);
	font-style: italic;
	font-weight: 400;
	letter-spacing: 0;
	margin-bottom: 0.4rem;
	opacity: 0;
	transform: translateX(-40px);
	animation: heroSlideIn 1.4s var(--ease-out) 0.7s forwards;
}

.hero-cinematic__title-jp {
	display: block;
	font-family: var(--font-jp);
	font-size: clamp(1.4rem, 3.2vw, 2.1rem);
	font-weight: 400;
	letter-spacing: 0.05em;
	opacity: 0;
	transform: translateX(-40px);
	animation: heroSlideIn 1.4s var(--ease-out) 1.05s forwards;
}

.hero-cinematic__location {
	color: var(--text-soft);
	font-family: var(--font-sans);
	font-size: 0.86rem;
	letter-spacing: 0.08em;
	max-width: 480px;
	opacity: 0;
	text-shadow: 0 1px 8px rgba(0, 0, 0, 0.5);
	animation: heroFadeIn 1.2s var(--ease-out) 1.5s forwards;
}

.hero-cinematic__scroll {
	bottom: 1.5rem;
	left: 50%;
	opacity: 0;
	position: absolute;
	transform: translateX(-50%);
	z-index: 2;
	pointer-events: none;
	transition: opacity 0.5s var(--ease-out);
}

.hero-cinematic__scroll.is-visible {
	opacity: 1;
}

.hero-cinematic__scroll.is-hidden {
	opacity: 0;
}

.hero-cinematic__scroll span {
	color: var(--text-muted);
	display: inline-block;
	font-family: var(--font-sans);
	font-size: 0.7rem;
	letter-spacing: 0.36em;
	animation: scrollPulse 2.4s ease-in-out infinite;
}

@keyframes heroZoom {
	from { transform: scale(1.08); }
	to { transform: scale(1); }
}

@keyframes heroSlideIn {
	from { opacity: 0; transform: translateX(-40px); }
	to { opacity: 1; transform: translateX(0); }
}

@keyframes heroFadeIn {
	from { opacity: 0; transform: translateY(8px); }
	to { opacity: 1; transform: translateY(0); }
}

@keyframes scrollPulse {
	0%, 100% { opacity: 0.5; transform: translateY(0); }
	50% { opacity: 1; transform: translateY(4px); }
}

/* ============================================================
   Page content (place pages — cinematic article)
   ============================================================ */

.article {
	margin: 0 auto;
	max-width: var(--max-w);
	padding: clamp(3rem, 8vh, 6rem) clamp(1.25rem, 4vw, 2rem) 4rem;
}

.article__lede {
	color: var(--text-soft);
	font-family: var(--font-jp);
	font-size: clamp(1.05rem, 1.6vw, 1.2rem);
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 2;
	margin: 0 auto 4rem;
	max-width: var(--max-w-prose);
	opacity: 0;
	animation: revealUp 1.2s var(--ease-out) 1.8s forwards;
	text-align: center;
}

.article__lede::before {
	background: var(--accent);
	content: "";
	display: block;
	height: 1px;
	margin: 0 auto 2rem;
	width: 3rem;
}

.section {
	margin: 0 auto 4.5rem;
	max-width: var(--max-w-prose);
}

.section__heading {
	color: var(--text);
	font-family: var(--font-jp);
	font-size: clamp(1.55rem, 2.6vw, 1.95rem);
	font-weight: 500;
	letter-spacing: 0.08em;
	line-height: 1.5;
	margin: 0 auto 2.5rem;
	text-align: center;
}

.section__heading::before {
	background: var(--accent);
	content: "";
	display: block;
	height: 1px;
	margin: 0 auto 1.5rem;
	width: 2.4rem;
}

.section p {
	margin-bottom: 1.5rem;
}

.section p:last-child {
	margin-bottom: 0;
}

.figure-block {
	margin: 3.5rem auto;
	max-width: var(--max-w-prose);
}

.figure-block--wide {
	max-width: var(--max-w);
}

.figure-block__img {
	height: auto;
	max-height: 60vh;
	object-fit: cover;
	width: 100%;
}

/* ============================================================
   CTA card (cinematic)
   ============================================================ */

.cta-card {
	background: linear-gradient(180deg, var(--bg-card) 0%, var(--bg-soft) 100%);
	border: 1px solid var(--border);
	border-top: 1px solid var(--border-accent);
	margin: 5rem auto 0;
	max-width: var(--max-w-prose);
	padding: clamp(2.5rem, 5vw, 3.5rem) clamp(1.5rem, 4vw, 2.75rem);
	position: relative;
}

.cta-card::before {
	background: var(--accent);
	content: "";
	height: 1px;
	left: 50%;
	position: absolute;
	top: -1px;
	transform: translateX(-50%);
	width: 4rem;
}

.cta-card__eyebrow {
	color: var(--accent);
	display: block;
	font-family: var(--font-sans);
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.22em;
	margin-bottom: 1rem;
	text-align: center;
	text-transform: uppercase;
}

.cta-card__lead {
	color: var(--text);
	font-family: var(--font-jp);
	font-size: clamp(1.25rem, 2vw, 1.5rem);
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 1.6;
	margin-bottom: 1.75rem;
	text-align: center;
}

.cta-card__body {
	color: var(--text-soft);
	font-size: 0.95rem;
	margin-bottom: 1.25rem;
}

.cta-card__body:last-of-type {
	margin-bottom: 2.25rem;
}

.cta-card__button {
	align-items: center;
	background: var(--accent);
	border: 1px solid var(--accent);
	color: var(--bg);
	display: inline-flex;
	font-family: var(--font-jp);
	font-size: 0.95rem;
	font-weight: 600;
	gap: 0.85rem;
	justify-content: center;
	letter-spacing: 0.08em;
	margin: 0 auto;
	padding: 1.05rem 2.25rem;
	text-decoration: none;
	transition: transform 0.3s var(--ease-out), background 0.3s var(--ease-out), color 0.3s var(--ease-out), box-shadow 0.3s var(--ease-out);
	width: 100%;
	max-width: 420px;
}

.cta-card__button-wrap {
	display: flex;
	justify-content: center;
}

.cta-card__button:hover,
.cta-card__button:focus-visible {
	background: var(--accent-bright);
	color: var(--bg);
	transform: translateY(-2px);
	box-shadow: 0 12px 32px -16px rgba(201, 162, 98, 0.6);
}

.cta-card__button .arrow {
	display: inline-block;
	transition: transform 0.3s var(--ease-out);
}

.cta-card__button:hover .arrow {
	transform: translateX(4px);
}

.cta-card__disclaimer {
	color: var(--text-muted);
	font-family: var(--font-sans);
	font-size: 0.74rem;
	letter-spacing: 0.08em;
	line-height: 1.7;
	margin-top: 1.5rem;
	text-align: center;
}

.back-to-index {
	margin: clamp(4rem, 8vw, 5rem) auto 0;
	max-width: var(--max-w);
	padding: 0 clamp(1.25rem, 4vw, 2rem);
	text-align: center;
}

.back-to-index__link {
	color: var(--text-soft);
	display: inline-block;
	font-family: var(--font-sans);
	font-size: 0.88rem;
	font-weight: 500;
	letter-spacing: 0.12em;
	padding: 0.75rem 1rem;
	text-decoration: none;
	transition: color 0.3s var(--ease-out);
}

.back-to-index__link:hover,
.back-to-index__link:focus-visible {
	color: var(--accent);
}

.back-to-index__link .arrow {
	display: inline-block;
	font-size: 1.2em;
	font-weight: 700;
	line-height: 1;
	margin-right: 0.55em;
	transition: transform 0.3s var(--ease-out);
	vertical-align: -1px;
}

.back-to-index__link:hover .arrow,
.back-to-index__link:focus-visible .arrow {
	transform: translateX(-3px);
}

/* ============================================================
   Reveal-on-scroll
   ============================================================ */

.reveal {
	opacity: 0;
	transform: translateY(24px);
	transition: opacity 0.9s var(--ease-out), transform 0.9s var(--ease-out);
}

.reveal.is-visible {
	opacity: 1;
	transform: translateY(0);
}

@keyframes revealUp {
	from { opacity: 0; transform: translateY(16px); }
	to { opacity: 1; transform: translateY(0); }
}

/* ============================================================
   Index page — intro, featured, asymmetric grid
   ============================================================ */

.visually-hidden {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

main.index-main {
	margin: 0;
	max-width: none;
	padding: 0;
}

.index-intro {
	margin: 0 auto;
	max-width: var(--max-w-prose);
	padding: clamp(3.5rem, 9vh, 6rem) clamp(1.25rem, 4vw, 2rem) clamp(2.5rem, 6vh, 4rem);
	text-align: center;
}

.index-intro::before {
	background: var(--accent);
	content: "";
	display: block;
	height: 1px;
	margin: 0 auto 2.5rem;
	width: 2.4rem;
}

.index-intro__lede {
	color: var(--text-soft);
	font-family: var(--font-jp);
	font-size: clamp(0.95rem, 1.4vw, 1.05rem);
	font-weight: 300;
	letter-spacing: 0.02em;
	line-height: 2;
	margin: 0 auto;
	max-width: 600px;
}

.place-feature-wrap {
	margin: 0 auto clamp(4rem, 8vh, 6rem);
	max-width: var(--max-w-wide);
	padding: 0 clamp(1.25rem, 4vw, 2rem);
}

.place-feature {
	color: var(--text);
	display: block;
	overflow: hidden;
	position: relative;
	text-decoration: none;
}

.place-feature__media {
	aspect-ratio: 16 / 9;
	background: var(--bg);
	font-size: 0;
	line-height: 0;
	overflow: hidden;
	position: relative;
}

.place-feature__media::after {
	background: var(--bg);
	bottom: -1px;
	content: "";
	height: 2px;
	left: 0;
	pointer-events: none;
	position: absolute;
	right: 0;
	z-index: 3;
}

.place-feature__media img {
	display: block;
	height: 100%;
	width: 100%;
	object-fit: cover;
	transition: transform 1s var(--ease-out);
	vertical-align: bottom;
}

.place-feature:hover .place-feature__media img,
.place-feature:focus-visible .place-feature__media img {
	transform: scale(1.04);
}

.place-feature__caption {
	background: linear-gradient(
		to top,
		rgba(10, 14, 19, 0.78) 0%,
		rgba(10, 14, 19, 0.55) 35%,
		rgba(10, 14, 19, 0.2) 75%,
		rgba(10, 14, 19, 0) 100%
	);
	bottom: -1px;
	left: 0;
	padding: clamp(2rem, 5vw, 3.5rem) clamp(1.75rem, 4vw, 2.75rem) clamp(1.25rem, 3.5vw, 2.25rem);
	pointer-events: none;
	position: absolute;
	right: 0;
	z-index: 2;
}

.place-feature__title {
	margin-bottom: 0.4rem;
	text-shadow: 0 1px 12px rgba(0, 0, 0, 0.55);
}

.place-feature__title-en {
	color: var(--text);
	display: block;
	font-family: var(--font-display);
	font-size: clamp(2rem, 4.5vw, 3rem);
	font-style: italic;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.1;
	margin-bottom: 0.3rem;
}

.place-feature__title-jp {
	color: var(--text);
	display: block;
	font-family: var(--font-jp);
	font-size: clamp(1.05rem, 1.8vw, 1.3rem);
	font-weight: 400;
	letter-spacing: 0.05em;
}

.place-feature__meta {
	color: var(--text-soft);
	font-family: var(--font-sans);
	font-size: 0.78rem;
	letter-spacing: 0.18em;
	margin-top: 0.85rem;
	text-shadow: 0 1px 8px rgba(0, 0, 0, 0.5);
	text-transform: uppercase;
}

.place-grid {
	display: grid;
	gap: clamp(2rem, 5vw, 3.5rem) clamp(1rem, 3vw, 2rem);
	grid-template-columns: 1fr 1fr;
	margin: 0 auto;
	max-width: var(--max-w-wide);
	padding: 0 clamp(1rem, 4vw, 2rem) clamp(4rem, 8vh, 6rem);
}

.place-card {
	align-self: start;
	color: var(--text);
	display: block;
	text-decoration: none;
}

.place-card__media {
	aspect-ratio: 4 / 5;
	margin-bottom: 1rem;
	overflow: hidden;
}

.place-card__media img {
	display: block;
	height: 100%;
	width: 100%;
	object-fit: cover;
	transition: transform 0.8s var(--ease-out);
}

.place-card:hover .place-card__media img,
.place-card:focus-visible .place-card__media img {
	transform: scale(1.05);
}

.place-card__title {
	margin-bottom: 0.4rem;
}

.place-card__title-en {
	color: var(--text);
	display: block;
	font-family: var(--font-display);
	font-size: clamp(1.05rem, 2vw, 1.55rem);
	font-style: italic;
	font-weight: 400;
	letter-spacing: 0;
	line-height: 1.2;
	margin-bottom: 0.25rem;
	transition: color 0.3s var(--ease-out);
}

.place-card:hover .place-card__title-en,
.place-card:focus-visible .place-card__title-en {
	color: var(--accent-bright);
}

.place-card__title-jp {
	color: var(--text);
	display: block;
	font-family: var(--font-jp);
	font-size: clamp(0.82rem, 1.5vw, 0.95rem);
	font-weight: 400;
	letter-spacing: 0.05em;
}

.place-card__meta {
	color: var(--text-soft);
	font-family: var(--font-sans);
	font-size: clamp(0.66rem, 1.2vw, 0.74rem);
	letter-spacing: 0.16em;
	margin-top: 0.5rem;
	text-transform: uppercase;
}

/* ============================================================
   Reduced motion
   ============================================================ */

@media (prefers-reduced-motion: reduce) {
	*,
	*::before,
	*::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}

	.hero-cinematic__title-en,
	.hero-cinematic__title-jp,
	.hero-cinematic__location,
	.article__lede,
	.reveal {
		opacity: 1 !important;
		transform: none !important;
	}

	.hero-cinematic__title-en,
	.hero-cinematic__title-jp {
		transform: none !important;
	}

	.hero-cinematic__scroll.is-visible {
		opacity: 1 !important;
	}

	.hero-cinematic__scroll span {
		animation: none !important;
	}
}

/* ============================================================
   Legacy components (index, about, contact, privacy, namib-desert)
   — preserved until Step3 propagation
   ============================================================ */

main {
	margin: 0 auto;
	max-width: var(--max-w);
	padding: 3rem 1.25rem 4rem;
}

main h1 {
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 3vw, 2.2rem);
	font-style: italic;
	font-weight: 500;
	letter-spacing: 0.04em;
	line-height: 1.4;
	margin-bottom: 0.75rem;
}

main h2 {
	border-left: 2px solid var(--accent);
	font-size: 1.2rem;
	font-weight: 500;
	letter-spacing: 0.1em;
	margin: 2.75rem 0 1.25rem;
	padding-left: 0.85rem;
}

main p {
	margin-bottom: 1.25rem;
}

table.legal-table {
	border-collapse: collapse;
	font-size: 0.95rem;
	margin: 1.5rem 0;
	width: 100%;
}

table.legal-table th,
table.legal-table td {
	border-bottom: 1px solid var(--border-soft);
	padding: 0.85rem 0.75rem;
	text-align: left;
	vertical-align: top;
}

table.legal-table th {
	color: var(--text-muted);
	font-weight: 400;
	letter-spacing: 0.05em;
	white-space: nowrap;
	width: 30%;
}
