/* ---------- kryton: app styles ---------- */
/* Tokens lifted from design_handoff_kryton_redesign/prototype/styles/tokens.css
   (dark theme, violet accent). Marketing site is dark-only; the app side
   layers light theme + accent variants on top of these. */

:root {
	/* Type */
	--font-mono: 'JetBrains Mono', 'IBM Plex Mono', ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
	--font-sans: 'Inter', ui-sans-serif, system-ui, sans-serif;
	--font-display: 'JetBrains Mono', ui-monospace, monospace;

	/* Scale */
	--fs-xs: 11px;
	--fs-sm: 12px;
	--fs-base: 13px;
	--fs-md: 14px;
	--fs-lg: 16px;
	--fs-xl: 20px;
	--fs-2xl: 28px;
	--fs-3xl: 40px;

	--radius-xs: 3px;
	--radius-sm: 5px;
	--radius-md: 8px;
	--radius-lg: 12px;

	--row-comfy: 32px;
	--row-cozy: 28px;
	--row-compact: 24px;

	/* Surfaces */
	--bg: oklch(0.18 0.012 280);
	--bg-1: oklch(0.205 0.014 280);
	--bg-2: oklch(0.235 0.016 282);
	--bg-3: oklch(0.27 0.018 282);
	--bg-input: oklch(0.225 0.014 282);
	--bg-hover: oklch(0.255 0.018 285 / 0.6);
	--bg-active: oklch(0.32 0.06 285 / 0.35);

	--line: oklch(0.32 0.012 280 / 0.6);
	--line-strong: oklch(0.4 0.014 280 / 0.7);

	--fg: oklch(0.96 0.005 280);
	--fg-1: oklch(0.85 0.01 280);
	--fg-2: oklch(0.65 0.012 280);
	--fg-3: oklch(0.5 0.012 280);
	--fg-4: oklch(0.4 0.012 280);

	--accent: oklch(0.72 0.18 295);
	--accent-soft: oklch(0.72 0.18 295 / 0.18);
	--accent-fg: oklch(0.18 0.02 280);
	--accent-2: oklch(0.78 0.14 200);
	--accent-warn: oklch(0.82 0.16 75);
	--accent-good: oklch(0.78 0.16 155);
	--accent-danger: oklch(0.7 0.2 25);

	--link: oklch(0.78 0.16 285);
	--code-bg: oklch(0.78 0.16 350 / 0.15);
	--code-fg: oklch(0.85 0.18 350);

	--selection: oklch(0.72 0.18 295 / 0.35);

	--shadow-md: 0 4px 24px -6px oklch(0 0 0 / 0.5), 0 1px 2px oklch(0 0 0 / 0.4);
	--shadow-lg: 0 12px 48px -12px oklch(0 0 0 / 0.6);

	--grid: oklch(0.32 0.012 280 / 0.18);

	/* Legacy aliases — keep existing .kryton-* rules working through the
	   token migration. New code should use the tokens above directly. */
	--c-base: var(--bg);
	--c-surface: var(--bg-1);
	--c-surface-2: var(--bg-2);
	--c-border: var(--line);
	--c-text: var(--fg);
	--c-muted: var(--fg-2);
	--c-dim: var(--fg-3);
	--c-accent-p: var(--accent);
	--c-accent-o: var(--accent-warn);
	--c-wikilink: var(--link);
	--mono: var(--font-mono);
}

html, body { background: var(--bg); color: var(--fg); font-feature-settings: 'cv11','ss01','ss02'; font-family: var(--font-sans); }
body { overflow-x: hidden; }
* { -webkit-font-smoothing: antialiased; }
::selection { background: var(--selection); color: var(--fg); }

a { text-decoration: none; }

/* Reusable utilities (handoff parity) */
.mono { font-family: var(--font-mono); font-feature-settings: "ss01", "cv02", "cv11"; }
.kbd {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: 10.5px;
	padding: 2px 5px;
	border-radius: var(--radius-xs);
	background: var(--bg-2);
	border: 1px solid var(--line);
	border-bottom-width: 2px;
	color: var(--fg-2);
	line-height: 1;
}
.dot {
	display: inline-block; width: 6px; height: 6px; border-radius: 50%;
	background: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft);
}
.dot.pulse { animation: kryton-dot-pulse 2.4s ease-in-out infinite; }
@keyframes kryton-dot-pulse {
	0%, 100% { opacity: 1; }
	50%      { opacity: 0.45; }
}
.bg-grid {
	background-image:
		linear-gradient(var(--grid) 1px, transparent 1px),
		linear-gradient(90deg, var(--grid) 1px, transparent 1px);
	background-size: 32px 32px;
}

/* ---------- header ---------- */

.kryton-header {
	max-width: 1200px;
	margin: 0 auto !important;
	border-bottom: 1px solid transparent;
	background: transparent;
	position: relative;
	z-index: 10;
}
.kryton-brand { display: inline-flex; align-items: center; gap: 0.6rem; color: var(--c-text); font-weight: 500; letter-spacing: -0.01em; font-size: 1.125rem; }
.kryton-wordmark { line-height: 1; }
.kryton-nav,
.kryton-nav .wp-block-navigation__container {
	display: flex;
	gap: 1.5rem;
	flex-wrap: nowrap;
	align-items: center;
}
.kryton-nav a,
.kryton-nav .wp-block-navigation-item__content {
	color: var(--c-muted);
	font-size: 0.9rem;
	white-space: nowrap;
	transition: color 0.15s ease;
}
.kryton-nav a:hover,
.kryton-nav .wp-block-navigation-item__content:hover { color: var(--c-text); }
.kryton-nav .wp-block-navigation-item__label { white-space: nowrap; }
.kryton-pill {
	display: inline-flex; align-items: center;
	background: var(--accent); color: var(--accent-fg);
	padding: 0.55rem 1.1rem; border-radius: 999px;
	font-family: var(--font-mono);
	font-size: 12.5px; font-weight: 600;
	letter-spacing: 0.04em; text-transform: uppercase;
	transition: filter 0.18s ease;
}
.kryton-pill:hover { filter: brightness(1.08); }
.kryton-header-actions { margin: 0; }
.kryton-pill-block .wp-block-button__link {
	display: inline-flex; align-items: center;
	background: var(--accent); color: var(--accent-fg);
	padding: 0.55rem 1.1rem; border-radius: 999px;
	font-family: var(--font-mono);
	font-size: 12.5px; font-weight: 600;
	letter-spacing: 0.04em; text-transform: uppercase;
	transition: filter 0.18s ease;
	line-height: 1;
}
.kryton-pill-block .wp-block-button__link:hover { filter: brightness(1.08); }
.kryton-pill-ghost .wp-block-button__link {
	background: transparent;
	color: var(--fg-2);
	border: 1px solid var(--line);
}
.kryton-pill-ghost .wp-block-button__link:hover {
	color: var(--fg);
	border-color: var(--fg-3);
	filter: none;
}
.kryton-header-actions { display: flex; gap: 0.6rem; }

@media (max-width: 720px) {
	.kryton-nav { display: none !important; }
}

/* ---------- hero ---------- */

.kryton-hero {
	position: relative;
	max-width: 1200px;
	margin: 0 auto;
	padding: clamp(2rem, 4vw, 5rem) 1.5rem 3rem;
	overflow: hidden;
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(0, 1fr);
	gap: clamp(1.5rem, 4vw, 3rem);
	align-items: center;
}
@media (max-width: 880px) {
	.kryton-hero { grid-template-columns: 1fr; }
}
.kryton-hero-glow {
	position: absolute; inset: -10% -20% auto auto;
	width: 70%; height: 70%;
	background:
		radial-gradient(ellipse at 70% 30%, var(--accent-soft) 0%, transparent 55%);
	pointer-events: none;
	filter: blur(20px);
	z-index: 0;
}
.kryton-hero-inner { position: relative; z-index: 1; min-width: 0; }

.kryton-eyebrow { display: flex; gap: 0.75rem; align-items: center; margin-bottom: 1.5rem; }
.kryton-eyebrow > * { margin: 0; }
.kryton-tag {
	display: inline-block; font-family: var(--mono); font-size: 0.65rem;
	letter-spacing: 0.12em; padding: 0.2rem 0.5rem; border-radius: 4px;
	background: oklch(0.72 0.18 295 / 0.15); color: var(--c-accent-p);
	text-transform: uppercase;
}
.kryton-mono { font-family: var(--mono); font-size: 0.78rem; color: var(--c-dim); letter-spacing: 0.04em; text-transform: uppercase; }

.kryton-hero-title {
	margin: 0 0 1.25rem;
	font-size: clamp(2.25rem, 1.4rem + 3.5vw, 3.75rem);
	font-weight: 600;
	letter-spacing: -0.035em;
	line-height: 1.04;
	color: var(--c-text);
}
.kryton-grad {
	color: var(--accent-warn);
}
.kryton-hero-sub {
	max-width: 620px;
	font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
	line-height: 1.6;
	color: var(--c-muted);
	margin: 0 0 2rem;
}
.kryton-wikilink {
	color: var(--link);
	background: var(--accent-soft);
	padding: 0.05em 0.35em;
	border-radius: var(--radius-xs);
	font-family: var(--font-mono);
	font-size: 0.92em;
	text-decoration: underline;
	text-decoration-style: dashed;
	text-decoration-color: oklch(0.72 0.18 295 / 0.5);
	text-underline-offset: 3px;
}
.kryton-emph {
	color: var(--accent-warn);
	font-style: normal;
	font-weight: 600;
}

.kryton-hero-ctas { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; }

.kryton-btn {
	display: inline-flex; align-items: center; gap: 0.5rem;
	padding: 0.85rem 1.4rem; border-radius: 999px;
	font-size: 0.92rem; font-weight: 500;
	border: 1px solid transparent; cursor: pointer; transition: all 0.18s ease;
	font-family: inherit; line-height: 1;
}
.kryton-buttons { margin: 0; }
.kryton-btn-block .wp-block-button__link {
	display: inline-flex; align-items: center; gap: 0.5rem;
	padding: 0.85rem 1.4rem; border-radius: 999px;
	font-size: 0.92rem; font-weight: 500;
	border: 1px solid transparent; cursor: pointer; transition: all 0.18s ease;
	font-family: inherit; line-height: 1;
	text-decoration: none;
}
.kryton-btn-primary {
	background: var(--accent); color: var(--accent-fg);
	font-family: var(--font-mono);
	font-size: 12.5px; font-weight: 600;
	letter-spacing: 0.04em; text-transform: uppercase;
}
.kryton-btn-primary .wp-block-button__link {
	background: var(--accent); color: var(--accent-fg);
	font-family: var(--font-mono);
	font-size: 12.5px; font-weight: 600;
	letter-spacing: 0.04em; text-transform: uppercase;
}
.kryton-btn-primary:hover { filter: brightness(1.08); }
.kryton-btn-primary .wp-block-button__link:hover { filter: brightness(1.08); }

