/* ============================================
   KANENAS PICTURES — Design System Overrides
   ============================================
   This file loads AFTER all theme CSS.
   All overrides use specificity or !important
   only where strictly necessary.
   ============================================ */

/* ------------------------------------------
   0. VIDEO INTRO OVERLAY
   ------------------------------------------ */
.intro-overlay {
	position: fixed;
	inset: 0;
	z-index: 10000;
	background: var(--color-background);
	display: flex;
	align-items: center;
	justify-content: center;
	transition: opacity 1s ease, visibility 1s ease;
}

.intro-overlay.done {
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
}

.intro-overlay video {
	max-width: 60vw;
	max-height: 50vh;
	object-fit: contain;
}

/* ------------------------------------------
   1. COLOR PALETTE — Force Kanenas dark
   ------------------------------------------ */
:root,
html[data-color-scheme='dark'],
html[data-color-scheme='light'],
html[data-color-scheme='system'] {
	--ghost-accent-color: #c4956a;
	--color-accent-foreground: #141414;

	--color-background: #141414 !important;
	--color-background-100: #1a1a1a;
	--color-background-200: #1f1f1f;
	--color-background-300: #262626;
	--color-background-400: #2c2c2c;
	--color-background-800: #1a1a1a;
	--color-background-900: #0f0f0f;

	--color-contrast: #e8e0d4;
	--color-contrast-0: #1f1f1f;
	--color-foreground: #e8e0d4;
	--color-secondary: #b5ada5;
	--color-mute: #8a8078;
	--color-border: #1e1a17;
	--color-shadow: rgba(0, 0, 0, 0.5);

	--popup--overlay--background-color: rgba(0, 0, 0, 0.85);
	--shadow: 0 20px 60px -10px rgba(0, 0, 0, 0.7),
		0 4px 20px -8px rgba(0, 0, 0, 0.7);

	color-scheme: dark;

	/* Kanenas extended tokens */
	--color-accent-dim: #d4a87e;
	--color-divider: #1e1a17;
}

/* Force body background — Moment theme variable override fails silently */
body,
html {
	background-color: #141414 !important;
}

/* ------------------------------------------
   2. TYPOGRAPHY
   ------------------------------------------ */
:root {
	--font-family-headings: 'Cormorant Garamond', Georgia, serif;
	--font-family-body: 'Geist', sans-serif;
	--font-family-button: 'Geist', sans-serif;
}

/* Section label utility (for Phase 2+) */
.section-label {
	font-family: var(--font-family-body);
	font-size: clamp(0.95rem, 1vw, 1.05rem);
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
}

/* ------------------------------------------
   2b. AMBIENT AUDIO TOGGLE
   ------------------------------------------ */
.audio-toggle {
	position: fixed;
	bottom: 2.5rem;
	right: 2.5rem;
	z-index: 9998;
	background: rgba(20, 20, 20, 0.75);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	border: 1px solid var(--color-accent-dim);
	border-radius: 24px;
	cursor: pointer;
	display: flex;
	align-items: center;
	gap: 0.6rem;
	padding: 0.6rem 1rem 0.6rem 0.85rem;
	opacity: 0;
	animation: kanenas-revealFade 1.5s ease 3.5s forwards, audioGlow 4s ease-in-out 5s infinite;
	transition: border-color 0.4s ease, opacity 0.4s ease, box-shadow 0.4s ease;
}

.audio-toggle-text {
	font-family: var(--font-family-body);
	font-size: 0.72rem;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	line-height: 1;
	transition: color 0.4s ease;
}

.audio-toggle.playing .audio-toggle-text {
	color: var(--color-accent);
}

.audio-toggle:hover {
	border-color: var(--color-accent);
	box-shadow: 0 0 20px rgba(196, 149, 106, 0.25);
}

.audio-toggle:hover .audio-toggle-text {
	color: var(--color-accent);
}

.audio-bars {
	display: flex;
	align-items: center;
	gap: 2px;
	height: 14px;
}

.audio-bar {
	display: block;
	width: 2.5px;
	background: var(--color-accent-dim);
	border-radius: 1px;
	transition: background-color 0.4s ease;
}

/* Idle state — static low bars */
.audio-bar:nth-child(1) { height: 4px; }
.audio-bar:nth-child(2) { height: 7px; }
.audio-bar:nth-child(3) { height: 5px; }
.audio-bar:nth-child(4) { height: 3px; }

/* Playing state — animated bars */
.audio-toggle.playing .audio-bar {
	background: var(--color-accent);
	animation: audioBarPulse 1.2s ease-in-out infinite;
}

.audio-toggle.playing .audio-bar:nth-child(1) { animation-delay: 0s; }
.audio-toggle.playing .audio-bar:nth-child(2) { animation-delay: 0.15s; }
.audio-toggle.playing .audio-bar:nth-child(3) { animation-delay: 0.3s; }
.audio-toggle.playing .audio-bar:nth-child(4) { animation-delay: 0.45s; }

@keyframes audioBarPulse {
	0%, 100% { height: 3px; }
	50% { height: 14px; }
}

.audio-toggle:hover .audio-bar {
	background: var(--color-accent);
}

@keyframes audioGlow {
	0%, 100% {
		box-shadow: 0 0 8px rgba(196, 149, 106, 0.0);
	}
	50% {
		box-shadow: 0 0 15px rgba(196, 149, 106, 0.18);
	}
}

/* Adjust audio toggle on small screens */
@media (max-width: 480px) {
	.audio-toggle {
		bottom: 1.5rem;
		right: 1.5rem;
		padding: 0.5rem 0.85rem 0.5rem 0.7rem;
		gap: 0.5rem;
	}

	.audio-toggle-text {
		font-size: 0.65rem;
	}
}

/* ------------------------------------------
   3. FILM GRAIN OVERLAY
   ------------------------------------------ */
.grain-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 9999;
	pointer-events: none;
	opacity: 0.035;
	mix-blend-mode: overlay;
}

@media (prefers-reduced-motion: reduce) {
	.grain-overlay {
		display: none;
	}
}

/* ------------------------------------------
   4. DIVIDERS
   ------------------------------------------ */
.kanenas-divider {
	border: none;
	height: 1px;
	background: linear-gradient(
		to right,
		transparent,
		var(--color-divider),
		transparent
	);
}

/* ------------------------------------------
   5. STRIP: Hide unwanted Moment elements
   ------------------------------------------ */

/* Color scheme toggle */
.toggle-color-scheme-button {
	display: none !important;
}

/* Announcement bar */
#announcement-bar-root {
	display: none !important;
}

/* "Published with Ghost & Moment" in footer */
.footer-copyright span {
	display: none;
}

/* Social share buttons on posts */
.post-share {
	display: none !important;
}

/* Scroll-to-explore label (Moment default) */
.scroll-to-explore {
	display: none !important;
}

/* ------------------------------------------
   6. BUTTON OVERRIDES
   ------------------------------------------ */
:root {
	--button--color: #141414;
	--button--background-color: #c4956a;
	--button-hover--color: #141414;
	--button-hover--background-color: #d4a57a;
	--button--border-radius: 0;
	--button-sm--border-radius: 0;
	--button-xs--border-radius: 0;
}

/* ------------------------------------------
   7. LINK OVERRIDES
   ------------------------------------------ */
a {
	color: var(--color-accent-dim);
}

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

/* ============================================
   8. HOMEPAGE — LAYER 1: THE FEELING
   ============================================ */
.layer-feeling {
	position: relative;
	height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	overflow: hidden;
}

