/* Helper styles
---------------------------------------------------------------------------- */

a.more-link {
	display: block;
}

/* Inline code */
*:not(.wp-block-code) > code {
	background-color: var(--cn-accent-soft);
	border: 1px solid var(--cn-border);
	color: var(--cn-text);
	padding: 3px 5px;
	position: relative;
	border-radius: var(--cn-radius-sm);
}

.wp-block-categories {
	position: relative;
}

/* Remove margin on term description on archive pages */
.wp-block-term-description p:last-child {
	margin-bottom: 0;
}

/* Remove last separator on post list */
.remove-border-and-padding .wp-block-post-template li:last-child .wp-block-separator {
	display: none;
}

/* Hide post meta div if no tags assigned */
.single .wp-block-group:has(> .post-meta:empty) {
	display: none;
}

.wp-block-group:empty:has(+ .comment-respond) {
	display: none;
}

.row-logos > figure {
	flex-shrink: 1 !important;
}

/* Reusable hover cursor */

.cn-hover-cursor {
	--cn-hover-cursor-background: var(--cn-cursor);
	--cn-hover-cursor-shadow: rgba(0, 0, 0, 0.22);
	--cn-hover-cursor-text: var(--cn-cursor-text);
	background: transparent;
	border: 0;
	box-shadow: none;
	color: var(--cn-hover-cursor-text);
	display: block;
	height: 3.5rem;
	left: var(--cn-hover-cursor-x, -6rem);
	opacity: 0;
	pointer-events: none;
	position: fixed;
	top: var(--cn-hover-cursor-y, -6rem);
	transform: translate(0.2rem, 0.1rem) scale(0.96);
	transform-origin: 0 0;
	transition: opacity 180ms ease, transform 320ms cubic-bezier(0.2, 0, 0.18, 1);
	width: 11rem;
	z-index: 2147483647 !important;
}

.cn-hover-cursor__pointer {
	filter: drop-shadow(0 0.16rem 0.22rem var(--cn-hover-cursor-shadow));
	height: 1.62rem;
	left: 0;
	position: absolute;
	top: 0;
	transform: rotate(2deg);
	transform-origin: 0 0;
	width: 1.42rem;
}

.cn-hover-cursor__pointer-image {
	display: block;
	height: 100%;
	width: 100%;
}

.cn-hover-cursor__label {
	background: var(--cn-hover-cursor-background);
	border-radius: 0.16rem;
	box-shadow: 0 0.2rem 0.38rem var(--cn-hover-cursor-shadow);
	color: var(--cn-hover-cursor-text);
	display: block;
	font-family: var(--cn-font-sans);
	font-size: 0.9rem;
	font-weight: 600;
	left: 1.8rem;
	letter-spacing: 0;
	line-height: 1;
	padding: 0.43rem 0.52rem 0.48rem;
	position: absolute;
	text-transform: lowercase;
	top: 1.18rem;
	white-space: nowrap;
}

.cn-hover-cursor.is-active {
	opacity: 1;
	transform: translate(0.2rem, 0.1rem) scale(1);
}

@media (pointer: fine) {
	.cn-hover-cursor-ready .cn-can-hover,
	.cn-hover-cursor-ready .cn-can-hover *,
	.cn-hover-cursor-ready .wp-block-button__link,
	.cn-hover-cursor-ready button,
	.cn-hover-cursor-ready input[type="button"],
	.cn-hover-cursor-ready input[type="submit"],
	.cn-hover-cursor-ready input[type="reset"],
	.cn-hover-cursor-ready .cn-logo__link,
	.cn-hover-cursor-ready .cn-logo__link *,
	.cn-hover-cursor-ready .wp-block-navigation-item__content,
	.cn-hover-cursor-ready .wp-block-navigation-item__content *,
	.cn-hover-cursor-ready .wp-block-navigation-submenu__toggle,
	.cn-hover-cursor-ready .wp-block-navigation-submenu__toggle *,
	.cn-hover-cursor-ready .cn-visual-code__tab,
	.cn-hover-cursor-ready .cn-visual-code__tab *,
	.cn-hover-cursor-ready .cn-story-card,
	.cn-hover-cursor-ready .cn-story-card *,
	.cn-hover-cursor-ready .cn-blog-category-tabs__link,
	.cn-hover-cursor-ready .cn-blog-category-tabs__link *,
	.cn-hover-cursor-ready .cn-blog-category-tabs__rss,
	.cn-hover-cursor-ready .cn-blog-category-tabs__rss *,
	.cn-hover-cursor-ready .cn-post-toc a,
	.cn-hover-cursor-ready .cn-post-toc a *,
	.cn-hover-cursor-ready .cn-code-stack__reference,
	.cn-hover-cursor-ready .cn-code-stack__reference *,
	.cn-hover-cursor-ready .cn-knowledge-layout a,
	.cn-hover-cursor-ready .cn-knowledge-layout a *,
	.cn-hover-cursor-ready .cn-portfolio-query .wp-block-post,
	.cn-hover-cursor-ready .cn-portfolio-query .wp-block-post *,
	.cn-hover-cursor-ready .cn-blog-query .wp-block-post,
	.cn-hover-cursor-ready .cn-blog-query .wp-block-post * {
		cursor: none;
	}
}