.kryton-btn-ghost {
	background: transparent; color: var(--c-muted); border-color: var(--c-border);
}
.kryton-btn-ghost .wp-block-button__link {
	background: transparent; color: var(--c-muted); border-color: var(--c-border);
}
.kryton-btn-ghost:hover { color: var(--c-text); border-color: var(--c-muted); }
.kryton-btn-ghost .wp-block-button__link:hover { color: var(--c-text); border-color: var(--c-muted); }

.kryton-btn-mono {
	background: var(--c-surface); color: var(--c-muted);
	border-color: var(--c-border);
	font-family: var(--mono);
	font-size: 0.82rem;
	letter-spacing: 0.01em;
}
.kryton-btn-mono:hover { color: var(--c-text); border-color: var(--c-accent-p); }
.kryton-prompt { color: var(--accent); font-weight: 600; }
.kryton-copy-state { color: var(--c-accent-p); font-size: 0.7rem; opacity: 0; transition: opacity 0.2s ease; }
.kryton-btn-mono.is-copied .kryton-copy-state { opacity: 1; }
.kryton-btn-mono.is-copied .kryton-copy-state::before { content: "✓ copied"; }

/* ---------- hero viz ---------- */

.kryton-hero-viz { position: relative; z-index: 1; margin-top: 0; min-width: 0; }
.kryton-viz-frame {
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: var(--radius-lg);
	padding: 0.85rem 1rem;
	box-shadow: var(--shadow-md);
}
@media (max-width: 880px) {
	.kryton-hero-viz { margin-top: clamp(1.5rem, 5vw, 3rem); }
	.kryton-viz-frame { max-width: 720px; margin: 0 auto; }
}
.kryton-viz-header {
	display: flex; justify-content: space-between; align-items: center;
	font-family: var(--font-mono); font-size: var(--fs-xs); color: var(--fg-3);
	letter-spacing: 0.06em; text-transform: uppercase;
	padding: 0.15rem 0.25rem 0.65rem;
	border-bottom: 1px solid var(--line);
	flex-wrap: wrap; gap: 0.5rem;
}
.kryton-viz-agents { display: flex; gap: 0.85rem; align-items: center; }
.kryton-viz-agents .dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; margin-right: 0.35rem; }
.kryton-graph { width: 100%; height: auto; display: block; padding: 0.5rem 0 0; }

/* hero screenshot of the real graph view */
.kryton-graph-shot {
	position: relative;
	margin-top: 1rem;
	border-radius: 10px;
	overflow: hidden;
	border: 1px solid var(--c-border);
	background: #000;
	box-shadow: 0 0 0 1px oklch(0.72 0.18 295 / 0.05) inset;
}
.kryton-graph-shot img {
	display: block;
	width: 100%;
	height: auto;
	max-height: 560px;
	object-fit: cover;
	object-position: center top;
}
.kryton-graph-pulse {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	pointer-events: none;
	mix-blend-mode: screen;
}

/* status indicator (top-left of viz header) */
.kryton-viz-meta { display: flex; flex-wrap: wrap; gap: 0.85rem; align-items: center; }
.kryton-viz-status { display: inline-flex; align-items: center; gap: 0.4rem; color: var(--c-accent-p); }
.kryton-viz-status-dot {
	width: 7px; height: 7px; border-radius: 50%; background: oklch(0.78 0.16 155);
	box-shadow: 0 0 0 0 oklch(0.78 0.16 155 / 0.5);
	animation: kryton-pulse-status 1.6s ease-in-out infinite;
}
@keyframes kryton-pulse-status {
	0%, 100% { box-shadow: 0 0 0 0    oklch(0.78 0.16 155 / 0.45); }
	50%      { box-shadow: 0 0 0 6px  oklch(0.78 0.16 155 / 0);    }
}

.kryton-viz-agents { display: flex; gap: 1rem; align-items: center; flex-wrap: wrap; }
.kryton-viz-agent { display: inline-flex; align-items: center; gap: 0.4rem; transition: color 0.2s; color: var(--c-dim); }
.kryton-viz-agent .dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; background: var(--c-border); transition: background 0.4s, box-shadow 0.4s; }
.kryton-viz-agent[data-agent="claude"] .dot   { background: oklch(0.72 0.18 295); }
.kryton-viz-agent[data-agent="cursor"] .dot   { background: var(--fg-3); }
.kryton-viz-agent[data-agent="codex"] .dot { background: var(--fg-3); }
.kryton-viz-agent.is-active { color: var(--c-text); }
.kryton-viz-agent.is-active .dot { box-shadow: 0 0 0 4px var(--accent-soft); }

/* ---- knowledge graph animation ---- */

.kg-glow { animation: kg-breathe 5s ease-in-out infinite; transform-origin: 360px 190px; }
@keyframes kg-breathe {
	0%, 100% { opacity: 0.6; transform: scale(1); }
	50%      { opacity: 1;   transform: scale(1.1); }
}

.kg-center-ring {
	fill: none;
	stroke: oklch(0.72 0.18 295 / 0.5);
	stroke-width: 1;
	transform-origin: 0 0;
	animation: kg-ring-grow 3s ease-out infinite;
}
@keyframes kg-ring-grow {
	0%   { r: 12; opacity: 0.9; }
	100% { r: 38; opacity: 0;   }
}
.kg-center-core { animation: kg-core-pulse 2.4s ease-in-out infinite; transform-origin: 0 0; }
@keyframes kg-core-pulse {
	0%, 100% { transform: scale(1);    filter: drop-shadow(0 0 4px oklch(0.72 0.18 295 / 0.6)); }
	50%      { transform: scale(1.12); filter: drop-shadow(0 0 10px oklch(0.72 0.18 295 / 0.9)); }
}

.kg-node circle:first-child {  /* the glow halo */
	opacity: 0;
	animation: kg-node-glow 3.6s ease-in-out infinite var(--d);
}
.kg-node circle:last-child {   /* the dot */
	transform-origin: 0 0;
	animation: kg-node-pulse 3.6s ease-in-out infinite var(--d);
}
@keyframes kg-node-glow {
	0%, 70%, 100% { opacity: 0; }
	35%           { opacity: 1; }
}
@keyframes kg-node-pulse {
	0%, 70%, 100% { transform: scale(1);    stroke: oklch(0.72 0.18 295); }
	35%           { transform: scale(1.4);  stroke: oklch(0.72 0.18 295 / 0.7); }
}

.kg-flow {
	stroke-dasharray: 6 240;
	stroke-dashoffset: 0;
	opacity: 0;
	animation: kg-flow-run 3.6s linear infinite var(--d);
}
@keyframes kg-flow-run {
	0%   { stroke-dashoffset: 240; opacity: 0; }
	10%  { opacity: 0.9; }
	90%  { opacity: 0.9; }
	100% { stroke-dashoffset: 0;   opacity: 0; }
}

/* leaf nodes in the larger hero graph — small dots with a soft pulse */
.kg-leaf {
	fill: oklch(0.72 0.18 295);
	opacity: 0.45;
	animation: kg-leaf-pulse 4s ease-in-out infinite;
	animation-delay: var(--d, 0s);
	transform-origin: center;
}
@keyframes kg-leaf-pulse {
	0%, 100% { opacity: 0.30; }
	50%      { opacity: 0.75; }
}

.kg-caption {
	opacity: 0;
	animation: kg-caption-fade 6s ease-in-out infinite;
}
@keyframes kg-caption-fade {
	0%, 30%, 100% { opacity: 0; transform: translate(380px, 190px); }
	50%, 80%      { opacity: 1; transform: translate(380px, 190px); }
}

.kg-ring {
	transform-origin: 0 0;
	animation: kg-scan 4s ease-out infinite;
	opacity: 0;
}
.kg-ring-2 { animation-delay: 2s; stroke: oklch(0.72 0.18 295 / 0.7); }
@keyframes kg-scan {
	0%   { r: 20;  opacity: 0.7; }
	100% { r: 220; opacity: 0;   }
}

@media (prefers-reduced-motion: reduce) {
	.kg-glow, .kg-center-ring, .kg-center-core, .kg-node circle, .kg-flow, .kg-caption, .kg-ring, .kryton-viz-status-dot {
		animation: none;
	}
	.kg-flow { opacity: 0.6; stroke-dashoffset: 0; stroke-dasharray: none; }
	.kg-node circle:first-child { opacity: 0.5; }
	.kg-caption { opacity: 1; }
}

/* ---------- plugins (stat teaser on home) ---------- */