.hero-atmosphere {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.hero-atmosphere picture {
	position: absolute;
	inset: 0;
	overflow: visible;
}

.hero-bg-image {
	position: absolute;
	inset: -10%;
	width: 120%;
	height: 120%;
	max-width: none;
	object-fit: cover;
	object-position: center 40%;
	opacity: 0;
	animation: kenBurnsReveal 3s cubic-bezier(0.22, 1, 0.36, 1) 0.3s forwards,
	           kenBurnsDrift 28s ease-in-out infinite 0.3s;
	will-change: transform, opacity;
	pointer-events: none;
}

@keyframes kenBurnsReveal {
	to { opacity: 0.78; }
}

@keyframes kenBurnsDrift {
	0%   { transform: scale(1)    translate(0, 0); }
	50%  { transform: scale(1.06) translate(-0.5%, 0.3%); }
	100% { transform: scale(1)    translate(0, 0); }
}

.hero-bg-overlay {
	position: absolute;
	inset: 0;
	z-index: 1;
	background:
		radial-gradient(ellipse at 50% 45%, transparent 45%, rgba(20,20,20,0.25) 70%, rgba(20,20,20,0.7) 100%),
		linear-gradient(180deg, rgba(20,20,20,0.1) 0%, transparent 30%, transparent 70%, rgba(20,20,20,0.4) 100%);
	pointer-events: none;
}

.hero-atmosphere .atmos-layer {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 60% 35%, rgba(42,31,20,0.3) 0%, transparent 55%),
		radial-gradient(ellipse at 25% 70%, rgba(26,21,16,0.25) 0%, transparent 45%),
		radial-gradient(ellipse at 80% 75%, rgba(20,18,14,0.2) 0%, transparent 50%);
	will-change: transform;
	transition: transform 0.15s ease-out;
}

.hero-atmosphere::after {
	content: '';
	position: absolute;
	top: 15%;
	right: 20%;
	width: 35vw;
	height: 35vw;
	background: radial-gradient(ellipse, rgba(196,149,106,0.05) 0%, transparent 70%);
	animation: kanenas-breathe 9s ease-in-out infinite;
}

@keyframes kanenas-breathe {
	0%, 100% { opacity: 0.3; transform: scale(1); }
	50% { opacity: 1; transform: scale(1.15); }
}

.hero-logo-group {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0;
	opacity: 0;
	animation: kanenas-revealFade 2s cubic-bezier(0.22, 1, 0.36, 1) 0.8s forwards;
}

.hero-production-label {
	font-family: var(--font-family-body);
	font-size: clamp(1.05rem, 1.3vw, 1.2rem);
	font-weight: 400;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--color-foreground);
	margin-bottom: 0.3rem;
	opacity: 0.85;
	text-shadow: 0 1px 16px rgba(0,0,0,0.9), 0 0 40px rgba(0,0,0,0.6), 0 0 8px rgba(0,0,0,0.8);
}
.hero-production-sublabel {
	font-family: var(--font-family-headings);
	font-size: clamp(1.05rem, 1.3vw, 1.2rem);
	font-weight: 400;
	font-style: italic;
	letter-spacing: 0.25em;
	color: var(--color-foreground);
	margin-bottom: 1.5rem;
	opacity: 0.7;
	text-shadow: 0 1px 12px rgba(0,0,0,0.8), 0 0 30px rgba(0,0,0,0.4);
}

.hero-title {
	font-family: var(--font-family-headings);
	font-weight: 400;
	font-size: clamp(2.2rem, 5vw, 4.5rem);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-foreground);
	line-height: 1;
	white-space: nowrap;
	text-shadow: 0 2px 20px rgba(0,0,0,0.8), 0 0 40px rgba(0,0,0,0.5);
}

.hero-title-logo {
	width: clamp(280px, 50vw, 600px);
	height: auto;
	display: block;
	filter: drop-shadow(0 2px 20px rgba(0,0,0,0.6)) drop-shadow(0 0 40px rgba(0,0,0,0.4));
}

.hero-divider-line {
	width: 100%;
	height: 1px;
	background: var(--color-secondary);
	margin: 0.15em 0 0 0;
	opacity: 0.6;
}

.hero-reflection {
	font-family: var(--font-family-headings);
	font-weight: 400;
	font-size: clamp(2.2rem, 5vw, 4.5rem);
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-mute);
	line-height: 1;
	transform: scaleY(-1);
	mask-image: linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 75%);
	-webkit-mask-image: linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, rgba(0,0,0,0) 75%);
	filter: blur(0.5px);
	animation: kanenas-waterRipple 4s ease-in-out infinite;
	position: relative;
	overflow: hidden;
}

@keyframes kanenas-waterRipple {
	0%, 100% { letter-spacing: 0.18em; filter: blur(0.5px); }
	25% { letter-spacing: 0.185em; filter: blur(0.8px); }
	50% { letter-spacing: 0.178em; filter: blur(1px); }
	75% { letter-spacing: 0.183em; filter: blur(0.6px); }
}

.hero-tagline {
	position: relative;
	z-index: 2;
	font-family: var(--font-family-headings);
	font-weight: 300;
	font-size: clamp(1.25rem, 2.2vw, 1.65rem);
	color: var(--color-secondary);
	letter-spacing: 0.06em;
	margin-top: 4rem;
	opacity: 0;
	animation: kanenas-revealFade 1.5s ease 2s forwards;
	text-shadow: 0 2px 16px rgba(0,0,0,0.8), 0 0 30px rgba(0,0,0,0.4);
}

.scroll-indicator {
	position: absolute;
	bottom: 4vh;
	left: 50%;
	transform: translateX(-50%);
	z-index: 2;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8px;
	opacity: 0;
	animation: kanenas-revealFade 1s ease 3s forwards;
}

.scroll-indicator span {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--color-mute);
	text-shadow: 0 1px 10px rgba(0,0,0,0.6);
}

.scroll-line {
	width: 1px;
	height: 40px;
	background: linear-gradient(180deg, var(--color-accent-dim), transparent);
	animation: kanenas-scrollPulse 2.5s ease-in-out infinite, scrollBob 2s ease-in-out infinite;
}

@keyframes scrollBob {
	0%, 100% { transform: translateY(0); }
	50% { transform: translateY(6px); }
}

@keyframes kanenas-scrollPulse {
	0%, 100% { opacity: 0.2; }
	50% { opacity: 0.7; }
}

@keyframes kanenas-revealFade {
	to { opacity: 1; }
}

/* Member variant — link behavior, same visual */
a.scroll-indicator-member {
	text-decoration: none;
	cursor: pointer;
	transition: opacity 0.4s ease;
}

a.scroll-indicator-member:hover {
	opacity: 0.7;
}

a.scroll-indicator-member span {
	color: var(--color-accent-dim);
	transition: color 0.4s ease;
}

a.scroll-indicator-member:hover span {
	color: var(--color-accent);
}

/* ============================================
   9. HOMEPAGE — LAYER 2: THE PROOF
   ============================================ */
.layer-proof {
	position: relative;
	padding: 15vh 8vw;
	min-height: 100vh;
	display: flex;
	flex-direction: column;
	justify-content: center;
}

.layer-proof::before {
	content: '';
	position: absolute;
	top: 0;
	left: 15%;
	right: 15%;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-divider), transparent);
}

.proof-grid {
	display: grid;
	grid-template-columns: 1fr 1px 1fr;
	gap: 0 5vw;
	max-width: 1100px;
	align-items: start;
}

.proof-left {
	padding-right: 2vw;
}

.proof-divider {
	background: linear-gradient(180deg, var(--color-divider), transparent);
	height: 100%;
	min-height: 300px;
}

.proof-right {
	padding-left: 2vw;
}

.logline {
	font-family: var(--font-family-headings);
	font-size: clamp(1.3rem, 2.3vw, 1.8rem);
	font-weight: 400;
	line-height: 1.7;
	color: var(--color-foreground);
	margin-bottom: 2rem;
}

.proof-credit {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-secondary);
	margin-bottom: 3rem;
	letter-spacing: 0.03em;
}