@media (prefers-reduced-motion: reduce) {
	.cn-hover-cursor {
		transition: none;
	}
}

/* Passive roaming visitor cursor */

.cn-roaming-highlight-target {
	border-radius: 0.12em;
	-webkit-box-decoration-break: clone;
	box-decoration-break: clone;
	transition: background-color 180ms ease;
}

.cn-roaming-highlight-target.is-cn-roaming-highlighted {
	background: rgba(255, 232, 94, 0.72);
}

html[data-theme="dark"] .cn-roaming-highlight-target.is-cn-roaming-highlighted {
	background: rgba(255, 220, 84, 0.62);
}

.is-cn-roaming-hovered {
	transition-duration: 160ms;
	transition-property: background-color, border-color, color, filter, opacity, transform;
	transition-timing-function: ease;
}

a.is-cn-roaming-hovered {
	color: var(--cn-accent);
}

button.is-cn-roaming-hovered:not(.cn-visual-code__tab):not(.cn-code-stack__tab),
.wp-block-button__link.is-cn-roaming-hovered {
	filter: saturate(1.04) brightness(1.03);
}

summary.is-cn-roaming-hovered {
	color: var(--cn-accent);
}

.cn-timeline__summary.is-cn-roaming-hovered .cn-timeline__title {
	color: var(--cn-timeline-accent, var(--cn-accent));
}

.cn-timeline__summary.is-cn-roaming-hovered .cn-timeline__toggle {
	transform: scale(1.06);
}

.cn-blog-card.is-cn-roaming-hovered .cn-blog-card__title a,
.cn-blog-card.is-cn-roaming-hovered .cn-blog-card__placeholder-title,
.cn-portfolio-archive-card.is-cn-roaming-hovered .cn-portfolio-archive-card__title a,
.cn-portfolio-archive-card.is-cn-roaming-hovered .cn-portfolio-archive-card__placeholder-title {
	color: var(--cn-accent);
}

.cn-blog-card.is-cn-roaming-hovered .cn-blog-card__placeholder-title,
.cn-portfolio-archive-card.is-cn-roaming-hovered .cn-portfolio-archive-card__placeholder-title {
	text-decoration: underline;
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.12em;
}

.cn-blog-card.is-cn-roaming-hovered .cn-blog-card__image img,
.cn-portfolio-archive-card.is-cn-roaming-hovered .cn-portfolio-archive-card__image img {
	transform: scale(1.015);
}

.cn-portfolio-marquee .cn-portfolio-card.is-cn-roaming-hovered {
	top: var(--cn-portfolio-card-hover-offset);
}

.cn-portfolio-card.is-cn-roaming-hovered .cn-portfolio-card__image.is-active {
	transform: scale(1.025);
}

.cn-portfolio-card.is-cn-roaming-hovered .cn-portfolio-card__title a {
	color: var(--cn-accent);
}

.cn-story-card.is-cn-roaming-hovered .cn-story-card__image {
	transform: scale(1.02);
}

.cn-story-card.is-cn-roaming-hovered .cn-story-card__title a {
	color: var(--cn-text);
}

.cn-story-card.is-cn-roaming-hovered .cn-story-card__link {
	color: var(--cn-accent);
}

