/* =========================================================================
   Melissa Kampers Dossiers — front-end styles
   Story threads in the suite's console language. Theme-independent,
   light/dark aware, zero JavaScript.
   ========================================================================= */

.mkdo-strip,
.mkdo-masthead,
.mkdo-nav,
.mkdo-grid {
	--mkdo-text: #1d2027;
	--mkdo-muted: #565d69;
	--mkdo-border: #dcdfe6;
	--mkdo-card: #ffffff;
	--mkdo-accent: #2742e0;
	--mkdo-accent-2: #0b7b86;
	--mkdo-focus: #2742e0;
	--mkdo-shadow: 0 1px 2px rgba(22, 23, 28, 0.04), 0 10px 28px rgba(22, 23, 28, 0.06);
	--mkdo-shadow-up: 0 2px 6px rgba(22, 23, 28, 0.06), 0 20px 48px rgba(22, 23, 28, 0.12);
}

[data-theme="dark"] .mkdo-strip,
[data-theme="dark"] .mkdo-masthead,
[data-theme="dark"] .mkdo-nav,
[data-theme="dark"] .mkdo-grid {
	--mkdo-text: #e8ebf2;
	--mkdo-muted: #9aa4b5;
	--mkdo-border: rgba(141, 164, 255, 0.16);
	--mkdo-card: #11141d;
	--mkdo-accent: #8da4ff;
	--mkdo-accent-2: #34d8c5;
	--mkdo-focus: #8da4ff;
	--mkdo-shadow: 0 1px 2px rgba(0, 0, 0, 0.3), 0 12px 32px rgba(5, 8, 18, 0.3);
	--mkdo-shadow-up: 0 2px 8px rgba(0, 0, 0, 0.4), 0 22px 52px rgba(5, 8, 18, 0.5);
}

@media (prefers-color-scheme: dark) {
	:root:not([data-theme="light"]) .mkdo-strip,
	:root:not([data-theme="light"]) .mkdo-masthead,
	:root:not([data-theme="light"]) .mkdo-nav,
	:root:not([data-theme="light"]) .mkdo-grid {
		--mkdo-text: #e8ebf2;
		--mkdo-muted: #9aa4b5;
		--mkdo-border: rgba(141, 164, 255, 0.16);
		--mkdo-card: #11141d;
		--mkdo-accent: #8da4ff;
		--mkdo-accent-2: #34d8c5;
		--mkdo-focus: #8da4ff;
		--mkdo-shadow: 0 1px 2px rgba(0, 0, 0, 0.3), 0 12px 32px rgba(5, 8, 18, 0.3);
		--mkdo-shadow-up: 0 2px 8px rgba(0, 0, 0, 0.4), 0 22px 52px rgba(5, 8, 18, 0.5);
	}
}

/* Status chips: text carries the meaning, the dot reinforces it. -------- */
.mkdo-status {
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	padding: 0.12rem 0.6rem;
	border: 1px solid currentColor;
	border-radius: 999px;
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	white-space: nowrap;
}

.mkdo-status--active { color: var(--mkdo-accent-2, #0b7b86); }
.mkdo-status--concluded { color: var(--mkdo-muted, #565d69); }

.mkdo-status__dot {
	width: 6px;
	height: 6px;
	border-radius: 50%;
	background: currentColor;
	flex-shrink: 0;
}

/* The strip above an article ------------------------------------------------ */
.mkdo-strip {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	margin: 0 0 1.75rem;
	padding: 0.7rem 1.1rem;
	background: var(--mkdo-card);
	border: 1px solid var(--mkdo-border);
	border-radius: 12px;
	text-decoration: none;
	color: var(--mkdo-text);
	transition: border-color 180ms ease;
}

.mkdo-strip:hover,
.mkdo-strip:focus-visible {
	border-color: var(--mkdo-accent);
}

.mkdo-strip:focus-visible {
	outline: 2px solid var(--mkdo-focus);
	outline-offset: 3px;
}

.mkdo-strip__kicker {
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mkdo-muted);
}

.mkdo-strip__dot--active { width: 6px; height: 6px; border-radius: 50%; background: var(--mkdo-accent-2); }
.mkdo-strip__dot--concluded { width: 6px; height: 6px; border-radius: 50%; background: var(--mkdo-muted); }

.mkdo-strip__name {
	font-weight: 700;
	font-size: 0.9375rem;
	letter-spacing: -0.01em;
}

.mkdo-strip__part {
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mkdo-muted);
}

.mkdo-strip__cta {
	margin-left: auto;
	font-size: 0.78rem;
	font-weight: 700;
	color: var(--mkdo-accent);
	white-space: nowrap;
}

.mkdo-strip:hover .mkdo-strip__cta {
	text-decoration: underline;
	text-underline-offset: 0.3em;
}

/* The dossier page masthead --------------------------------------------------- */
.mkdo-masthead {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 0.5rem 1.1rem;
	margin: 0.9rem 0 0.25rem;
	font-size: 0.8125rem;
	color: var(--mkdo-muted);
}

.mkdo-masthead__kicker {
	font-size: 0.6875rem;
	font-weight: 700;
	letter-spacing: 0.16em;
	text-transform: uppercase;
	color: var(--mkdo-accent);
}

.mkdo-masthead__fact {
	letter-spacing: 0.02em;
}

.mkdo-masthead__follow {
	font-size: 0.78rem;
	font-weight: 700;
	color: var(--mkdo-accent);
	text-decoration: none;
}

.mkdo-masthead__follow:hover {
	text-decoration: underline;
	text-underline-offset: 0.3em;
}

.mkdo-masthead__follow:focus-visible {
	outline: 2px solid var(--mkdo-focus);
	outline-offset: 2px;
	border-radius: 3px;
}

/* Previous/next within the thread --------------------------------------------- */
.mkdo-nav {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(16rem, 100%), 1fr));
	gap: 1rem;
	margin-top: 2.25rem;
}