.comparables {
	display: flex;
	gap: 2rem;
	flex-wrap: wrap;
}

.comparable-item {
	display: flex;
	flex-direction: column;
	gap: 0.3rem;
}

.comparable-label {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-secondary);
}

.comparable-title {
	font-family: var(--font-family-headings);
	font-style: italic;
	font-size: 1rem;
	color: var(--color-secondary);
}

/* Story Room Preview — "Overheard" approach */
.storyroom-preview {
	position: relative;
}

.overheard-questions {
	display: flex;
	flex-direction: column;
	gap: 0;
	margin-bottom: 2.5rem;
	position: relative;
	overflow: hidden;
	min-height: 280px;
}

.overheard-q {
	font-family: var(--font-family-headings);
	font-style: italic;
	font-size: clamp(1rem, 1.6vw, 1.15rem);
	line-height: 1.5;
	padding: 0.85rem 0;
	border-bottom: 1px solid var(--color-divider);
	color: var(--color-secondary);
	opacity: 0;
	transform: translateY(10px);
	transition: all 0.8s cubic-bezier(0.22, 1, 0.36, 1);
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.overheard-q.visible {
	opacity: 1;
	transform: translateY(0);
}

.overheard-q .q-status {
	font-family: var(--font-family-body);
	font-style: italic;
	font-size: 0.95rem;
	font-weight: 600;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	white-space: nowrap;
	padding-left: 1rem;
}

.answer-tease {
	position: relative;
	padding: 1.5rem 0;
	margin-bottom: 2rem;
}

.answer-tease-label {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-bottom: 0.8rem;
}

.answer-tease-text {
	font-family: var(--font-family-headings);
	font-size: 1.1rem;
	line-height: 1.8;
	color: var(--color-secondary);
}

.answer-tease-text .visible-part {
	opacity: 0.8;
}

.answer-tease-text .blurred-part {
	filter: blur(5px);
	user-select: none;
	opacity: 0.4;
}

.storyroom-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	font-family: var(--font-family-body);
	font-size: 1rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--ghost-accent-color);
	text-decoration: none;
	padding: 1rem 2rem;
	border: 1px solid var(--color-accent-dim);
	margin-top: 1.5rem;
	transition: all 0.4s ease;
}

.storyroom-cta:hover {
	background: var(--color-accent-dim);
	color: var(--color-background);
}

.storyroom-cta svg {
	width: 16px;
	height: 16px;
	stroke: currentColor;
	transition: transform 0.3s ease;
}

.storyroom-cta:hover svg {
	transform: translateX(4px);
}

.storyroom-pulse {
	margin-top: 2rem;
	display: flex;
	align-items: center;
	gap: 8px;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	letter-spacing: 0.1em;
	color: var(--color-mute);
}

.pulse-dot {
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--color-accent-dim);
	animation: kanenas-pulseDot 3s ease-in-out infinite;
}

@keyframes kanenas-pulseDot {
	0%, 100% { opacity: 0.3; }
	50% { opacity: 1; }
}

/* ============================================
   10. HOMEPAGE — LAYER 3: THE INVITATION
   ============================================ */
.layer-invitation {
	position: relative;
	padding: 14vh 8vw 16vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
}

.layer-invitation::before {
	content: '';
	position: absolute;
	top: 0;
	left: 15%;
	right: 15%;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-divider), transparent);
}

.invitation-status {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.4em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-bottom: 3rem;
	display: inline-flex;
	align-items: center;
	gap: 10px;
}

.invitation-status::before {
	content: '';
	width: 5px;
	height: 5px;
	border-radius: 50%;
	background: var(--color-accent-dim);
	animation: kanenas-pulseDot 3s ease-in-out infinite;
}

.invitation-heading {
	font-family: var(--font-family-headings);
	font-size: clamp(1.6rem, 3.2vw, 2.6rem);
	font-weight: 300;
	line-height: 1.45;
	color: var(--color-foreground);
	max-width: 550px;
	margin-bottom: 1.5rem;
}

.invitation-sub {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	color: var(--color-secondary);
	max-width: 420px;
	line-height: 1.75;
	margin-bottom: 3.5rem;
}

.access-form {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1.8rem;
	max-width: 340px;
	width: 100%;
	background: transparent;
	border-radius: 0;
	padding: 0;
}

.access-form input[type="email"] {
	width: 100%;
	background: transparent;
	border: none;
	border-bottom: 1px solid var(--color-divider);
	padding: 0.8rem 0.2rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	color: var(--color-foreground);
	outline: none;
	transition: border-color 0.5s ease;
	letter-spacing: 0.04em;
	text-align: center;
	border-radius: 0;
	appearance: none;
	-webkit-appearance: none;
}

.access-form input[type="email"]::placeholder {
	color: var(--color-mute);
	transition: opacity 0.3s ease;
}

.access-form input[type="email"]:focus::placeholder {
	opacity: 0.4;
}

.access-form input[type="email"]:focus {
	border-color: var(--color-accent-dim);
}

.access-form button {
	background: transparent;
	border: 1px solid var(--color-accent-dim);
	padding: 0.85rem 2.4rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--color-accent);
	cursor: pointer;
	transition: all 0.5s cubic-bezier(0.22, 1, 0.36, 1);
	white-space: nowrap;
	border-radius: 0;
}

.access-form button:hover {
	background: var(--color-accent-dim);
	border-color: var(--color-accent-dim);
	color: var(--color-background);
}

.access-form .btn-label {
	display: none;
}

.access-form .btn-default {
	display: inline;
}

.access-form.loading .btn-default {
	display: none;
}

.access-form.loading .btn-loading {
	display: inline;
}

.access-form.success .btn-default,
.access-form.success .btn-loading {
	display: none;
}

.access-form.success .btn-success {
	display: inline;
}

.access-form-message {
	margin-top: 1rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
}

.access-form-message .msg-success {
	display: none;
	color: var(--color-accent-dim);
}

.access-form-message .msg-error {
	display: none;
	color: #c34d4d;
}

.access-form.success ~ .access-form-message .msg-success {
	display: block;
}

.access-form.error ~ .access-form-message .msg-error {
	display: block;
}

.invitation-note {
	margin-top: 1.2rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	color: var(--color-secondary);
}

.storyroom-enter-link {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.15em;
	text-transform: uppercase;
	color: var(--ghost-accent-color);
	text-decoration: none;
	padding: 1rem 2rem;
	border: 1px solid var(--color-accent-dim);
	transition: all 0.4s ease;
}

.storyroom-enter-link:hover {
	background: var(--color-accent-dim);
	color: var(--color-background);
}

.storyroom-enter-link svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	transition: transform 0.3s ease;
}

.storyroom-enter-link:hover svg {
	transform: translateX(3px);
}

/* ============================================
   11. HOMEPAGE — FOOTER
   ============================================ */
.kanenas-footer {
	padding: 5vh 8vw;
	text-align: center;
}

.footer-mark {
	font-family: var(--font-family-headings);
	font-size: 0.95rem;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--color-mute);
	opacity: 0.5;
}

.footer-tagline {
	font-family: var(--font-family-headings);
	font-size: 0.95rem;
	font-weight: 300;
	font-style: italic;
	letter-spacing: 0.08em;
	color: var(--color-mute);
	opacity: 0.4;
	margin-top: 0.4rem;
}

.footer-signout {
	display: inline-block;
	margin-top: 1.5rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-mute);
	text-decoration: none;
	opacity: 0.6;
	transition: opacity 0.4s ease, color 0.4s ease;
}

.footer-signout:hover {
	opacity: 0.8;
	color: var(--color-secondary);
}

.footer-legal {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0.15em;
	color: var(--color-mute);
	margin-top: 2.5rem;
}