.cn-roaming-cursor {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor);
	--cn-roaming-cursor-shadow: rgba(0, 0, 0, 0.2);
	--cn-roaming-cursor-label-text: var(--cn-roaming-cursor-text);
	color: var(--cn-roaming-cursor-label-text);
	display: block;
	height: 3.5rem;
	left: 0;
	opacity: 0;
	pointer-events: none;
	position: absolute;
	top: 0;
	transform: translate3d(var(--cn-roaming-cursor-x, -8rem), var(--cn-roaming-cursor-y, -8rem), 0) scale(0.94);
	transform-origin: 0 0;
	transition: opacity 520ms ease, transform 340ms cubic-bezier(0.2, 0, 0.18, 1);
	user-select: none;
	will-change: transform;
	width: 11rem;
	z-index: 900;
}

.cn-roaming-cursor.is-active {
	opacity: 1;
	transform: translate3d(var(--cn-roaming-cursor-x, -8rem), var(--cn-roaming-cursor-y, -8rem), 0) scale(1);
}

.cn-roaming-cursor.is-placing {
	transition: opacity 520ms ease, transform 0ms linear;
}

.cn-roaming-cursor--purple {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-purple);
	z-index: 899;
}

.cn-roaming-cursor--yellow {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-yellow);
	z-index: 898;
}

.cn-roaming-cursor--grey {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-grey);
	z-index: 897;
}

.cn-roaming-cursor--cyan {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-cyan);
	z-index: 896;
}

.cn-roaming-cursor--rose {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-rose);
	z-index: 895;
}

.cn-roaming-cursor--orange {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-orange);
	z-index: 894;
}

.cn-roaming-cursor--indigo {
	--cn-roaming-cursor-background: var(--cn-roaming-cursor-indigo);
	z-index: 893;
}

.cn-roaming-cursor__pointer {
	filter: drop-shadow(0 0.16rem 0.22rem var(--cn-roaming-cursor-shadow));
	height: 1.62rem;
	left: 0;
	position: absolute;
	top: 0;
	transform: rotate(2deg);
	transform-origin: 0 0;
	width: 1.42rem;
	z-index: 2;
}

.cn-roaming-cursor__pointer-image {
	display: block;
	height: 100%;
	width: 100%;
}

.cn-roaming-cursor__label {
	background: var(--cn-roaming-cursor-background);
	border-radius: 0.16rem;
	box-shadow: 0 0.2rem 0.38rem var(--cn-roaming-cursor-shadow);
	color: var(--cn-roaming-cursor-label-text);
	display: block;
	font-family: var(--cn-font-sans);
	font-size: 0.9rem;
	font-weight: 600;
	left: 1.8rem;
	letter-spacing: 0;
	line-height: 1;
	padding: 0.43rem 0.52rem 0.48rem;
	position: absolute;
	text-transform: lowercase;
	top: 1.18rem;
	white-space: nowrap;
	z-index: 2;
}

.cn-roaming-cursor__focus {
	background: color-mix(in srgb, var(--cn-roaming-cursor-background) 16%, transparent);
	border: 1px solid color-mix(in srgb, var(--cn-roaming-cursor-background) 42%, transparent);
	border-radius: 999px;
	height: 1.4rem;
	left: -0.45rem;
	opacity: 0;
	position: absolute;
	top: -0.45rem;
	transform: scale(0.7);
	transition: opacity 260ms ease, transform 260ms ease;
	width: 1.4rem;
	z-index: 1;
}

.cn-roaming-cursor.is-clicking .cn-roaming-cursor__focus {
	opacity: 1;
	transform: scale(1.28);
}

@media (prefers-reduced-motion: reduce), (pointer: coarse) {
	.cn-roaming-cursor {
		display: none;
	}
}

/* Sticky header */

body:not(.wp-admin) header:has(>.is-position-sticky) {
	position: sticky;
	top: calc( 0px + var( --wp-admin--admin-bar--height, 0px ) );
	z-index: 100;
}

/* Account for admin bar on mobile */

@media (max-width: 600px) {
	header:has(>.is-position-sticky) {
		top: 0;
	}
}

/* Mobile helper classes */

@media (max-width: 781px) {
	.cn-hide-on-mobile {
		display: none;
	}

	.cn-unstick-mobile {
		position: static;
	}

	header:has(>.cn-unstick-mobile) {
		position: static;
	}
}