.kryton-plugins-teaser { padding: clamp(3rem, 6vw, 5rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }
.kryton-plugins-teaser-inner {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 18px;
	padding: clamp(2rem, 4vw, 3rem);
	background-image: radial-gradient(ellipse at 100% 0%, oklch(0.72 0.18 295 / 0.10) 0%, transparent 55%);
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: center;
}
@media (min-width: 880px) { .kryton-plugins-teaser-inner { grid-template-columns: 1.1fr 1fr; } }

.kryton-plugins-teaser-copy h2 {
	margin: 0 0 1rem;
	font-size: clamp(1.75rem, 1.3rem + 1.5vw, 2.4rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.1;
	display: flex; align-items: baseline; gap: 0.6rem; flex-wrap: wrap;
}
.kryton-stat-num {
	font-size: clamp(3rem, 2rem + 4vw, 5rem);
	font-weight: 600;
	letter-spacing: -0.04em;
	line-height: 0.9;
	color: var(--accent);
	font-feature-settings: 'tnum';
	font-family: var(--font-display);
}
.kryton-stat-rest { color: var(--c-text); }
.kryton-plugins-teaser-copy p { margin: 0 0 1.5rem; color: var(--c-muted); line-height: 1.65; max-width: 480px; }

.kryton-plugins-teaser-row {
	list-style: none; padding: 0; margin: 0;
	display: grid; grid-template-columns: 1fr 1fr; gap: 0.55rem;
	align-content: start;
}
@media (min-width: 540px) { .kryton-plugins-teaser-row { grid-template-columns: 1fr 1fr 1fr; } }
@media (min-width: 880px) { .kryton-plugins-teaser-row { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1080px) { .kryton-plugins-teaser-row { grid-template-columns: 1fr 1fr 1fr; } }

.kryton-teaser-chip {
	display: flex; align-items: center; gap: 0.6rem;
	padding: 0.7rem 0.85rem;
	background: var(--c-base);
	border: 1px solid var(--c-border);
	border-radius: 10px;
	color: var(--c-muted);
	transition: border-color 0.18s, color 0.18s;
	font-size: 0.85rem;
}
.kryton-teaser-chip:hover { border-color: var(--accent); color: var(--c-text); }
.kryton-teaser-chip-icon {
	flex-shrink: 0; width: 26px; height: 26px; border-radius: 6px;
	background: var(--accent-soft);
	border: 1px solid oklch(0.72 0.18 295 / 0.2);
	display: inline-flex; align-items: center; justify-content: center;
	font-family: var(--mono); font-weight: 600; color: var(--c-accent-p);
	font-size: 0.78rem;
}
.kryton-teaser-chip-name { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* ---------- plugins (full marketplace page) ---------- */

.kryton-plugins { padding: clamp(4rem, 8vw, 7rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }
.kryton-plugins-inner { width: 100%; }

.kryton-plugins-head { margin-bottom: 2rem; max-width: 720px; }
.kryton-plugins-head h2 { margin: 0 0 0.85rem; font-size: clamp(1.8rem, 1.3rem + 1.6vw, 2.6rem); font-weight: 600; letter-spacing: -0.025em; line-height: 1.15; }
.kryton-plugins-head p { color: var(--c-muted); margin: 0 0 1rem; line-height: 1.65; }
.kryton-plugins-source {
	display: inline-flex; align-items: center; gap: 0.5rem;
	color: var(--c-muted); font-size: 0.85rem;
	padding: 0.4rem 0.75rem; border: 1px solid var(--c-border); border-radius: 6px;
	transition: color 0.18s, border-color 0.18s;
}
.kryton-plugins-source:hover { color: var(--c-text); border-color: var(--c-muted); }

.kryton-plugins-controls { display: flex; flex-direction: column; gap: 0.85rem; margin-bottom: 1.5rem; }
.kryton-search {
	position: relative;
	display: flex; align-items: center;
	background: var(--c-surface); border: 1px solid var(--c-border); border-radius: 8px;
	padding: 0 0.85rem;
	transition: border-color 0.18s;
	max-width: 420px;
}
.kryton-search:focus-within { border-color: oklch(0.72 0.18 295 / 0.5); }
.kryton-search svg { color: var(--c-dim); flex-shrink: 0; }
.kryton-search input {
	flex: 1; background: transparent; border: 0; padding: 0.7rem 0.7rem;
	color: var(--c-text); font: inherit; font-size: 0.92rem; outline: none;
}
.kryton-search input::placeholder { color: var(--c-dim); }

.kryton-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.kryton-tag-chip {
	background: transparent; color: var(--c-muted);
	border: 1px solid var(--c-border); border-radius: 999px;
	padding: 0.3rem 0.85rem;
	font-size: 0.78rem; font-family: var(--mono); letter-spacing: 0.02em;
	cursor: pointer; transition: all 0.15s ease;
	display: inline-flex; align-items: center; gap: 0.4rem;
}
.kryton-tag-chip:hover { border-color: var(--c-muted); color: var(--c-text); }
.kryton-tag-chip.is-active {
	background: oklch(0.72 0.18 295 / 0.12); color: var(--c-accent-p); border-color: var(--accent);
}
.kryton-tag-count { color: var(--c-dim); font-size: 0.7rem; }
.kryton-tag-chip.is-active .kryton-tag-count { color: var(--c-accent-p); opacity: 0.7; }

.kryton-plugin-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 0.85rem; }
.kryton-plugin-grid[data-empty="1"] { display: block; }

.kryton-plugin-card {
	display: flex; gap: 0.95rem;
	padding: 1.1rem;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 10px;
	color: inherit;
	transition: border-color 0.18s, background 0.18s;
}
.kryton-plugin-card:hover { border-color: var(--accent); background: var(--c-surface-2); }
.kryton-plugin-card.is-hidden { display: none; }
.kryton-plugin-icon {
	flex-shrink: 0;
	width: 40px; height: 40px; border-radius: 8px;
	background: var(--accent-soft);
	border: 1px solid oklch(0.72 0.18 295 / 0.2);
	display: flex; align-items: center; justify-content: center;
	font-family: var(--mono); font-weight: 600; color: var(--c-accent-p);
	font-size: 0.95rem;
}
.kryton-plugin-body { min-width: 0; flex: 1; }
.kryton-plugin-row { display: flex; align-items: baseline; justify-content: space-between; gap: 0.5rem; }
.kryton-plugin-name { margin: 0 0 0.25rem; font-size: 0.98rem; font-weight: 500; color: var(--c-text); letter-spacing: -0.005em; }
.kryton-plugin-version { font-family: var(--mono); font-size: 0.7rem; color: var(--c-dim); }
.kryton-plugin-desc { margin: 0 0 0.7rem; font-size: 0.85rem; color: var(--c-muted); line-height: 1.5; }
.kryton-plugin-meta { display: flex; align-items: center; justify-content: space-between; gap: 0.5rem; flex-wrap: wrap; }
.kryton-plugin-author { font-size: 0.75rem; color: var(--c-dim); font-family: var(--mono); }
.kryton-plugin-tags { display: inline-flex; gap: 0.25rem; flex-wrap: wrap; }
.kryton-plugin-tag {
	font-family: var(--mono); font-size: 0.65rem;
	padding: 0.12rem 0.4rem; border-radius: 3px;
	background: oklch(0.72 0.18 295 / 0.08); color: var(--c-wikilink);
}

.kryton-plugins-empty { color: var(--c-muted); font-size: 0.9rem; padding: 1rem 0; }
.kryton-link {
	background: none; border: 0; padding: 0; cursor: pointer;
	color: var(--c-accent-p); font: inherit; text-decoration: underline; text-underline-offset: 3px;
}
.kryton-link:hover { color: var(--fg); }

/* ---------- pillars ---------- */

.kryton-pillars { padding: clamp(3rem, 6vw, 6rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }
.kryton-pillars-inner {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 1rem;
	align-items: stretch;
}
.kryton-pillars-inner > * {
	margin-block-start: 0 !important;
}
@media (max-width: 880px) { .kryton-pillars-inner { grid-template-columns: 1fr; } }

.kryton-card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 14px;
	padding: 1.75rem;
	transition: border-color 0.2s ease;
	align-self: stretch;
	height: 100%;
}
.kryton-card:hover { border-color: var(--accent); }
.kryton-card-tag {
	display: inline-block;
	font-family: var(--font-mono); font-size: var(--fs-xs);
	letter-spacing: 0.02em; color: var(--fg-3);
	margin-bottom: 1rem; text-transform: lowercase;
}
.kryton-card-tag::before { content: "// "; color: var(--accent); }
.kryton-card p.kryton-card-tag { margin: 0 0 1rem; color: var(--fg-3); }
.kryton-card h3 { margin: 0 0 0.7rem; font-size: 1.2rem; font-weight: 500; letter-spacing: -0.01em; line-height: 1.3; color: var(--c-text); }
.kryton-card p { margin: 0; color: var(--c-muted); font-size: 0.95rem; line-height: 1.6; }

/* ---------- agents at work ---------- */

.kryton-agents { padding: clamp(4rem, 8vw, 7rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }

.kryton-agents-head { max-width: 720px; margin-bottom: 2.5rem; }
.kryton-agents-head h2 {
	margin: 0 0 0.85rem;
	font-size: clamp(1.85rem, 1.4rem + 1.6vw, 2.7rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.12;
}
.kryton-agents-head p { color: var(--c-muted); margin: 0; line-height: 1.65; }

.kryton-agents-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 0.85rem;
	align-items: stretch;
}
.kryton-agents-grid > * {
	margin-block-start: 0 !important;
}
@media (min-width: 720px)  { .kryton-agents-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1080px) { .kryton-agents-grid { grid-template-columns: 1fr 1fr 1fr; } }

.kryton-agent-card {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 14px;
	padding: 1.5rem 1.5rem 1.65rem;
	position: relative;
	transition: border-color 0.2s ease, background 0.2s ease;
	align-self: stretch;
	height: 100%;
}
.kryton-agent-card:hover { border-color: var(--accent); background: var(--c-surface-2); }

.kryton-agent-num {
	display: inline-block;
	font-family: var(--font-mono);
	font-size: var(--fs-xs);
	letter-spacing: 0.04em;
	color: var(--accent-2);
	padding: 0;
	margin-bottom: 0.85rem;
}
.kryton-agent-card h3 {
	margin: 0 0 0.55rem;
	font-size: 1.05rem;
	font-weight: 500;
	letter-spacing: -0.01em;
	line-height: 1.3;
	color: var(--c-text);
}
.kryton-agent-card p.kryton-agent-num {
	margin: 0 0 0.85rem;
	color: var(--accent-2);
	font-size: var(--fs-xs);
	line-height: 1;
}
.kryton-agent-card p {
	margin: 0;
	color: var(--c-muted);
	font-size: 0.92rem;
	line-height: 1.55;
}

/* ---------- product preview (real screenshots) ---------- */

.kryton-preview { padding: clamp(4rem, 8vw, 7rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }
.kryton-preview-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 3.5rem);
	align-items: center;
}
@media (min-width: 980px) { .kryton-preview-inner { grid-template-columns: 1fr 1.2fr; } }

.kryton-preview-copy h2 {
	margin: 0 0 1rem;
	font-size: clamp(1.75rem, 1.3rem + 1.5vw, 2.6rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.12;
}
.kryton-preview-copy p { margin: 0 0 1.75rem; color: var(--c-muted); line-height: 1.65; max-width: 480px; }
.kryton-preview-copy .kryton-coming-soon-note {
	margin: 1.25rem 0 0;
	color: var(--c-dim);
	font-size: 0.78rem;
	line-height: 1.6;
	max-width: 480px;
}

.kryton-preview-points {
	list-style: none; padding: 0; margin: 0;
	display: grid; gap: 0.85rem;
}
.kryton-preview-points li {
	position: relative;
	padding: 0.85rem 1rem 0.85rem 2rem;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 10px;
	color: var(--c-muted);
	font-size: 0.92rem; line-height: 1.5;
}
.kryton-preview-points li strong { color: var(--accent-warn); font-weight: 600; margin-right: 0.25rem; }
/* Replace numeric point prefix with a markdown `-` bullet */
.kryton-preview-points li .kryton-point-num,
.kryton-selfhost-points li .kryton-point-num { display: none; }
.kryton-preview-points li::before,
.kryton-selfhost-points li::before {
	content: "-"; color: var(--accent-warn); font-family: var(--font-mono);
	font-weight: 600; flex-shrink: 0;
}
/* Position the absolute bullet on the card variant so the title and body
   flow inline as wrapped text (no flex column). */
.kryton-preview-points li::before {
	position: absolute; left: 1rem; top: 0.85rem;
}
.kryton-point-num {
	font-family: var(--mono); font-size: 0.7rem; color: var(--c-accent-p);
	letter-spacing: 0.08em; flex-shrink: 0;
}

/* shots layout — tabbed switcher + floating mobile */
.kryton-preview-shots {
	position: relative;
	display: block;
}
@media (min-width: 540px) { .kryton-preview-shots { padding-right: 130px; } }
@media (min-width: 980px) { .kryton-preview-shots { padding-right: 160px; } }

/* shared chrome (used in tabs and self-host) */
.kryton-shot-chrome {
	display: flex; align-items: center; gap: 0.45rem;
	padding: 0.65rem 1rem;
	background: var(--c-surface-2);
	border-bottom: 1px solid var(--c-border);
}
.kryton-shot-chrome .kryton-dot { width: 11px; height: 11px; }
.kryton-shot-title {
	margin-left: 0.65rem;
	font-family: var(--mono); font-size: 0.72rem;
	color: var(--c-dim); letter-spacing: 0.04em;
	white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* tabs (CSS-only, radio-input driven) */
.kryton-tabs { position: relative; }
.kryton-tab-input { position: absolute; opacity: 0; pointer-events: none; }

.kryton-tab-bar {
	display: inline-flex;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 999px;
	padding: 4px;
	margin-bottom: 1rem;
	gap: 2px;
	max-width: 100%;
	overflow-x: auto;
}
.kryton-tab-label {
	flex-shrink: 0;
	padding: 0.45rem 1rem;
	border-radius: 999px;
	font-size: 0.85rem;
	color: var(--c-muted);
	cursor: pointer;
	transition: color 0.18s, background 0.18s;
	user-select: none;
	white-space: nowrap;
}
.kryton-tab-label:hover { color: var(--c-text); }

/* highlight active tab — match input id with label's `for` */
.kryton-tab-input:checked + .kryton-tab-input + .kryton-tab-input + .kryton-tab-input ~ .kryton-tab-bar > .kryton-tab-label:nth-of-type(1),
.kryton-tab-input:checked + .kryton-tab-input + .kryton-tab-input ~ .kryton-tab-bar > .kryton-tab-label:nth-of-type(2),
.kryton-tab-input:checked + .kryton-tab-input ~ .kryton-tab-bar > .kryton-tab-label:nth-of-type(3),
.kryton-tab-input:checked ~ .kryton-tab-bar > .kryton-tab-label:nth-of-type(4) {
	background: var(--c-accent-p); color: var(--c-base);
}

/* simpler approach: target by id pairing */
#pp-dashboard:checked ~ .kryton-tab-bar > label[for="pp-dashboard"],
#pp-editor:checked    ~ .kryton-tab-bar > label[for="pp-editor"],
#pp-notes:checked     ~ .kryton-tab-bar > label[for="pp-notes"],
#pp-graph:checked     ~ .kryton-tab-bar > label[for="pp-graph"] {
	background: var(--c-accent-p); color: var(--c-base);
}

.kryton-tab-panels { position: relative; }
.kryton-tab-panel {
	display: none;
	margin: 0;
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 14px;
	overflow: hidden;
	box-shadow: 0 30px 80px -25px var(--accent-soft);
}
.kryton-tab-panel img { display: block; width: 100%; height: auto; max-height: 540px; object-fit: cover; object-position: top; }
.kryton-tab-caption {
	padding: 0.7rem 1rem;
	font-size: 0.78rem;
	color: var(--c-muted);
	border-top: 1px solid var(--c-border);
	background: var(--c-surface-2);
}

#pp-dashboard:checked ~ .kryton-tab-panels [data-for="pp-dashboard"],
#pp-editor:checked    ~ .kryton-tab-panels [data-for="pp-editor"],
#pp-notes:checked     ~ .kryton-tab-panels [data-for="pp-notes"],
#pp-graph:checked     ~ .kryton-tab-panels [data-for="pp-graph"] {
	display: block;
}

/* mobile floating frame, anchored to bottom-right of the shots area */
.kryton-shot-mobile {
	position: absolute;
	right: 0; bottom: -28px;
	width: 130px;
	display: none;
}
@media (min-width: 540px) { .kryton-shot-mobile { display: block; } }
@media (min-width: 980px) { .kryton-shot-mobile { width: 160px; bottom: -36px; } }

.kryton-shot-mobile-frame {
	background: var(--bg);
	border: 1px solid var(--c-border);
	border-radius: 18px;
	padding: 6px;
	box-shadow: 0 30px 60px -20px rgba(0,0,0,0.6), 0 0 0 1px oklch(0.72 0.18 295 / 0.15) inset;
	overflow: hidden;
}
.kryton-shot-mobile-frame img {
	display: block; width: 100%; height: auto;
	border-radius: 12px;
}
.kryton-shot-cap {
	display: block;
	margin-top: 0.6rem;
	font-family: var(--mono);
	font-size: 0.68rem;
	color: var(--c-dim);
	letter-spacing: 0.08em;
	text-align: center;
	text-transform: uppercase;
}

/* ---------- self-host (login + hero backdrop) ---------- */

.kryton-selfhost { padding: clamp(4rem, 8vw, 7rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }
.kryton-selfhost-inner {
	display: grid;
	grid-template-columns: 1fr;
	gap: clamp(2rem, 4vw, 3rem);
	align-items: center;
}
@media (min-width: 980px) { .kryton-selfhost-inner { grid-template-columns: 1fr 1.1fr; } }

.kryton-selfhost-copy h2 {
	margin: 0 0 1rem;
	font-size: clamp(1.75rem, 1.3rem + 1.5vw, 2.6rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.12;
}
.kryton-selfhost-copy > p { margin: 0 0 1.5rem; color: var(--c-muted); line-height: 1.65; max-width: 480px; }
.kryton-selfhost-copy em { color: var(--c-wikilink); font-style: normal; font-family: var(--mono); font-size: 0.92em; padding: 0 0.15em; }

.kryton-selfhost-points { list-style: none; padding: 0; margin: 0 0 1.75rem; display: grid; gap: 0.55rem; }
.kryton-selfhost-points li {
	display: flex; gap: 0.65rem;
	color: var(--c-muted);
	font-size: 0.92rem; line-height: 1.5;
}
.kryton-selfhost-points .kryton-point-num { color: var(--c-accent-p); font-family: var(--mono); flex-shrink: 0; }

.kryton-selfhost-visual {
	position: relative;
	aspect-ratio: 16 / 11;
	border-radius: 16px;
	overflow: hidden;
	border: 1px solid var(--c-border);
	background: var(--c-base);
	box-shadow: 0 30px 80px -25px oklch(0.72 0.18 295 / 0.20);
}
.kryton-selfhost-bg {
	position: absolute; inset: 0;
	width: 100%; height: 100%;
	object-fit: cover;
	opacity: 0.35;
	filter: blur(2px) saturate(0.85);
}
.kryton-selfhost-fg {
	position: absolute;
	left: 50%; top: 50%;
	transform: translate(-50%, -50%);
	width: min(82%, 460px);
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 30px 60px -20px rgba(0,0,0,0.7);
}
.kryton-selfhost-fg img { display: block; width: 100%; height: auto; }
.kryton-selfhost-visual::after {
	content: '';
	position: absolute; inset: 0;
	background: radial-gradient(ellipse at 50% 50%, rgba(0,0,0,0) 30%, rgba(10,10,15,0.6) 100%);
	pointer-events: none;
}

/* ---------- mcp section ---------- */

.kryton-mcp {
	padding: clamp(4rem, 8vw, 8rem) 1.5rem 2rem;
	max-width: 1200px; margin: 0 auto;
}
.kryton-mcp-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: clamp(2rem, 4vw, 4rem);
	align-items: start;
}
@media (max-width: 980px) { .kryton-mcp-inner { grid-template-columns: 1fr; } }

/* Markdown-flavored section eyebrows: `// section-name`. The `//` itself
   gets the cyan accent-2 used for header markers in markdown source. */
.kryton-eyebrow-line {
	display: inline-block; font-family: var(--font-mono); font-size: var(--fs-xs);
	letter-spacing: 0.02em; text-transform: lowercase; color: var(--fg-3);
	margin-bottom: 0.85rem;
}
.kryton-eyebrow-line::before {
	content: "// "; color: var(--accent-2); margin-right: 0.05em;
}

/* Section H2s rely on the `// EYEBROW` line above them to set the
   markdown-source mood — the redundant `## ` ::before prefix was
   forcing awkward mid-word wraps (e.g. "Your sign-" / "in.") at
   narrower widths and has been removed. */

/* Card tag `// for humans` — also cyan, same role as eyebrow. */
.kryton-card-tag::before { color: var(--accent-2); }
.kryton-mcp-copy h2 {
	margin: 0 0 1.5rem; font-size: clamp(1.8rem, 1.3rem + 1.6vw, 2.6rem);
	font-weight: 600; letter-spacing: -0.025em; line-height: 1.15;
}
.kryton-mcp-copy p { color: var(--c-muted); margin: 0 0 1.5rem; line-height: 1.65; max-width: 480px; }
.kryton-code {
	font-family: var(--font-mono); font-size: 0.88em;
	background: var(--code-bg); padding: 1px 6px; border-radius: var(--radius-xs);
	color: var(--code-fg);
}
.kryton-tools { list-style: none; padding: 0; margin: 1rem 0 0; display: grid; grid-template-columns: 1fr 1fr; gap: 0.55rem 1.25rem; }
.kryton-tools li { display: flex; gap: 0.5rem; align-items: baseline; }
.kryton-tools li::before {
	content: "-"; color: var(--accent-warn); font-family: var(--font-mono);
	flex-shrink: 0; font-weight: 600;
}
.kryton-tools .kryton-mono { color: var(--c-accent-p); text-transform: none; letter-spacing: 0; font-size: 0.83rem; flex-shrink: 0; }
/* em takes the remaining row width and wraps with the text flowing back
   under itself rather than being centred or indented far right. */
.kryton-tools em { color: var(--c-muted); font-style: normal; font-size: 0.85rem; flex: 1; min-width: 0; text-align: left; }

/* mcp snippet */
.kryton-mcp-snippet {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 12px;
	overflow: hidden;
	box-shadow: 0 30px 80px -30px var(--accent-soft);
}
.kryton-snippet-head {
	display: flex; align-items: center; gap: 0.5rem;
	padding: 0.7rem 1rem; border-bottom: 1px solid var(--c-border);
	background: var(--c-surface-2);
}
.kryton-dot { width: 11px; height: 11px; border-radius: 50%; display: inline-block; }
.kryton-dot-r { background: #ff5f56; }
.kryton-dot-y { background: #ffbd2e; }
.kryton-dot-g { background: #27c93f; }
.kryton-snippet-name { margin-left: 0.6rem; font-family: var(--font-mono); font-size: 0.75rem; color: var(--fg-3); }
.kryton-snippet-lang {
	margin-left: auto; font-family: var(--font-mono);
	font-size: var(--fs-xs); letter-spacing: 0.06em; text-transform: uppercase;
	color: var(--fg-3); padding: 0.1rem 0.5rem; border-radius: var(--radius-xs);
	border: 1px solid var(--line); background: var(--bg-1);
}
.kryton-snippet-body {
	margin: 0; padding: 1.25rem 1.5rem;
	font-family: var(--mono); font-size: 0.82rem; line-height: 1.65;
	color: var(--c-muted); overflow-x: auto;
	white-space: pre;
}
.kryton-snippet-body .t-k { color: var(--c-accent-p); }
.kryton-snippet-body .t-s { color: var(--accent-2); }
.kryton-snippet-body .t-p { color: var(--c-dim); }

/* ---------- comparison ---------- */

.kryton-compare { padding: clamp(4rem, 8vw, 7rem) 1.5rem 0; max-width: 1200px; margin: 0 auto; }

.kryton-compare-head { max-width: 720px; margin-bottom: 2.25rem; }
.kryton-compare-head h2 {
	margin: 0 0 0.85rem;
	font-size: clamp(1.85rem, 1.4rem + 1.6vw, 2.7rem);
	font-weight: 600;
	letter-spacing: -0.025em;
	line-height: 1.12;
}
.kryton-compare-head p { color: var(--c-muted); margin: 0; line-height: 1.65; }

.kryton-compare-table {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 14px;
	overflow: hidden;
}

.kryton-compare-headrow,
.kryton-compare-row {
	display: grid;
	grid-template-columns: 1.4fr 1fr 1fr 1fr;
	align-items: center;
}
.kryton-compare-row + .kryton-compare-row,
.kryton-compare-headrow + .kryton-compare-row {
	border-top: 1px solid var(--c-border);
}
.kryton-compare-row:hover { background: oklch(0.72 0.18 295 / 0.03); }

.kryton-compare-headrow {
	background: var(--c-surface-2);
	border-bottom: 1px solid var(--c-border);
}
.kryton-compare-headrow .kc-col,
.kryton-compare-headrow .kc-col-feat { padding: 0.85rem 1rem; }

.kc-col-feat {
	padding: 1rem 1.25rem;
	color: var(--c-text);
	font-size: 0.92rem;
	border-right: 1px solid var(--c-border);
}
.kc-col {
	padding: 1rem 1rem;
	display: flex;
	align-items: center;
	gap: 0.6rem;
	color: var(--c-muted);
	font-size: 0.85rem;
	border-right: 1px solid var(--c-border);
	min-width: 0;
}
.kc-col:last-child { border-right: 0; }

.kc-col-k {
	background: linear-gradient(180deg, oklch(0.72 0.18 295 / 0.10) 0%, oklch(0.72 0.18 295 / 0.03) 100%);
	color: var(--c-text);
}
.kryton-compare-headrow .kc-col-k {
	background: linear-gradient(180deg, var(--accent-soft) 0%, oklch(0.72 0.18 295 / 0.06) 100%);
}

.kc-pillar {
	display: inline-block;
	padding: 0.25rem 0.6rem;
	font-family: var(--font-mono);
	font-size: 0.72rem;
	letter-spacing: 0.12em;
	background: var(--accent);
	color: var(--accent-fg);
	border-radius: var(--radius-sm);
	font-weight: 600;
}
.kc-name {
	font-family: var(--mono);
	font-size: 0.78rem;
	color: var(--c-dim);
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.kc-i { flex-shrink: 0; }
.kc-check { color: var(--c-accent-p); }
.kc-cross { color: var(--fg-3); }
.kc-dash  { color: var(--c-dim); }
.kc-text  { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.kryton-compare-note {
	margin: 1.25rem 0 0;
	color: var(--c-dim);
	font-size: 0.78rem;
	line-height: 1.6;
	max-width: 720px;
}

/* mobile: collapse to stacked rows where each cell shows the column label */
@media (max-width: 760px) {
	.kryton-compare-headrow { display: none; }
	.kryton-compare-row {
		grid-template-columns: 1fr;
		padding: 1rem 0.5rem;
	}
	.kc-col-feat {
		padding: 0.5rem 1rem 0.85rem;
		border-right: 0;
		font-weight: 500;
		color: var(--c-text);
		font-size: 0.95rem;
	}
	.kc-col {
		padding: 0.5rem 1rem;
		border-right: 0;
		gap: 0.75rem;
	}
	.kc-col::before {
		content: attr(data-label);
		display: inline-block;
		min-width: 60px;
		font-family: var(--mono);
		font-size: 0.7rem;
		letter-spacing: 0.08em;
		text-transform: uppercase;
		color: var(--c-dim);
	}
	.kc-col-k::before { content: 'KRYTON'; color: var(--c-accent-p); }
	.kryton-compare-row .kc-col:nth-of-type(3)::before { content: 'OBSIDIAN'; }
	.kryton-compare-row .kc-col:nth-of-type(4)::before { content: 'NOTION'; }
}

/* ---------- final cta ---------- */

.kryton-cta { padding: clamp(4rem, 8vw, 7rem) 1.5rem; max-width: 1200px; margin: 0 auto; }
.kryton-cta-inner {
	background: var(--c-surface);
	border: 1px solid var(--c-border);
	border-radius: 20px;
	padding: clamp(2.5rem, 5vw, 4rem) clamp(1.5rem, 4vw, 3rem);
	background-image: radial-gradient(ellipse at 90% 10%, oklch(0.72 0.18 295 / 0.10) 0%, transparent 50%);
	text-align: left;
}
.kryton-cta-inner h2 {
	margin: 0 0 0.9rem; font-size: clamp(1.75rem, 1.3rem + 1.5vw, 2.5rem);
	font-weight: 600; letter-spacing: -0.025em;
}
.kryton-cta-inner > p { margin: 0 0 1.75rem; color: var(--c-muted); max-width: 640px; line-height: 1.6; }
.kryton-cta-row { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: center; }
/* Higher specificity to beat `.kryton-cta-inner > p`'s margin reset. */
.kryton-cta-inner > p.kryton-cta-fineprint { margin-top: 3rem; margin-bottom: 0; color: var(--c-dim); }

/* ---------- footer ---------- */

.kryton-footer { max-width: 1200px; margin: 0 auto !important; }
.kryton-footer-grid { display: grid; grid-template-columns: 1.2fr 2fr; gap: 2rem; align-items: start; }
@media (max-width: 720px) { .kryton-footer-grid { grid-template-columns: 1fr; } }
.kryton-footer-brand { display: flex; flex-direction: column; gap: 0.85rem; }
.kryton-footer-tag { color: var(--c-muted); font-size: 0.85rem; margin: 0; }
.kryton-footer-cols { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
@media (max-width: 540px) { .kryton-footer-cols { grid-template-columns: 1fr 1fr; } }
.kryton-footer-cols h4 { margin: 0 0 0.85rem; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--c-dim); font-weight: 500; }
.kryton-footer-cols .wp-block-navigation__container {
	display: grid;
	gap: 0;
}
.kryton-footer-cols a,
.kryton-footer-cols .wp-block-navigation-item__content { display: block; color: var(--c-muted); font-size: 0.9rem; padding: 0.2rem 0; transition: color 0.15s ease; }
.kryton-footer-cols a:hover,
.kryton-footer-cols .wp-block-navigation-item__content:hover { color: var(--c-text); }
.kryton-footer-bottom {
	display: flex; justify-content: space-between; align-items: center;
	margin-top: 2.5rem; padding-top: 1.5rem;
	border-top: 1px solid var(--c-border);
	color: var(--c-dim); font-size: 0.8rem;
	flex-wrap: wrap; gap: 0.5rem;
}
.kryton-footer-bottom p { margin: 0; }

/* ---------- misc / chrome ---------- */

::selection { background: var(--selection); color: var(--c-text); }

/* ============================================================ */
/* Tunnels: customer-facing pages (signup, checkout, dashboard, */
/* welcome, account, verify-email, landing).                    */
/* ============================================================ */

.kt-page {
	max-width: 720px;
	margin: 0 auto;
	padding: clamp(2.5rem, 4vw, 4.5rem) 1.5rem clamp(4rem, 8vw, 7rem);
}
.kt-page-wide { max-width: 980px; }

.kt-eyebrow {
	display: inline-block;
	font-family: var(--mono); font-size: var(--fs-xs);
	color: var(--fg-3); letter-spacing: 0.14em;
	text-transform: uppercase;
	margin: 0 0 1rem;
}
.kt-eyebrow::before { content: "// "; color: var(--accent); }

.kt-title {
	margin: 0 0 0.75rem;
	font-size: clamp(2rem, 1.5rem + 1.8vw, 2.75rem);
	font-weight: 600; letter-spacing: -0.025em; line-height: 1.1;
	color: var(--fg);
}
.kt-lede {
	margin: 0 0 2rem;
	font-size: clamp(1rem, 0.95rem + 0.3vw, 1.125rem);
	line-height: 1.6; color: var(--fg-2); max-width: 60ch;
}

.kt-card {
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: clamp(1.5rem, 2vw, 2.25rem);
	box-shadow: var(--shadow-md);
}
.kt-card + .kt-card { margin-top: 1.25rem; }
.kt-card-h {
	margin: 0 0 0.4rem;
	font-size: 1.25rem; font-weight: 600;
	letter-spacing: -0.01em; color: var(--fg);
}
.kt-card-sub {
	margin: 0 0 1.5rem;
	color: var(--fg-2); font-size: 0.95rem; line-height: 1.55;
}

/* Forms */
.kt-form { display: grid; gap: 1.1rem; }
.kt-form label {
	display: grid; gap: 0.4rem;
	font-family: var(--mono);
	font-size: 0.72rem;
	letter-spacing: 0.08em;
	color: var(--fg-3);
	text-transform: uppercase;
}
.kt-form label.kt-inline {
	display: flex; align-items: center; gap: 0.6rem;
	text-transform: none; letter-spacing: 0; font-family: var(--font-sans);
	font-size: 0.92rem; color: var(--fg-2);
}
.kt-form input[type="text"],
.kt-form input[type="email"],
.kt-form input[type="password"],
.kt-form input[type="number"],
.kt-form select {
	width: 100%;
	background: var(--bg-input);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 0.75rem 0.85rem;
	color: var(--fg);
	font-family: var(--font-sans);
	font-size: 0.95rem;
	letter-spacing: normal;
	text-transform: none;
	transition: border-color 0.18s ease, background 0.18s ease;
}
.kt-form input:focus,
.kt-form select:focus {
	outline: none;
	border-color: var(--accent);
	background: var(--bg-2);
	box-shadow: 0 0 0 4px var(--accent-soft);
}
.kt-form input[type="checkbox"] {
	width: 1.1rem; height: 1.1rem;
	accent-color: var(--accent);
	flex-shrink: 0;
}
.kt-form .kt-subdomain-wrap {
	display: flex; align-items: center;
	background: var(--bg-input);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding-right: 0.85rem;
	transition: border-color 0.18s ease, background 0.18s ease;
}
.kt-form .kt-subdomain-wrap:focus-within {
	border-color: var(--accent);
	background: var(--bg-2);
	box-shadow: 0 0 0 4px var(--accent-soft);
}
.kt-form .kt-subdomain-wrap input {
	border: none; background: transparent; box-shadow: none !important;
	padding: 0.75rem 0.85rem;
	flex: 1; min-width: 0;
}
.kt-form .kt-subdomain-wrap input:focus { box-shadow: none; }
.kt-suffix {
	font-family: var(--mono);
	font-size: 0.82rem;
	color: var(--fg-3);
	white-space: nowrap;
}
.kt-status {
	margin-top: 0.35rem;
	font-family: var(--mono); font-size: 0.75rem;
	letter-spacing: 0.02em; color: var(--fg-2);
	text-transform: none;
}
.kt-status[data-state="ok"]   { color: var(--accent-good); }
.kt-status[data-state="bad"]  { color: var(--accent-warn); }

.kt-actions {
	display: flex; flex-wrap: wrap; gap: 0.75rem;
	align-items: center;
	margin-top: 0.5rem;
}
/* When the action row follows a content card (not a form), match the
   inter-card spacing so the back-button doesn't sit flush against it. */
.kt-card + .kt-actions { margin-top: 1.5rem; }

/* Buttons */
.kt-btn {
	display: inline-flex; align-items: center; gap: 0.5rem;
	padding: 0.8rem 1.4rem;
	border-radius: 999px;
	border: 1px solid transparent;
	font-family: var(--mono);
	font-size: 0.78rem; font-weight: 600;
	letter-spacing: 0.06em; text-transform: uppercase;
	cursor: pointer;
	transition: filter 0.18s ease, border-color 0.18s ease, color 0.18s ease, background 0.18s ease;
	text-decoration: none;
}
.kt-btn-primary {
	background: var(--accent); color: var(--accent-fg);
}
.kt-btn-primary:hover { filter: brightness(1.08); color: var(--accent-fg); }
.kt-btn-ghost {
	background: transparent; color: var(--fg-2); border-color: var(--line);
}
.kt-btn-ghost:hover { color: var(--fg); border-color: var(--fg-3); }

/* Inline error / notice */
.kt-error {
	margin-top: 0.75rem;
	color: var(--accent-danger);
	font-size: 0.9rem;
	font-family: var(--font-sans);
}
.kt-notice {
	background: var(--accent-soft);
	border: 1px solid oklch(0.72 0.18 295 / 0.35);
	border-radius: var(--radius-md);
	padding: 0.85rem 1rem;
	color: var(--fg);
	font-size: 0.92rem;
}

/* Landing — full-width like the home hero (1200px) */
.kt-landing {
	max-width: 1200px;
	margin: 0 auto;
	padding: clamp(2.5rem, 5vw, 5rem) 1.5rem clamp(4rem, 8vw, 7rem);
}
.kt-landing-inner { max-width: 880px; }
.kt-landing-title {
	margin: 0 0 1.5rem;
	font-size: clamp(2.5rem, 1.8rem + 3.5vw, 4rem);
	font-weight: 600; letter-spacing: -0.035em; line-height: 1.04;
	color: var(--fg);
}
.kt-landing-title .kt-grad { color: var(--accent-warn); }
.kt-landing-sub {
	max-width: 65ch;
	margin: 0 0 2rem;
	font-size: clamp(1rem, 0.95rem + 0.3vw, 1.15rem);
	line-height: 1.65;
	color: var(--fg-2);
}
.kt-landing-features {
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 1rem; margin-top: clamp(3rem, 5vw, 4.5rem);
}
@media (max-width: 820px) {
	.kt-landing-features { grid-template-columns: 1fr; }
}

.kt-features {
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 1rem; margin-top: 2.5rem;
}
@media (max-width: 720px) {
	.kt-features { grid-template-columns: 1fr; }
}
.kt-feature {
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: 14px;
	padding: 1.5rem;
}
.kt-feature .kt-feature-tag {
	font-family: var(--mono); font-size: var(--fs-xs);
	color: var(--fg-3); letter-spacing: 0.02em; text-transform: lowercase;
	margin: 0 0 0.75rem;
}
.kt-feature .kt-feature-tag::before { content: "// "; color: var(--accent); }
.kt-feature h3 { margin: 0 0 0.4rem; font-size: 1.05rem; font-weight: 600; color: var(--fg); }
.kt-feature p { margin: 0; color: var(--fg-2); font-size: 0.92rem; line-height: 1.55; }

/* Checkout */
.kt-plan-grid {
	display: grid; grid-template-columns: 1fr 1fr;
	gap: 0.75rem; margin-bottom: 1.25rem;
}
@media (max-width: 520px) { .kt-plan-grid { grid-template-columns: 1fr; } }
.kt-plan {
	display: block; cursor: pointer;
	background: var(--bg-input);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 1rem 1.1rem;
	transition: border-color 0.18s ease, background 0.18s ease;
	font-family: var(--font-sans);
	text-transform: none; letter-spacing: 0;
}
.kt-plan input { display: none; }
.kt-plan-title {
	display: block;
	font-family: var(--mono); font-size: 0.72rem;
	letter-spacing: 0.1em; text-transform: uppercase;
	color: var(--fg-3); margin-bottom: 0.4rem;
}
.kt-plan-price {
	display: block;
	font-size: 1.25rem; font-weight: 600; color: var(--fg);
	font-feature-settings: 'tnum';
}
.kt-plan-meta {
	display: block; margin-top: 0.25rem;
	font-size: 0.82rem; color: var(--fg-2);
}
.kt-plan.is-selected,
.kt-plan:has(input:checked) {
	border-color: var(--accent);
	background: var(--bg-2);
	box-shadow: 0 0 0 4px var(--accent-soft);
}
.kt-plan:hover { border-color: var(--fg-3); }
.kt-plan.is-selected:hover { border-color: var(--accent); }

.kt-help {
	margin: 0.5rem 0 0; color: var(--fg-3);
	font-size: 0.85rem;
}

#kt-checkout-embed {
	margin-top: 0.5rem;
	min-height: 600px;
	background: #fff;
	border-radius: var(--radius-md);
	padding: 0.5rem;
}

/* Welcome */
.kt-token-block {
	background: var(--bg-input);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 1rem;
	font-family: var(--mono);
	font-size: 0.78rem;
	color: var(--accent-2);
	overflow-wrap: anywhere;
	word-break: break-all;
	white-space: pre-wrap;
	line-height: 1.5;
}
.kt-kv { display: grid; gap: 0.35rem; margin: 0 0 1.25rem; }
.kt-kv .kt-k {
	font-family: var(--mono); font-size: var(--fs-xs);
	color: var(--fg-3); letter-spacing: 0.08em; text-transform: uppercase;
}
.kt-kv .kt-v code, .kt-kv .kt-v strong { font-family: var(--mono); }
.kt-warn {
	color: var(--accent-warn);
	font-weight: 500;
}

/* Dashboard */
.kt-dash-grid {
	display: grid; gap: 1rem;
	grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
	margin-bottom: 1.5rem;
}
.kt-stat {
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 1rem 1.1rem;
}
.kt-stat-label {
	display: block;
	font-family: var(--mono); font-size: var(--fs-xs);
	color: var(--fg-3); letter-spacing: 0.08em; text-transform: uppercase;
	margin-bottom: 0.4rem;
}
.kt-stat-value {
	display: block;
	font-size: 1.4rem; font-weight: 600;
	color: var(--fg);
	font-feature-settings: 'tnum';
}
.kt-stat-meta {
	display: block; margin-top: 0.3rem;
	font-size: 0.82rem; color: var(--fg-2);
}
.kt-conn-dot {
	display: inline-block; width: 0.55rem; height: 0.55rem;
	border-radius: 50%; margin-right: 0.35rem;
	vertical-align: 0.05em;
	background: var(--fg-3);
}
.kt-conn-dot[data-on="1"] {
	background: var(--accent-good);
	box-shadow: 0 0 0 3px oklch(0.78 0.16 155 / 0.18);
}
.kt-state-pill {
	display: inline-block;
	font-family: var(--mono); font-size: var(--fs-xs);
	letter-spacing: 0.06em; text-transform: uppercase;
	padding: 0.18rem 0.55rem;
	border-radius: 999px;
	background: var(--accent-soft);
	color: var(--accent);
}
.kt-state-pill[data-state="active"]    { color: var(--accent-good); background: oklch(0.78 0.16 155 / 0.16); }
.kt-state-pill[data-state="suspended"],
.kt-state-pill[data-state="canceled"],
.kt-state-pill[data-state="past_due"]  { color: var(--accent-warn); background: oklch(0.82 0.16 75 / 0.16); }

.kt-token-row {
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	padding: 0.85rem 1rem;
	margin-bottom: 1.5rem;
	display: flex; justify-content: space-between; gap: 1rem;
	flex-wrap: wrap; align-items: center;
}
.kt-token-row code {
	font-family: var(--mono); color: var(--accent-2);
	font-size: 0.85rem;
}
.kt-token-row .kt-token-meta {
	font-size: 0.82rem; color: var(--fg-3);
	font-family: var(--mono); letter-spacing: 0.02em;
}


/* ---------- kryton connect (home section) ---------- */
.kryton-connect-section {
	max-width: 1200px;
	margin: clamp(3rem, 6vw, 6rem) auto 0;
	padding: 0 1.5rem;
}
.kryton-connect-inner {
	background:
		radial-gradient(ellipse 800px 300px at 20% 0%, oklch(0.72 0.18 295 / 0.08), transparent 70%),
		var(--bg-1);
	border: 1px solid var(--line);
	border-radius: 18px;
	padding: clamp(2rem, 4vw, 3.5rem);
}
.kryton-connect-inner h2 {
	margin: 0 0 1.25rem;
	font-size: clamp(2rem, 1.6rem + 1.6vw, 2.75rem);
	font-weight: 600; letter-spacing: -0.025em; line-height: 1.1;
}
.kryton-connect-inner > p {
	max-width: 65ch; color: var(--fg-2); font-size: 1.05rem; line-height: 1.65;
	margin: 0 0 2rem;
}
.kryton-connect-features {
	display: grid; grid-template-columns: repeat(3, 1fr);
	gap: 1rem;
	margin-bottom: 2rem;
}
@media (max-width: 820px) {
	.kryton-connect-features { grid-template-columns: 1fr; }
}
.kryton-connect-feature {
	background: var(--bg);
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 1.25rem 1.4rem;
}
.kryton-connect-feature .kryton-card-tag {
	font-family: var(--mono);
	font-size: var(--fs-xs);
	color: var(--fg-3);
	letter-spacing: 0.04em;
	text-transform: lowercase;
	display: block;
	margin: 0 0 0.6rem;
}
.kryton-connect-feature .kryton-card-tag::before { content: "// "; color: var(--accent); }
.kryton-connect-feature h3 {
	margin: 0 0 0.5rem;
	font-size: 1.1rem;
	font-weight: 600;
	color: var(--fg);
}
.kryton-connect-feature p { margin: 0; color: var(--fg-2); font-size: 0.92rem; line-height: 1.55; }
.kryton-connect-fineprint {
	margin: 1.25rem 0 0;
	color: var(--fg-3);
	font-family: var(--font-mono);
	font-size: 12px;
	letter-spacing: 0;
	text-transform: none;
}
/* Inline text link used in section CTAs ("Already have an account? Sign in") */
.kryton-text-link {
	display: inline-flex; align-items: center;
	padding: 0.85rem 0;
	color: var(--fg-2);
	font-family: var(--font-mono);
	font-size: 12.5px; font-weight: 500;
	letter-spacing: 0.02em;
	text-decoration: none;
	transition: color 0.15s ease;
}
.kryton-text-link:hover { color: var(--fg); }
.kryton-text-link-target {
	margin-left: 0.4rem;
	color: var(--link);
	text-decoration: underline;
	text-decoration-style: dashed;
	text-underline-offset: 3px;
}
.kryton-text-link:hover .kryton-text-link-target { color: var(--accent); }

/* ---------- header user menu (logged in) ---------- */
.kryton-user-menu {
	position: relative;
	display: inline-block;
}
.kryton-user-menu-trigger {
	display: inline-flex; align-items: center; justify-content: center;
	background: transparent;
	border: 1px solid transparent;
	border-radius: 999px;
	padding: 2px;
	color: var(--fg);
	cursor: pointer;
	transition: border-color 0.18s ease;
}
.kryton-user-menu-trigger:hover,
.kryton-user-menu-trigger[aria-expanded="true"] {
	border-color: var(--accent-soft);
}
.kryton-user-avatar {
	display: inline-flex; align-items: center; justify-content: center;
	width: 1.85rem; height: 1.85rem;
	border-radius: 50%;
	background: var(--accent);
	color: var(--accent-fg);
	font-family: var(--mono);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0;
}
.kryton-user-menu-header {
	padding: 0.6rem 0.75rem 0.4rem;
	display: flex; flex-direction: column; gap: 0.15rem;
}
.kryton-user-menu-eyebrow {
	font-family: var(--mono);
	font-size: var(--fs-xs);
	color: var(--fg-3);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}
.kryton-user-menu-email {
	font-size: 0.85rem;
	color: var(--fg);
	overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
	max-width: 14rem;
}

.kryton-user-menu-panel {
	position: absolute; top: calc(100% + 0.5rem); right: 0;
	min-width: 180px;
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: var(--radius-md);
	box-shadow: var(--shadow-lg);
	padding: 0.3rem;
	z-index: 100;
	display: flex; flex-direction: column;
}
.kryton-user-menu-panel[hidden] { display: none; }
.kryton-user-menu-item {
	display: block;
	padding: 0.45rem 0.7rem;
	border-radius: var(--radius-sm);
	color: var(--fg);
	font-size: 0.88rem;
	font-family: var(--font-sans);
	text-decoration: none;
	transition: background 0.12s ease, color 0.12s ease;
	line-height: 1.3;
}
.kryton-user-menu-item:hover {
	background: var(--bg-2);
	color: var(--fg);
}
.kryton-user-menu-sep {
	height: 1px;
	background: var(--line);
	margin: 0.25rem 0.35rem;
}
.kryton-user-menu-signout {
	color: var(--fg-2);
	margin-top: 0.3rem;
	padding-top: 0.6rem;
	border-top: 1px solid var(--line);
	border-radius: 0 0 var(--radius-sm) var(--radius-sm);
}
.kryton-user-menu-signout:hover { color: var(--accent-warn); }

/* ============================================================ */
/* Kryton Connect (.kc-*) — design-handoff system               */
/* ============================================================ */

/* Container */
.kc-container { width: 100%; max-width: 1180px; margin: 0 auto; padding: 0 28px; }

/* Sections */
.kc-section { padding: 80px 0; }
.kc-section.tight { padding: 48px 0; }

/* Grid backdrop */
.kc-grid-bg {
	background-image:
		linear-gradient(var(--grid) 1px, transparent 1px),
		linear-gradient(90deg, var(--grid) 1px, transparent 1px);
	background-size: 48px 48px;
}

/* Eyebrow */
.kc-eyebrow {
	display: inline-flex; align-items: center; gap: 8px;
	font-family: var(--font-mono);
	font-size: 11.5px; letter-spacing: 0.08em;
	color: var(--accent);
	text-transform: lowercase;
}
.kc-eyebrow::before { content: "//"; color: var(--fg-3); }

/* Headings */
.kc-h1 {
	font-family: var(--font-display);
	font-size: clamp(38px, 5.5vw, 64px);
	line-height: 1.04;
	letter-spacing: -1.4px;
	font-weight: 600;
	color: var(--fg);
	margin: 18px 0 22px;
	max-width: 18ch;
	text-wrap: pretty;
}
.kc-h2 {
	font-family: var(--font-display);
	font-size: clamp(24px, 2.4vw, 34px);
	letter-spacing: -0.6px;
	color: var(--fg);
	margin: 0 0 14px;
	font-weight: 600;
}
.kc-h3 {
	font-family: var(--font-display);
	font-size: 17px; letter-spacing: -0.2px;
	color: var(--fg);
	margin: 0 0 8px;
	font-weight: 600;
}
.kc-lede {
	color: var(--fg-2);
	font-size: 17px; line-height: 1.55;
	max-width: 56ch;
	text-wrap: pretty;
	margin: 0;
}

/* Buttons */
.kc-btn {
	display: inline-flex; align-items: center; gap: 8px;
	padding: 11px 18px; border-radius: 8px;
	font-family: var(--font-mono);
	font-size: 13px; font-weight: 600;
	letter-spacing: 0.04em;
	text-decoration: none;
	cursor: pointer; border: 0;
	transition: transform 80ms, background 120ms, border-color 120ms, color 120ms, filter 120ms;
	line-height: 1;
}
.kc-btn:active { transform: translateY(1px); }
.kc-btn-primary { background: var(--accent); color: var(--accent-fg); }
.kc-btn-primary:hover { filter: brightness(1.08); color: var(--accent-fg); }
.kc-btn-ghost { background: transparent; color: var(--fg-1); border: 1px solid var(--line); }
.kc-btn-ghost:hover { border-color: var(--accent); color: var(--fg); }
.kc-btn-text { color: var(--fg-1); background: transparent; padding: 11px 6px; }
.kc-btn-text:hover { color: var(--accent); }
.kc-btn-sm { padding: 7px 13px; font-size: 12px; }

/* Dashed link */
.kc-link {
	color: var(--link);
	text-decoration: underline;
	text-decoration-style: dashed;
	text-underline-offset: 3px;
}
.kc-link:hover { color: var(--accent); }

/* Inline code */
.kc-code {
	font-family: var(--font-mono);
	font-size: 0.92em;
	background: var(--code-bg);
	color: var(--code-fg);
	padding: 2px 7px;
	border-radius: 4px;
}

/* Card */
.kc-card {
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: 12px;
	padding: 22px;
}

/* Feature card (with accent thread on top) */
.kc-feature {
	padding: 24px;
	background: var(--bg-1);
	border: 1px solid var(--line);
	border-radius: 12px;
	position: relative;
	overflow: hidden;
	transition: border-color 0.18s ease;
}
.kc-feature::before {
	content: "";
	position: absolute; top: 0; left: 0; right: 0; height: 1px;
	background: linear-gradient(90deg, transparent, var(--accent), transparent);
	opacity: 0.5;
}
.kc-feature:hover { border-color: var(--accent); }
.kc-feature .eb {
	font-family: var(--font-mono); font-size: 10.5px;
	color: var(--fg-3); text-transform: uppercase; letter-spacing: 0.12em;
	margin-bottom: 14px; display: flex; align-items: center; gap: 8px;
}
.kc-feature p {
	color: var(--fg-2); line-height: 1.55; font-size: 14px; margin: 0;
}

/* Chips */
.kc-chip {
	display: inline-flex; align-items: center; gap: 6px;
	padding: 3px 8px; border-radius: 4px;
	font-family: var(--font-mono); font-size: 10.5px;
	letter-spacing: 0.04em;
}
.kc-chip.good   { background: color-mix(in oklch, var(--accent-good) 20%, transparent); color: var(--accent-good); }
.kc-chip.warn   { background: color-mix(in oklch, var(--accent-warn) 20%, transparent); color: var(--accent-warn); }
.kc-chip.muted  { background: var(--bg-2); color: var(--fg-3); border: 1px solid var(--line); }
.kc-chip.accent { background: var(--accent-soft); color: var(--accent); }

/* Inputs */
.kc-input {
	width: 100%;
	padding: 10px 12px;
	background: var(--bg-input);
	border: 1px solid var(--line);
	border-radius: 6px;
	color: var(--fg);
	font-family: var(--font-mono);
	font-size: 13px;
	outline: none;
	transition: border-color 120ms, box-shadow 120ms;
}
.kc-input:focus {
	border-color: var(--accent);
	box-shadow: 0 0 0 3px var(--accent-soft);
}
.kc-label {
	display: block;
	font-family: var(--font-mono);
	font-size: 11px;
	color: var(--fg-3);
	letter-spacing: 0.04em;
	margin-bottom: 5px;
	text-transform: lowercase;
}
.kc-field { display: flex; flex-direction: column; gap: 6px; }
.kc-field-hint { font-family: var(--font-mono); font-size: 10.5px; color: var(--fg-4); }
.kc-field-hint::before { content: "// "; }

/* Stat tile */
.kc-stat .v {
	font-family: var(--font-display);
	font-size: 28px; letter-spacing: -0.6px;
	color: var(--fg);
	font-variant-numeric: tabular-nums;
	font-weight: 600;
}
.kc-stat .l {
	font-family: var(--font-mono); font-size: 10.5px;
	text-transform: uppercase; letter-spacing: 0.1em;
	color: var(--fg-3);
	margin-top: 4px;
}
.kc-stat .delta {
	font-family: var(--font-mono); font-size: 11px;
	margin-left: 8px;
}
.kc-stat .delta.up { color: var(--accent-good); }
.kc-stat .delta.down { color: var(--accent-danger); }

/* Table */
.kc-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.kc-table th {
	text-align: left;
	font-family: var(--font-mono); font-weight: 500;
	font-size: 10.5px; letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--fg-4);
	padding: 10px 12px;
	border-bottom: 1px solid var(--line);
}
.kc-table td { padding: 12px; border-bottom: 1px solid var(--line); color: var(--fg-1); }
.kc-table tr:last-child td { border-bottom: 0; }
.kc-table tr:hover td { background: var(--bg-hover); }

/* Pulsing dot */
.kc-dot {
	display: inline-block; width: 6px; height: 6px; border-radius: 50%;
	background: var(--accent-good);
}
.kc-dot.pulse { animation: kc-dot-pulse 2.4s ease-in-out infinite; }
@keyframes kc-dot-pulse { 0%, 100% { opacity: 1; } 50% { opacity: 0.45; } }

/* Neutralize wpautop droppings in the header/footer template-parts so they
   don't push the sticky nav down or break inline alignment. */
.wp-block-template-part > br,
.wp-block-template-part br:first-child,
.kc-nav br { display: none; }
.wp-block-template-part > p { display: contents; margin: 0; }

/* TopNav */
.kc-nav {
	position: sticky; top: 0; z-index: 20;
	display: flex; align-items: center; gap: 22px;
	height: 56px; padding: 0 28px;
	background: color-mix(in oklch, var(--bg) 80%, transparent);
	backdrop-filter: blur(8px);
	border-bottom: 1px solid var(--line);
}
.kc-nav .kc-brand {
	display: inline-flex; align-items: center; gap: 8px;
	color: var(--fg);
	font-family: var(--font-display);
	font-size: 16px; font-weight: 600; letter-spacing: -0.3px;
	text-decoration: none;
}
.kc-nav .kc-nav-links { display: flex; gap: 18px; margin-left: 22px; }
.kc-nav a.kc-nav-link {
	color: var(--fg-2);
	font-family: var(--font-mono);
	font-size: 12.5px;
	padding: 6px 0;
	position: relative;
	text-decoration: none;
	white-space: nowrap;
}
.kc-nav a.kc-nav-link:hover { color: var(--fg); }
.kc-nav a.kc-nav-link.active { color: var(--fg); }
.kc-nav a.kc-nav-link.active::after {
	content: ""; position: absolute; left: 0; right: 0; bottom: -1px;
	height: 2px; background: var(--accent);
}
.kc-nav-grow { flex: 1; }
.kc-nav .kc-nav-right { display: flex; align-items: center; gap: 16px; }

/* Avatar (nav + account) */
.kc-avatar {
	display: inline-flex; align-items: center; justify-content: center;
	width: 24px; height: 24px; border-radius: 50%;
	background: linear-gradient(135deg, var(--accent), var(--accent-2));
	color: var(--accent-fg);
	font-weight: 600; font-size: 11px;
	font-family: var(--font-sans);
}
.kc-avatar.lg { width: 84px; height: 84px; font-family: var(--font-display); font-size: 36px; border: 1px solid var(--line); }

/* Footer */
.kc-footer {
	border-top: 1px solid var(--line);
	margin-top: 80px;
	padding: 60px 0 40px;
	background: var(--bg);
}
.kc-footer-grid {
	display: flex; align-items: flex-start; gap: 60px;
	flex-wrap: wrap; margin-bottom: 56px;
}
.kc-footer-brand { flex: 1; min-width: 240px; }
.kc-footer-brand .kc-brand-row { display: flex; align-items: center; gap: 10px; margin-bottom: 14px; }
.kc-footer-brand .kc-brand-row .kc-brand-name {
	font-family: var(--font-display); font-size: 20px; font-weight: 600; color: var(--fg);
}
.kc-footer-brand .kc-brand-tag { color: var(--fg-2); font-size: 13.5px; max-width: 320px; line-height: 1.6; }
.kc-footer-cols {
	display: grid; grid-template-columns: repeat(4, minmax(140px, 1fr));
	gap: 40px;
}
.kc-footer-cols h4 {
	font-family: var(--font-mono); font-size: 11px;
	color: var(--fg-3); letter-spacing: 0.1em;
	text-transform: uppercase;
	margin: 0 0 14px;
	font-weight: 500;
}
.kc-footer-cols ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.kc-footer-cols a {
	color: var(--fg-1); font-size: 13px; text-decoration: none;
	transition: color 0.15s ease;
}
.kc-footer-cols a:hover { color: var(--accent); }
.kc-footer-bottom {
	display: flex; align-items: center; gap: 16px;
	padding-top: 22px; border-top: 1px dashed var(--line);
	color: var(--fg-3); font-size: 12px;
	font-family: var(--font-mono);
}
.kc-footer-bottom .kc-sep { color: var(--fg-4); }
.kc-footer-bottom .kc-status { display: inline-flex; align-items: center; gap: 6px; margin-left: auto; }

@media (max-width: 820px) {
	.kc-nav .kc-nav-links { display: none; }
	.kc-footer-cols { grid-template-columns: repeat(2, 1fr); gap: 28px; }
}

/* zoomable screenshots */
[data-kryton-zoom] {
	cursor: zoom-in;
	transition: transform 220ms cubic-bezier(.2,.7,.2,1), box-shadow 220ms ease, filter 220ms ease;
	transform-origin: center;
	will-change: transform;
}
[data-kryton-zoom]:hover,
[data-kryton-zoom]:focus-visible {
	transform: translateY(-2px) scale(1.012);
	filter: brightness(1.04);
	outline: none;
}
.kryton-tab-panel:has([data-kryton-zoom]:hover),
.kryton-tab-panel:has([data-kryton-zoom]:focus-visible) {
	box-shadow: 0 40px 100px -25px var(--accent-soft, rgba(0,0,0,.4)), 0 0 0 1px var(--accent, #7c5cff);
}
[data-kryton-zoom]:focus-visible {
	box-shadow: 0 0 0 2px var(--accent, #7c5cff);
}

/* zoom modal */
.kryton-zoom-modal {
	position: fixed; inset: 0;
	display: flex; align-items: center; justify-content: center;
	padding: clamp(20px, 4vw, 56px);
	background: rgba(8, 8, 12, 0.78);
	backdrop-filter: blur(10px);
	-webkit-backdrop-filter: blur(10px);
	z-index: 9999;
	opacity: 0;
	transition: opacity 180ms ease;
}
.kryton-zoom-modal[data-open="1"] { opacity: 1; }
.kryton-zoom-modal-frame {
	position: relative;
	max-width: min(1400px, 96vw);
	max-height: 92vh;
	border-radius: 14px;
	overflow: hidden;
	background: var(--bg, #0c0d10);
	border: 1px solid var(--line, rgba(255,255,255,.12));
	box-shadow: 0 60px 140px -30px rgba(0,0,0,.7), 0 0 0 1px rgba(255,255,255,.04);
	transform: scale(.96);
	transition: transform 220ms cubic-bezier(.2,.7,.2,1);
}
.kryton-zoom-modal[data-open="1"] .kryton-zoom-modal-frame { transform: scale(1); }
.kryton-zoom-modal-frame img {
	display: block;
	max-width: 100%;
	max-height: 92vh;
	width: auto; height: auto;
	object-fit: contain;
}
.kryton-zoom-modal-close {
	position: absolute; top: 10px; right: 10px;
	width: 36px; height: 36px;
	display: inline-flex; align-items: center; justify-content: center;
	border-radius: 999px;
	background: rgba(0,0,0,.55);
	color: #fff;
	border: 1px solid rgba(255,255,255,.18);
	cursor: pointer;
	font: 600 18px/1 var(--font-mono, ui-monospace, monospace);
	transition: background 160ms ease, transform 160ms ease;
}
.kryton-zoom-modal-close:hover { background: rgba(0,0,0,.85); transform: scale(1.06); }
.kryton-zoom-modal-close:focus-visible { outline: 2px solid var(--accent, #7c5cff); outline-offset: 2px; }
body.kryton-zoom-open { overflow: hidden; }
@media (prefers-reduced-motion: reduce) {
	[data-kryton-zoom], .kryton-zoom-modal, .kryton-zoom-modal-frame { transition: none; }
	[data-kryton-zoom]:hover, [data-kryton-zoom]:focus-visible { transform: none; }
}