.footer-signin {
	display: inline-block;
	margin-top: 2.5rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: var(--color-mute);
	text-decoration: none;
	opacity: 0.7;
	transition: opacity 0.4s ease, color 0.4s ease;
	cursor: pointer;
}

.footer-signin:hover {
	opacity: 0.9;
	color: var(--color-secondary);
}

/* ============================================
   12. SCROLL REVEAL SYSTEM
   ============================================ */
.reveal {
	opacity: 0;
	transform: translateY(30px);
	transition: all 0.9s cubic-bezier(0.22, 1, 0.36, 1);
}

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

.reveal-delay-1 { transition-delay: 0.15s; }
.reveal-delay-2 { transition-delay: 0.3s; }
.reveal-delay-3 { transition-delay: 0.45s; }
.reveal-delay-4 { transition-delay: 0.6s; }

/* ============================================
   13. HOMEPAGE RESPONSIVE
   ============================================ */
@media (max-width: 768px) {
	.proof-grid {
		grid-template-columns: 1fr;
		gap: 5rem;
	}

	.proof-divider {
		display: none;
	}

	.proof-left,
	.proof-right {
		padding: 0;
	}

	.access-form {
		max-width: 300px;
	}

	.access-form input[type="email"] {
		font-size: 0.95rem;
	}

	.hero-title,
	.hero-reflection {
		font-size: clamp(1.6rem, 7vw, 2.8rem);
		white-space: normal;
		text-align: center;
	}

	.hero-title-logo {
		width: clamp(240px, 75vw, 400px);
	}

	.hero-bg-image {
		opacity: 0;
		animation: kenBurnsReveal 3s cubic-bezier(0.22, 1, 0.36, 1) 0.3s forwards,
		           kenBurnsDrift 28s ease-in-out infinite 0.3s;
		object-position: 55% center;
	}

	@keyframes kenBurnsReveal {
		to { opacity: 0.55; }
	}

	.hero-bg-overlay {
		background:
			radial-gradient(ellipse at 50% 40%, transparent 25%, rgba(20,20,20,0.3) 50%, rgba(20,20,20,0.8) 100%),
			linear-gradient(180deg, rgba(20,20,20,0.25) 0%, transparent 25%, transparent 60%, rgba(20,20,20,0.55) 100%);
	}

	.overheard-questions {
		min-height: auto;
	}

	.layer-proof {
		padding: 8vh 6vw 6vh;
	}

	.layer-invitation {
		padding: 6vh 6vw 10vh;
	}

	.storyroom-cta {
		font-size: 0.95rem;
		padding: 0.85rem 1.5rem;
	}
}

/* ============================================
   14. ERROR PAGE
   ============================================ */
.error-page {
	min-height: 80vh;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	padding: 8vh 8vw;
}

.error-label {
	font-family: var(--font-family-headings);
	font-size: clamp(4rem, 10vw, 8rem);
	font-weight: 300;
	color: var(--color-foreground);
	opacity: 0.08;
	line-height: 1;
	margin-bottom: 1rem;
}

.error-heading {
	font-family: var(--font-family-headings);
	font-size: clamp(1.2rem, 2.5vw, 1.8rem);
	font-weight: 300;
	color: var(--color-foreground);
	opacity: 0.6;
	margin-bottom: 3rem;
}

.error-home-link {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	padding-bottom: 0.3rem;
	transition: all 0.4s ease;
}

.error-home-link:hover {
	color: var(--color-accent);
	border-color: var(--color-accent-dim);
}

.error-home-link svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	transition: transform 0.3s ease;
}

.error-home-link:hover svg {
	transform: translateX(-3px);
}

/* ============================================
   15. CURSOR PILL — Cinematic override
   ============================================ */
.cursor {
	background-color: rgba(14, 14, 14, 0.92) !important;
	color: var(--color-foreground) !important;
	border: 1px solid var(--color-divider);
	font-family: var(--font-family-body);
	font-weight: 300;
	letter-spacing: 0.08em;
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
}

/* ============================================
   16. VIEW TRANSITIONS — Cinematic override
   ============================================ */
@media (prefers-reduced-motion: no-preference) {
	::view-transition-old(root) {
		animation-duration: 0.8s;
		animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
	}

	::view-transition-new(root) {
		animation-duration: 0.8s;
		animation-timing-function: cubic-bezier(0.22, 1, 0.36, 1);
	}
}

/* ============================================
   16. REDUCED MOTION
   ============================================ */
@media (prefers-reduced-motion: reduce) {
	.hero-logo-group,
	.hero-tagline,
	.scroll-indicator {
		opacity: 1;
		animation: none;
	}

	.hero-reflection {
		animation: none;
	}

	.hero-atmosphere::after {
		animation: none;
	}

	.hero-bg-image {
		animation: none;
		opacity: 0.5;
	}

	.scroll-line {
		animation: none;
		opacity: 0.5;
	}

	.pulse-dot,
	.invitation-status::before {
		animation: none;
		opacity: 0.6;
	}

	.reveal {
		opacity: 1;
		transform: none;
		transition: none;
	}

	.overheard-q {
		opacity: 1;
		transform: none;
		transition: none;
	}

	.exchange {
		opacity: 1;
		transform: none;
		transition: none;
	}

	/* Scroll hero: show first frame statically, no scroll animation */
	.kp-hero-scroll {
		height: auto;
	}

	.kp-hero-scroll-sticky {
		position: relative;
		height: 100vh;
	}

	#kpScrollCanvas {
		opacity: 1;
		transition: none;
	}

	.kp-scroll-pictures {
		opacity: 1;
		transition: none;
	}

}

/* ============================================
   15. STORY ROOM — Gated Page
   ============================================ */
.layer-storyroom {
	position: relative;
	padding: 8vh 8vw 12vh;
	background: var(--color-background-100);
	min-height: 80vh;
	overflow: hidden;
}

.layer-storyroom::after {
	content: '';
	position: absolute;
	inset: 0;
	background: url('../images/storyroom-warmth.jpg') center/cover no-repeat;
	opacity: 0.12;
	z-index: 0;
	pointer-events: none;
}

.layer-storyroom::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100px;
	background: linear-gradient(180deg, var(--color-background), var(--color-background-100));
	pointer-events: none;
	z-index: 1;
}

.storyroom-container {
	position: relative;
	z-index: 1;
	max-width: 640px;
	margin: 0 auto;
	padding-top: 6vh;
}

.storyroom-header {
	position: relative;
	text-align: center;
	margin-bottom: 4rem;
	padding-top: 12rem;
	padding-bottom: 5rem;
	overflow: visible;
}

.storyroom-hero-image {
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 100vw;
	z-index: 0;
	overflow: hidden;
}

.storyroom-hero-img {
	width: 100%;
	height: 100%;
	max-width: none;
	object-fit: cover;
	object-position: center 20%;
	opacity: 0;
	filter: saturate(0.7);
	animation: storyroomReveal 2.5s cubic-bezier(0.22, 1, 0.36, 1) 0.3s forwards;
}

@keyframes storyroomReveal {
	to { opacity: 0.50; }
}

.storyroom-hero-overlay {
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 50% 35%, transparent 30%, rgba(20,20,20,0.35) 55%, rgba(20,20,20,0.88) 100%),
		linear-gradient(180deg, rgba(20,20,20,0.1) 0%, transparent 25%, transparent 55%, rgba(20,20,20,0.88) 100%);
}

.storyroom-header .storyroom-label,
.storyroom-header .storyroom-title {
	position: relative;
	z-index: 1;
	text-shadow: 0 2px 20px rgba(0,0,0,0.9), 0 0 40px rgba(0,0,0,0.5);
}

.storyroom-label {
	font-family: var(--font-family-body);
	font-size: 1.05rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.4em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-bottom: 1.2rem;
}

