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

body {
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	background: #0f0e0d;
}

/* ─── Header ─────────────────────────────────────────────────────────────── */
.site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	background: rgba(15, 14, 13, 0.88) !important;
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border-bottom: 1px solid transparent;
	transition: border-color 0.4s ease;
}

.site-header.scrolled {
	border-bottom-color: #3a3835;
}

.site-header__inner {
	max-width: 1400px;
	margin-left: auto !important;
	margin-right: auto !important;
}

.site-header .wp-block-site-title a,
.site-header .wp-block-navigation a {
	color: #ede9e3 !important;
	text-decoration: none !important;
}

.site-header .wp-block-navigation a:hover {
	opacity: 0.5;
}

/* ─── Hero ────────────────────────────────────────────────────────────────── */
.hero-post {
	position: relative;
}

.hero-post .wp-block-post-featured-image {
	margin: 0 !important;
	line-height: 0;
}

.hero-post .wp-block-post-featured-image a {
	display: block;
	overflow: hidden;
	line-height: 0;
}

.hero-post .wp-block-post-featured-image img {
	width: 100%;
	display: block;
	transition: transform 0.9s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.hero-post .wp-block-post-featured-image a:hover img {
	transform: scale(1.03);
}

/* Title overlaid on the image, bottom-left */
.hero-post__text {
	position: absolute !important;
	bottom: 0;
	left: 0;
	right: 0;
	padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem) !important;
	background: linear-gradient(
		to top,
		rgba(15, 14, 13, 0.85) 0%,
		rgba(15, 14, 13, 0.4) 50%,
		transparent 100%
	);
}

.hero-post .wp-block-post-title {
	font-family: 'Cormorant Garamond', Georgia, serif !important;
	font-size: clamp(2.5rem, 6vw, 5.5rem) !important;
	font-weight: 300 !important;
	line-height: 1.0 !important;
	letter-spacing: -0.02em !important;
	color: #ede9e3 !important;
	margin-bottom: 0.5rem !important;
}

.hero-post .wp-block-post-title a {
	color: #ede9e3 !important;
	text-decoration: none !important;
	transition: opacity 0.3s ease;
}

.hero-post .wp-block-post-title a:hover { opacity: 0.7; }

.hero-post .wp-block-post-date {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.7rem !important;
	font-weight: 300 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: rgba(237, 233, 227, 0.6) !important;
}

/* ─── Masonry grid ────────────────────────────────────────────────────────── */
.kiim-masonry {
	column-count: 3;
	column-gap: 1rem;
	display: block !important;  /* override WP grid */
	width: 100%;
}

/* Each post card */
.kiim-masonry__item {
	break-inside: avoid;
	-webkit-column-break-inside: avoid;
	display: inline-block;
	width: 100%;
	margin-bottom: 1rem;
	vertical-align: top;
}

.kiim-masonry__item .wp-block-post-featured-image {
	margin-bottom: 0.6rem !important;
}

.kiim-masonry__item .wp-block-post-featured-image a {
	display: block;
	overflow: hidden;
	line-height: 0;
}

.kiim-masonry__item .wp-block-post-featured-image img {
	width: 100%;
	height: auto;
	display: block;
	transition: transform 0.6s cubic-bezier(0.25, 0.46, 0.45, 0.94),
	            opacity  0.4s ease;
}

.kiim-masonry__item .wp-block-post-featured-image a:hover img {
	transform: scale(1.03);
	opacity: 0.8;
}

/* Grid titles */
.kiim-masonry__item .wp-block-post-title {
	font-family: 'Cormorant Garamond', Georgia, serif !important;
	font-size: clamp(1rem, 2vw, 1.4rem) !important;
	font-weight: 300 !important;
	line-height: 1.2 !important;
	letter-spacing: -0.01em !important;
	color: #ede9e3 !important;
	margin-top: 0.5rem !important;
}

.kiim-masonry__item .wp-block-post-title a {
	text-decoration: none !important;
	color: inherit !important;
	transition: opacity 0.25s ease;
}

.kiim-masonry__item .wp-block-post-title a:hover { opacity: 0.5; }

.kiim-masonry__item .wp-block-post-date {
	font-size: 0.65rem !important;
	font-weight: 300 !important;
	letter-spacing: 0.1em !important;
	text-transform: uppercase !important;
	color: #8a8680 !important;
}

/* Responsive masonry */
@media (max-width: 900px) { .kiim-masonry { column-count: 2; } }
@media (max-width: 540px) { .kiim-masonry { column-count: 1; } }