.mkdo-nav__item {
	display: flex;
	flex-direction: column;
	gap: 0.35rem;
	padding: 1rem 1.2rem;
	background: var(--mkdo-card);
	border: 1px solid var(--mkdo-border);
	border-radius: 14px;
	box-shadow: var(--mkdo-shadow);
	text-decoration: none;
	color: var(--mkdo-text);
	transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

.mkdo-nav__item:hover,
.mkdo-nav__item:focus-visible {
	transform: translateY(-3px);
	border-color: var(--mkdo-accent);
	box-shadow: var(--mkdo-shadow-up);
}

.mkdo-nav__item:focus-visible {
	outline: 2px solid var(--mkdo-focus);
	outline-offset: 3px;
}

.mkdo-nav__item--next {
	text-align: right;
}

.mkdo-nav__label {
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mkdo-muted);
}

.mkdo-nav__title {
	font-weight: 700;
	line-height: 1.35;
	letter-spacing: -0.012em;
}

/* The dossier grid (homepage) --------------------------------------------------- */
.mkdo-grid {
	display: grid;
	gap: 1.1rem;
	grid-template-columns: repeat(auto-fill, minmax(min(15rem, 100%), 1fr));
}

.mkdo-card {
	position: relative;
	display: flex;
	flex-direction: column;
	gap: 0.55rem;
	padding: 1.3rem 1.4rem;
	background: var(--mkdo-card);
	border: 1px solid var(--mkdo-border);
	border-radius: 14px;
	overflow: hidden;
	text-decoration: none;
	color: var(--mkdo-text);
	box-shadow: var(--mkdo-shadow);
	transition: transform 200ms ease, border-color 200ms ease, box-shadow 200ms ease;
}

.mkdo-card::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 3px;
	background: linear-gradient(180deg, var(--mkdo-accent), var(--mkdo-accent-2));
	opacity: 0;
	transition: opacity 200ms ease;
}

.mkdo-card:hover,
.mkdo-card:focus-visible {
	transform: translateY(-3px);
	border-color: var(--mkdo-accent);
	box-shadow: var(--mkdo-shadow-up);
}

.mkdo-card:hover::before,
.mkdo-card:focus-visible::before {
	opacity: 1;
}

.mkdo-card:focus-visible {
	outline: 2px solid var(--mkdo-focus);
	outline-offset: 3px;
}

.mkdo-card__top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 0.75rem;
}

.mkdo-card__kicker {
	font-size: 0.625rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: var(--mkdo-muted);
}

.mkdo-card__name {
	font-size: 1.15rem;
	font-weight: 800;
	letter-spacing: -0.018em;
	line-height: 1.25;
}

.mkdo-card__desc {
	font-size: 0.9rem;
	line-height: 1.55;
	color: var(--mkdo-muted);
}

.mkdo-card__meta {
	margin-top: auto;
	padding-top: 0.5rem;
	font-size: 0.72rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	color: var(--mkdo-accent);
}

.mkdo-card__arrow {
	display: inline-block;
	transition: transform 200ms ease;
}

.mkdo-card:hover .mkdo-card__arrow {
	transform: translateX(4px);
}

/* Reduced motion ------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
	.mkdo-strip,
	.mkdo-nav__item,
	.mkdo-card,
	.mkdo-card__arrow {
		transition: none;
	}

	.mkdo-nav__item:hover,
	.mkdo-card:hover {
		transform: none;
	}
}

/* Print: thread context is useful on paper; navigation chrome is not. */
@media print {
	.mkdo-nav,
	.mkdo-masthead__follow {
		display: none;
	}

	.mkdo-strip {
		border-color: #999;
	}
}