.storyroom-title {
	font-family: var(--font-family-headings);
	font-size: clamp(1.5rem, 2.8vw, 2rem);
	font-weight: 300;
	color: var(--color-foreground);
}

.storyroom-exchanges {
	display: flex;
	flex-direction: column;
	gap: 2.5rem;
	padding-bottom: 1rem;
}

.exchange {
	opacity: 0;
	transform: translateY(15px);
	transition: all 0.7s cubic-bezier(0.22, 1, 0.36, 1);
	scroll-margin-bottom: 2rem;
	scroll-margin-top: 5rem;
	padding: 1.2rem 0;
	border-left: 1.5px solid transparent;
	padding-left: 1rem;
}

.exchange.visible {
	opacity: 1;
	transform: translateY(0);
}

.exchange.exchange-active {
	border-left-color: var(--color-accent-dim);
	background: linear-gradient(90deg, rgba(196, 149, 106, 0.04) 0%, transparent 60%);
	transition: all 0.5s ease;
}

.exchange-q {
	font-family: var(--font-family-body);
	font-size: 1.1rem;
	font-weight: 400;
	color: var(--color-accent);
	margin-bottom: 0.8rem;
	scroll-margin-top: 6rem;
}

.exchange-a {
	font-family: var(--font-family-headings);
	font-size: 1.4rem;
	font-weight: 400;
	scroll-margin-bottom: 6rem;
	line-height: 1.85;
	color: var(--color-foreground);
	opacity: 0.88;
}

.exchange-a .word-reveal {
	opacity: 0;
	transform: translateY(4px);
	display: inline;
	transition: opacity 0.4s ease, transform 0.4s ease;
}

.exchange-a .word-reveal.visible {
	opacity: 1;
	transform: translateY(0);
}

.storyroom-input-area {
	margin-top: 3.5rem;
	padding-top: 2.5rem;
	border-top: 1px solid var(--color-divider);
}

.storyroom-input-wrapper {
	display: flex;
	gap: 0;
}

.storyroom-input {
	flex: 1;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--color-mute);
	border-right: none;
	padding: 1.3rem 1.6rem;
	font-family: var(--font-family-headings);
	font-size: 1.35rem;
	font-style: italic;
	color: var(--color-foreground);
	outline: none;
	transition: border-color 0.4s ease, box-shadow 0.4s ease;
	border-radius: 0;
	appearance: none;
	-webkit-appearance: none;
}

.storyroom-input::placeholder {
	color: var(--color-secondary);
	font-style: italic;
}

.storyroom-input:focus {
	border-color: var(--color-accent-dim);
	box-shadow: 0 0 20px rgba(196, 149, 106, 0.08), inset 0 0 12px rgba(196, 149, 106, 0.03);
}

.storyroom-input:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.storyroom-submit {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid var(--color-mute);
	padding: 1.3rem 1.6rem;
	cursor: pointer;
	transition: border-color 0.4s ease, box-shadow 0.4s ease;
	display: flex;
	align-items: center;
	border-radius: 0;
}

.storyroom-input-wrapper:focus-within .storyroom-submit {
	border-color: var(--color-accent-dim);
	box-shadow: 0 0 20px rgba(196, 149, 106, 0.08);
}

.storyroom-submit:hover:not(:disabled) {
	border-color: var(--color-accent-dim);
}

.storyroom-submit:disabled {
	opacity: 0.4;
	cursor: not-allowed;
}

.storyroom-submit svg {
	width: 20px;
	height: 20px;
	stroke: var(--color-mute);
	transition: stroke 0.3s ease;
}

.storyroom-submit:hover:not(:disabled) svg {
	stroke: var(--color-accent);
}

.storyroom-input-note {
	margin-top: 1.2rem;
	font-family: var(--font-family-body);
	font-size: 1.1rem;
	font-weight: 400;
	color: var(--color-secondary);
	letter-spacing: 0.02em;
	font-style: italic;
}

/* Story Room typing indicator */
.exchange-typing {
	min-height: 2.5rem;
	display: flex;
	align-items: center;
}

.typing-dots {
	display: inline-flex;
	gap: 7px;
	align-items: center;
	padding: 0.5rem 0;
}

.typing-dots span {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: var(--color-accent);
	animation: typingBreathe 2s ease-in-out infinite;
}

.typing-dots span:nth-child(2) {
	animation-delay: 0.35s;
}

.typing-dots span:nth-child(3) {
	animation-delay: 0.7s;
}

@keyframes typingBreathe {
	0%, 100% { opacity: 0.15; transform: scale(0.9); }
	50% { opacity: 1; transform: scale(1.2); }
}

/* Story Room — separator between interactive and static content */
.storyroom-static-separator {
	max-width: 640px;
	margin: 5rem auto 0;
	padding-top: 4rem;
	border-top: 1px solid var(--color-divider);
	text-align: center;
}

.storyroom-static-label {
	font-family: var(--font-family-body);
	font-size: 1.05rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.4em;
	text-transform: uppercase;
	color: var(--color-mute);
}

/* Story Room content sections (member) */
.storyroom-section {
	position: relative;
	z-index: 1;
	max-width: 640px;
	margin: 0 auto;
	padding-top: 4rem;
}

.storyroom-section-divider {
	width: 40px;
	height: 1px;
	background: linear-gradient(90deg, var(--color-divider), transparent);
	margin-bottom: 2.5rem;
}

.storyroom-section-label {
	font-family: var(--font-family-body);
	font-size: 1.05rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.4em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-bottom: 1.8rem;
}

.storyroom-section-body {
	font-family: var(--font-family-headings);
	font-size: 1.4rem;
	font-weight: 400;
	line-height: 1.9;
	color: var(--color-foreground);
	opacity: 0.88;
}

.storyroom-section-body p {
	margin-bottom: 1.4rem;
}

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

.storyroom-section-letter {
	font-style: italic;
	opacity: 0.7;
}

.storyroom-section-closing {
	margin-top: 0.6rem;
	font-style: italic;
	color: var(--color-accent-dim);
}

/* Story Room gate (non-member) */
.layer-storyroom-gate {
	padding: 8vh 8vw 12vh;
	min-height: 60vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.storyroom-gate-link {
	display: inline-flex;
	align-items: center;
	gap: 0.7rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	padding-bottom: 0.3rem;
	transition: all 0.4s ease;
}

.storyroom-gate-link:hover {
	color: var(--color-accent);
	border-color: var(--color-accent-dim);
}

.storyroom-gate-link svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	transition: transform 0.3s ease;
}

.storyroom-gate-link:hover svg {
	transform: translateX(3px);
}

/* Story Room responsive */
@media (max-width: 768px) {
	.layer-storyroom {
		padding: 6vh 6vw 10vh;
	}

	.storyroom-container {
		padding-top: 4vh;
	}

	.exchange {
		padding-left: 0.8rem;
	}

	.exchange-a {
		font-size: 1.25rem;
	}

	.storyroom-section-body {
		font-size: 1.25rem;
	}

	.storyroom-input {
		font-size: 1.15rem;
		padding: 1.1rem 1.2rem;
	}

	.storyroom-static-separator {
		margin-top: 3rem;
		padding-top: 3rem;
	}
}

/* ------------------------------------------
   10. NAVIGATION
   ------------------------------------------ */
.kp-nav {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.2rem 4vw;
	background: transparent;
	transition: background 0.6s ease, padding 0.4s ease;
}

.kp-nav.scrolled {
	background: rgba(20, 20, 20, 0.92);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	padding: 0.8rem 4vw;
}

.kp-nav-logo {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-decoration: none;
	line-height: 1;
	gap: 0;
	opacity: 0.7;
	transition: opacity 0.3s ease;
}

.kp-nav-logo:hover {
	opacity: 1;
}