/* ─── Single post ─────────────────────────────────────────────────────────── */

.single-hero {
	position: relative;
}

.single-hero .wp-block-post-featured-image {
	margin: 0 !important;
	line-height: 0;
}

.single-hero .wp-block-post-featured-image img {
	width: 100%;
	display: block;
	max-height: 90vh;
	object-fit: cover;
}

.single-hero__text {
	position: absolute !important;
	bottom: 0;
	left: 0;
	right: 0;
	padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem) !important;
	background: linear-gradient(
		to top,
		rgba(15, 14, 13, 0.85) 0%,
		rgba(15, 14, 13, 0.3) 60%,
		transparent 100%
	);
}

.single-hero .wp-block-post-title {
	font-family: 'Cormorant Garamond', Georgia, serif !important;
	font-size: clamp(2rem, 5vw, 4.5rem) !important;
	font-weight: 300 !important;
	line-height: 1.0 !important;
	letter-spacing: -0.02em !important;
	color: #ede9e3 !important;
	margin-bottom: 0.5rem !important;
}

.single-hero .wp-block-post-date {
	font-family: 'Inter', sans-serif !important;
	font-size: 0.65rem !important;
	font-weight: 300 !important;
	letter-spacing: 0.14em !important;
	text-transform: uppercase !important;
	color: rgba(237, 233, 227, 0.6) !important;
}

/* If post has no featured image, show title normally */
.single-hero:not(:has(.wp-block-post-featured-image img)) .single-hero__text {
	position: relative !important;
	background: none;
	padding: clamp(2rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem) !important;
}

.single-hero:not(:has(.wp-block-post-featured-image img)) .wp-block-post-title {
	color: #ede9e3 !important;
}


.wp-block-post-featured-image.alignfull img {
	width: 100%;
	display: block;
}

.wp-block-post-content .wp-block-image img {
	width: 100%;
	height: auto;
	display: block;
}

.wp-block-post-content figure.wp-block-image {
	overflow: hidden;
}

.wp-block-post-content figure.wp-block-image img {
	transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.wp-block-post-content figure.wp-block-image:hover img {
	transform: scale(1.015);
}

/* ─── Navigation ──────────────────────────────────────────────────────────── */
.wp-block-post-navigation-link a,
.wp-block-navigation a {
	text-decoration: none !important;
	transition: opacity 0.2s ease;
}

.wp-block-post-navigation-link a:hover,
.wp-block-navigation a:hover { opacity: 0.5; }

/* ─── Separator ───────────────────────────────────────────────────────────── */
hr.wp-block-separator {
	border: none;
	border-top: 1px solid #3a3835;
	margin: 0;
}

/* ─── Post terms / tags ───────────────────────────────────────────────────── */
.wp-block-post-terms a {
	text-decoration: none !important;
	transition: opacity 0.2s ease;
}

.wp-block-post-terms a:hover { opacity: 0.5; }

/* ─── Infinite scroll ─────────────────────────────────────────────────────── */
.kiim-scroll-sentinel { height: 1px; }

.kiim-scroll-spinner {
	display: flex;
	justify-content: center;
	padding: 3rem 0;
	opacity: 0;
	transition: opacity 0.3s ease;
	pointer-events: none;
}

.kiim-scroll-spinner.active { opacity: 1; }

.kiim-scroll-spinner span {
	width: 20px;
	height: 20px;
	border: 1px solid #3a3835;
	border-top-color: #8a8680;
	border-radius: 50%;
	animation: kiim-spin 0.8s linear infinite;
}

@keyframes kiim-spin { to { transform: rotate(360deg); } }

/* ─── Footer ──────────────────────────────────────────────────────────────── */
.site-footer {
	padding-top: 2.25rem !important;
	padding-bottom: 2.25rem !important;
}

/* ─── Load more / pagination ──────────────────────────────────────────────── */
.wp-block-query-pagination-next,
.wp-block-query-pagination-previous {
	font-family: 'Inter', sans-serif;
	font-size: 0.7rem;
	font-weight: 300;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	text-decoration: none !important;
	border: 1px solid #3a3835;
	padding: 0.75rem 2rem;
	color: #ede9e3;
	transition: border-color 0.2s ease, color 0.2s ease;
}

.wp-block-query-pagination-next:hover,
.wp-block-query-pagination-previous:hover {
	border-color: #ede9e3;
}