.kp-nav-logo-text {
	font-family: var(--font-family-headings);
	font-size: 0.95rem;
	font-weight: 300;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-foreground);
}

.kp-nav-logo-reflection {
	font-family: var(--font-family-headings);
	font-size: 0.95rem;
	font-weight: 300;
	letter-spacing: 0.18em;
	text-transform: uppercase;
	color: var(--color-foreground);
	transform: scaleY(-1);
	mask-image: linear-gradient(to bottom, rgba(255,255,255,0.2), transparent 70%);
	-webkit-mask-image: linear-gradient(to bottom, rgba(255,255,255,0.2), transparent 70%);
	opacity: 0.25;
	margin-top: -2px;
	height: 0.6rem;
	overflow: hidden;
	animation: navWaterDrift 7s ease-in-out infinite;
	will-change: transform, opacity;
	pointer-events: none;
	user-select: none;
}

@keyframes navWaterDrift {
	0%, 100% { transform: scaleY(-1) translateY(0) scaleX(1); opacity: 0.25; }
	30% { transform: scaleY(-1) translateY(0.5px) scaleX(1.003); opacity: 0.2; }
	60% { transform: scaleY(-1) translateY(-0.3px) scaleX(0.998); opacity: 0.28; }
	85% { transform: scaleY(-1) translateY(0.2px) scaleX(1.001); opacity: 0.22; }
}

.kp-nav-logo-sub {
	font-family: var(--font-family-body);
	font-size: 0.45rem;
	font-weight: 400;
	letter-spacing: 0.45em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-top: 1px;
}

.kp-nav-links {
	display: flex;
	gap: 2.5rem;
}

.kp-nav-links a {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0.2em;
	text-transform: uppercase;
	color: var(--color-secondary);
	text-decoration: none;
	transition: color 0.3s ease;
}

.kp-nav-links a:hover {
	color: var(--color-foreground);
}

.nav-short {
	display: none;
}

/* ------------------------------------------
   11. COMPANY HOMEPAGE — SCROLL-DRIVEN HERO
   ------------------------------------------ */
.kp-hero-scroll {
	position: relative;
	height: 230vh;
	background: var(--color-background);
}

.kp-hero-scroll-sticky {
	position: sticky;
	top: 0;
	height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	background: var(--color-background);
}

#kpScrollCanvas {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	opacity: 0;
	transition: opacity 1.5s cubic-bezier(0.22, 1, 0.36, 1);
}

#kpScrollCanvas.loaded {
	opacity: 1;
}

/* "Pictures" — positioned inside sticky container, below canvas center */
.kp-scroll-pictures {
	position: absolute;
	z-index: 2;
	left: 50%;
	top: 58%;
	transform: translateX(-50%) scale(0.92);
	font-family: var(--font-family-headings);
	font-size: clamp(1.2rem, 2.2vw, 1.8rem);
	font-weight: 400;
	letter-spacing: 0.4em;
	text-transform: uppercase;
	color: #c4956a;
	opacity: 0;
	pointer-events: none;
	will-change: transform, opacity;
}

.kp-hero-scroll-sticky .scroll-indicator {
	animation: none;
	opacity: 1;
}

/* Keep old classes for other pages that may use them */
.kp-logo-pictures {
	font-family: var(--font-family-body);
	font-size: clamp(0.95rem, 1vw, 1.02rem);
	font-weight: 400;
	letter-spacing: 0.5em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-top: 0.6rem;
	opacity: 0;
	animation: kanenas-revealFade 1.5s cubic-bezier(0.22, 1, 0.36, 1) 1.5s forwards;
}

@keyframes waterDrift {
	0%, 100% { transform: scaleY(-1) translateY(0px) scaleX(1); opacity: 0.3; }
	30% { transform: scaleY(-1) translateY(1.5px) scaleX(1.004); opacity: 0.26; }
	60% { transform: scaleY(-1) translateY(-1px) scaleX(0.997); opacity: 0.33; }
	85% { transform: scaleY(-1) translateY(0.5px) scaleX(1.002); opacity: 0.28; }
}

@keyframes waterShimmer {
	0%, 100% { filter: blur(0px); }
	40% { filter: blur(0.4px); }
	70% { filter: blur(0.2px); }
}

/* ------------------------------------------
   12. COMPANY HOMEPAGE — VISION
   ------------------------------------------ */
.kp-vision {
	position: relative;
	padding: 8vh 8vw;
	display: flex;
	justify-content: center;
}

.kp-vision-inner {
	max-width: 680px;
	text-align: center;
}

.kp-vision-statement {
	font-family: var(--font-family-headings);
	font-size: clamp(1.4rem, 2.5vw, 2rem);
	font-weight: 300;
	line-height: 1.5;
	color: var(--color-foreground);
	margin-top: 2.5rem;
}

.kp-vision-body {
	font-family: var(--font-family-body);
	font-size: clamp(0.95rem, 1.05vw, 1.05rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-secondary);
	margin-top: 2rem;
}

.kp-vision-coda {
	font-family: var(--font-family-headings);
	font-size: clamp(0.9rem, 1.1vw, 1rem);
	font-weight: 300;
	color: var(--color-accent-dim);
	margin-top: 3rem;
	opacity: 0.8;
}

/* ------------------------------------------
   13. COMPANY HOMEPAGE — CURRENT PROJECT (Cinematic Banner)
   ------------------------------------------ */
.kp-project {
	position: relative;
	padding: 5vh 8vw 8vh;
}

.kp-project > .section-label {
	max-width: 1100px;
	margin: 0 auto;
}

.kp-project-banner {
	display: block;
	position: relative;
	margin-top: 3rem;
	max-width: 1100px;
	margin-left: auto;
	margin-right: auto;
	aspect-ratio: 2.4 / 1;
	border-radius: 2px;
	overflow: hidden;
	text-decoration: none;
	cursor: pointer;
}

.kp-project-banner-image {
	position: absolute;
	inset: 0;
}

.kp-project-banner-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center 40%;
	transform: scale(1.02);
	animation: bannerKenBurns 10s ease-in-out infinite alternate;
	will-change: transform;
}

@keyframes bannerKenBurns {
	0% { transform: scale(1.02) translate(0, 0); }
	100% { transform: scale(1.06) translate(-0.5%, -0.3%); }
}

.kp-project-banner-scrim {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		to left,
		rgba(20, 20, 20, 0.85) 0%,
		rgba(20, 20, 20, 0.65) 35%,
		rgba(20, 20, 20, 0.2) 65%,
		rgba(20, 20, 20, 0.08) 100%
	);
	transition: opacity 0.6s ease;
}

.kp-project-banner:hover .kp-project-banner-scrim {
	opacity: 0.85;
}

.kp-project-banner-content {
	position: relative;
	z-index: 2;
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: 100%;
	padding: clamp(2rem, 4vw, 4rem);
	padding-left: 50%;
	box-sizing: border-box;
}

.kp-project-banner-title-logo {
	width: clamp(200px, 28vw, 380px);
	height: auto;
	display: block;
	filter: drop-shadow(0 2px 12px rgba(0,0,0,0.5));
}

.kp-project-banner-title {
	font-family: var(--font-family-headings);
	font-size: clamp(1.6rem, 3vw, 2.8rem);
	font-weight: 300;
	letter-spacing: 0.06em;
	color: var(--color-foreground);
	margin: 0;
	line-height: 1.1;
}

.kp-project-banner-genre {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--color-accent);
	margin-top: 0.8rem;
}

.kp-project-banner-logline {
	font-family: var(--font-family-body);
	font-size: clamp(0.88rem, 1vw, 1rem);
	font-weight: 400;
	line-height: 1.75;
	color: rgba(232, 224, 212, 0.75);
	margin-top: 1.2rem;
	max-width: 420px;
}

.kp-project-banner-cta {
	display: inline-flex;
	align-items: center;
	gap: 0.6rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-top: 2rem;
	transition: color 0.3s ease;
}

.kp-project-banner:hover .kp-project-banner-cta {
	color: var(--color-foreground);
}

.kp-project-banner-cta svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	transition: transform 0.3s ease;
}

.kp-project-banner:hover .kp-project-banner-cta svg {
	transform: translateX(4px);
}

/* ------------------------------------------
   13b. COMPANY HOMEPAGE — CINEMATIC CREDITS
   ------------------------------------------ */
.kp-credits {
	position: relative;
	padding: 6vh 8vw 10vh;
}

.kp-credits-inner {
	max-width: 600px;
	margin: 0 auto;
	text-align: center;
}

.kp-credits-divider {
	width: 60px;
	height: 1px;
	margin: 0 auto 3rem;
	background: linear-gradient(to right, transparent, var(--color-accent-dim), transparent);
}

.kp-credits-divider:last-child {
	margin: 3rem auto 0;
}

.kp-credits-entry {
	margin-bottom: 2.2rem;
}

.kp-credits-entry:last-of-type {
	margin-bottom: 0;
}

.kp-credits-role {
	display: block;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-bottom: 0.4rem;
}

.kp-credits-name {
	display: block;
	font-family: var(--font-family-headings);
	font-size: clamp(1.2rem, 2vw, 1.6rem);
	font-weight: 300;
	letter-spacing: 0.04em;
	color: var(--color-foreground);
}

/* ------------------------------------------
   14. PAGE HERO (About, Contact)
   ------------------------------------------ */
.kp-page-hero {
	position: relative;
	min-height: 40vh;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 0 8vw 5vh;
}

.kp-page-hero-inner {
	text-align: center;
}

.kp-page-heading {
	font-family: var(--font-family-headings);
	font-size: clamp(2rem, 4vw, 3.5rem);
	font-weight: 300;
	letter-spacing: 0.12em;
	color: var(--color-foreground);
	margin-top: 1rem;
}

/* ------------------------------------------
   15. ABOUT — HERO
   ------------------------------------------ */
.kp-about-hero {
	position: relative;
	min-height: 50vh;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	padding: 0 8vw 6vh;
	overflow: hidden;
}

.kp-about-hero-atmosphere {
	position: absolute;
	inset: 0;
	z-index: 0;
}

.kp-about-hero-gradient {
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse 70% 50% at 50% 60%, #1e1c1a 0%, #141414 100%);
}

.kp-about-hero-content {
	position: relative;
	z-index: 2;
	text-align: center;
	max-width: 600px;
}

.kp-about-title {
	font-family: var(--font-family-headings);
	font-size: clamp(2.2rem, 4.5vw, 3.8rem);
	font-weight: 300;
	letter-spacing: 0.12em;
	color: var(--color-foreground);
	margin-top: 1rem;
}

.kp-about-intro {
	font-family: var(--font-family-body);
	font-size: clamp(1.05rem, 1.2vw, 1.15rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-secondary);
	margin-top: 2rem;
}

.kp-about-bridge {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 1rem;
	padding: 6vh 0;
}

.kp-about-bridge-line {
	width: 1px;
	height: 60px;
	background: linear-gradient(180deg, transparent, var(--color-divider), transparent);
}

/* ------------------------------------------
   15b. ABOUT — TEAM (centered vertical cards)
   ------------------------------------------ */
.kp-team {
	position: relative;
	padding: 10vh 8vw 15vh;
}

.kp-team::before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(ellipse at 50% 30%, rgba(196, 149, 106, 0.06) 0%, transparent 70%);
	z-index: 0;
	pointer-events: none;
}

.kp-team-inner {
	position: relative;
	z-index: 1;
	max-width: 700px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 8rem;
}

.kp-team-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	max-width: 400px;
	position: relative;
}

.kp-team-card + .kp-team-card::before {
	content: '';
	position: absolute;
	top: -4rem;
	left: 50%;
	transform: translateX(-50%);
	width: 120px;
	height: 1px;
	background: linear-gradient(90deg, transparent, var(--color-divider), transparent);
}

.kp-team-card:nth-child(2) { transition-delay: 0.15s; }
.kp-team-card:nth-child(3) { transition-delay: 0.3s; }

.kp-team-portrait {
	position: relative;
	margin-bottom: 1.8rem;
}

.kp-team-portrait img {
	width: 240px;
	height: 300px;
	object-fit: cover;
	border-radius: 2px;
	transition: opacity 0.5s ease;
}

.kp-team-portrait::after {
	content: '';
	position: absolute;
	inset: 0;
	border-radius: 2px;
	background: radial-gradient(ellipse 70% 65% at 50% 38%, transparent 40%, var(--color-background) 100%);
	pointer-events: none;
}

.kp-team-card:hover .kp-team-portrait img {
	opacity: 0.85;
}

.kp-team-portrait-placeholder {
	width: 240px;
	height: 300px;
	background: var(--color-background-200);
	border-radius: 2px;
}

.kp-team-portrait-initials {
	width: 240px;
	height: 300px;
	border-radius: 2px;
	background: var(--color-background-200);
	display: flex;
	align-items: center;
	justify-content: center;
}

.kp-team-portrait-initials span {
	font-family: var(--font-family-headings);
	font-size: 2.5rem;
	font-weight: 300;
	letter-spacing: 0.15em;
	color: var(--color-mute);
}

.kp-team-name {
	font-family: var(--font-family-headings);
	font-size: clamp(1.3rem, 2vw, 1.6rem);
	font-weight: 400;
	letter-spacing: 0.06em;
	color: var(--color-foreground);
	margin: 0;
}

.kp-team-role {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-top: 0.6rem;
}

.kp-team-bio {
	font-family: var(--font-family-body);
	font-size: 1.1rem;
	font-weight: 400;
	line-height: 1.7;
	color: var(--color-secondary);
	margin-top: 1.2rem;
	max-width: 420px;
}

.kp-team-imdb {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.25em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	padding-bottom: 0.15rem;
	margin-top: 1rem;
	transition: color 0.3s ease, border-color 0.3s ease;
}

.kp-team-imdb::after {
	content: '';
	width: 12px;
	height: 12px;
	background: currentColor;
	-webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17l9.2-9.2M17 17V7H7'/%3E%3C/svg%3E") center/contain no-repeat;
	mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M7 17l9.2-9.2M17 17V7H7'/%3E%3C/svg%3E") center/contain no-repeat;
	transition: transform 0.3s ease;
}

.kp-team-imdb:hover {
	color: var(--color-accent);
	border-color: var(--color-accent-dim);
}

.kp-team-imdb:hover::after {
	transform: translate(2px, -2px);
}

/* ------------------------------------------
   15c. ABOUT — SECTION LABELS
   ------------------------------------------ */
.kp-team-section-label {
	font-family: var(--font-family-body);
	font-size: 1.05rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.35em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	text-align: center;
	margin-bottom: 5rem;
}

/* ------------------------------------------
   15d. ABOUT — ADVISORY (horizontal card)
   ------------------------------------------ */
.kp-advisory {
	position: relative;
	padding: 0 8vw 15vh;
}

.kp-advisory-inner {
	max-width: 700px;
	margin: 0 auto;
}

.kp-advisory-card {
	display: flex;
	align-items: center;
	gap: 2.5rem;
	max-width: 500px;
	margin: 0 auto;
}

.kp-advisory-portrait {
	flex-shrink: 0;
	position: relative;
}

.kp-advisory-portrait img {
	width: 140px;
	height: 175px;
	object-fit: cover;
	border-radius: 2px;
	transition: opacity 0.5s ease;
}

.kp-advisory-card:hover .kp-advisory-portrait img {
	opacity: 0.85;
}

.kp-advisory-info {
	display: flex;
	flex-direction: column;
}

.kp-advisory-info .kp-team-name {
	font-size: clamp(1.2rem, 1.8vw, 1.5rem);
}

.kp-advisory-info .kp-team-bio {
	margin-top: 0.8rem;
	max-width: none;
	font-size: 1.1rem;
}

/* ------------------------------------------
   16. CONTACT
   ------------------------------------------ */
.kp-contact {
	padding: 5vh 8vw 15vh;
}

.kp-contact-inner {
	max-width: 800px;
	margin: 0 auto;
}

.kp-contact-intro {
	text-align: center;
	margin-bottom: 5rem;
}

.kp-contact-intro p {
	font-family: var(--font-family-body);
	font-size: clamp(1.05rem, 1.2vw, 1.15rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-secondary);
}

.kp-contact-grid {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 3rem;
}

.kp-contact-block {
	padding: 2rem 0;
	border-top: 1px solid var(--color-border);
}

.kp-contact-label {
	font-family: var(--font-family-body);
	font-size: 1.05rem;
	font-weight: 600;
	font-style: italic;
	letter-spacing: 0.3em;
	text-transform: uppercase;
	color: var(--color-accent-dim);
	margin-bottom: 1rem;
}

.kp-contact-block p {
	font-family: var(--font-family-body);
	font-size: 1.1rem;
	font-weight: 400;
	line-height: 1.7;
	color: var(--color-secondary);
	margin-bottom: 1.2rem;
}

.kp-contact-link {
	font-family: var(--font-family-body);
	font-size: 1.05rem;
	font-weight: 400;
	color: var(--color-foreground);
	text-decoration: none;
	border-bottom: 1px solid var(--color-border);
	padding-bottom: 0.2rem;
	transition: border-color 0.3s ease, color 0.3s ease;
}

.kp-contact-link:hover {
	color: var(--color-accent);
	border-color: var(--color-accent-dim);
}

.kp-contact-divider {
	width: 60px;
	height: 1px;
	margin: 0 auto 4rem;
	background: linear-gradient(to right, transparent, var(--color-accent-dim), transparent);
}

.kp-contact-closing {
	text-align: center;
	margin-top: 4rem;
	padding-top: 3rem;
	border-top: 1px solid var(--color-divider);
}

.kp-contact-closing p {
	font-family: var(--font-family-body);
	font-size: clamp(0.88rem, 0.95vw, 0.95rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-muted);
	max-width: 500px;
	margin: 0 auto;
}

/* ------------------------------------------
   18. LEGAL PAGES (Privacy, Terms)
   ------------------------------------------ */
.kp-legal {
	position: relative;
	padding: 5vh 8vw 12vh;
}

.kp-legal-inner {
	max-width: 720px;
	margin: 0 auto;
}

.kp-legal-updated {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	color: var(--color-accent-dim);
	margin-bottom: 4rem;
}

.kp-legal-section {
	margin-bottom: 3rem;
}

.kp-legal-section h2 {
	font-family: var(--font-family-headings);
	font-size: clamp(1.1rem, 1.5vw, 1.4rem);
	font-weight: 300;
	letter-spacing: 0.04em;
	color: var(--color-foreground);
	margin: 0 0 1rem;
}

.kp-legal-section h3 {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	color: var(--color-foreground);
	margin: 1.5rem 0 0.6rem;
}

.kp-legal-section p {
	font-family: var(--font-family-body);
	font-size: clamp(0.9rem, 1vw, 1rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-secondary);
	margin-bottom: 0.8rem;
}

.kp-legal-section ul {
	list-style: none;
	padding: 0;
	margin: 0.8rem 0 1.2rem;
}

.kp-legal-section li {
	font-family: var(--font-family-body);
	font-size: clamp(0.9rem, 1vw, 1rem);
	font-weight: 400;
	line-height: 1.8;
	color: var(--color-secondary);
	padding-left: 1.2rem;
	position: relative;
	margin-bottom: 0.3rem;
}

.kp-legal-section li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.7em;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: var(--color-accent-dim);
}

.kp-legal-section a {
	color: var(--color-accent);
	text-decoration: none;
	border-bottom: 1px solid transparent;
	transition: border-color 0.3s ease;
}

.kp-legal-section a:hover {
	border-color: var(--color-accent-dim);
}

.kp-legal-section strong {
	font-weight: 400;
	color: var(--color-foreground);
}

/* Footer legal links */
.footer-legal-links {
	display: flex;
	justify-content: center;
	gap: 2rem;
	margin-top: 0.8rem;
}

.footer-legal-links a {
	font-family: var(--font-family-body);
	font-size: 0.95rem;
	font-weight: 400;
	letter-spacing: 0.1em;
	color: var(--color-mute);
	text-decoration: none;
	transition: color 0.3s ease;
}

.footer-legal-links a:hover {
	color: var(--color-secondary);
}

/* ------------------------------------------
   19. RESPONSIVE — New pages
   ------------------------------------------ */
@media (max-width: 768px) {
	.kp-nav-links {
		gap: 1.5rem;
	}

	.kp-nav-links a {
		font-size: 0.72rem;
	}

	.nav-full {
		display: none;
	}

	.nav-short {
		display: inline;
	}

	.kp-project-banner {
		aspect-ratio: 3 / 4;
	}

	.kp-project-banner-content {
		padding: clamp(1.5rem, 5vw, 2.5rem);
		justify-content: flex-end;
		padding-bottom: clamp(2rem, 6vw, 3rem);
		padding-left: clamp(1.5rem, 5vw, 2.5rem);
	}

	.kp-project-banner-scrim {
		background: linear-gradient(
			to top,
			rgba(20, 20, 20, 0.95) 0%,
			rgba(20, 20, 20, 0.75) 45%,
			rgba(20, 20, 20, 0.15) 75%,
			rgba(20, 20, 20, 0.05) 100%
		);
	}

	.kp-project-banner-title-logo {
		width: clamp(180px, 55vw, 280px);
	}

	.kp-project-banner-logline {
		max-width: none;
		font-size: 0.95rem;
	}

	.kp-project-banner-title {
		font-size: clamp(1.4rem, 6vw, 2rem);
	}

	.kp-credits {
		padding: 5vh 6vw 8vh;
	}

	.kp-credits-entry {
		margin-bottom: 1.8rem;
	}

	.kp-team-inner {
		gap: 6rem;
	}

	.kp-team-portrait img,
	.kp-team-portrait-placeholder {
		width: 160px;
		height: 200px;
	}

	.kp-advisory-card {
		flex-direction: column;
		text-align: center;
		gap: 1.5rem;
	}

	.kp-advisory-portrait img {
		width: 100px;
		height: 125px;
	}

	.kp-advisory-info {
		align-items: center;
	}

	.kp-about-hero {
		min-height: 40vh;
		padding: 0 6vw 5vh;
	}

	.kp-contact-grid {
		grid-template-columns: 1fr;
	}

	.kp-vision {
		padding: 10vh 6vw;
	}

	.kp-project {
		padding: 5vh 6vw 10vh;
	}
}

@media (max-width: 480px) {
	.kp-nav {
		padding: 1rem 5vw;
	}

	.kp-nav.scrolled {
		padding: 0.6rem 5vw;
	}

	.kp-nav-logo-text {
		font-size: 0.95rem;
	}

	.kp-nav-logo-reflection {
		font-size: 0.95rem;
		height: 0.45rem;
	}

	.kp-nav-logo-sub {
		font-size: 0.35rem;
	}

	.kp-nav-links {
		gap: 1rem;
	}

	.kp-nav-links a {
		font-size: 0.7rem;
		letter-spacing: 0.15em;
	}

	.kp-hero-scroll {
		height: 180vh;
	}
}
