/* ==========================================================================
   Jumper Bee Blog — single posts, archives, comments, related
   ========================================================================== */

.jb-blog {
	--jb-blog-max:       1240px;
	--jb-blog-prose-max: 720px;
	--jb-blog-ink:       #0d1b3d;
	--jb-blog-ink-2:     #243059;
	--jb-blog-muted:     #5a6482;
	--jb-blog-muted-2:   #8a93ad;
	--jb-blog-line:      #e4e8f1;
	--jb-blog-line-2:    #eef1f7;
	--jb-blog-bg:        #ffffff;
	--jb-blog-bg-soft:   #f7f9fd;
	--jb-blog-bg-cream:  #fff8e7;
	--jb-blog-blue:      #00a6ff;
	--jb-blog-blue-deep: #0077cc;
	--jb-blog-yellow:    #ffd400;
	--jb-blog-pink:      #ff2e7e;
	--jb-blog-purple:    #7b3ff2;
	--jb-blog-teal:      #1fd8c5;
	--jb-blog-red:       #ff3b57;
	--jb-blog-green:     #2ecc71;
	--jb-blog-radius:    14px;
	--jb-blog-radius-lg: 22px;
	--jb-blog-radius-xl: 28px;
	--jb-blog-shadow:    0 6px 20px rgba(13,27,61,.08);
	--jb-blog-shadow-lg: 0 14px 40px rgba(13,27,61,.14);
	--jb-blog-font-head: "Fredoka", "Baloo 2", system-ui, -apple-system, "Segoe UI", sans-serif;
	--jb-blog-font-body: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
	--jb-blog-font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, "Cascadia Mono", Consolas, monospace;

	color: var(--jb-blog-ink);
	font-family: var(--jb-blog-font-body);
	font-size: 17px;
	line-height: 1.65;
	background: var(--jb-blog-bg);
}

.jb-blog * { box-sizing: border-box; }

.jb-blog__container {
	max-width: var(--jb-blog-max);
	margin: 0 auto;
	padding: 0 1.25rem;
}
@media (min-width: 768px) {
	.jb-blog__container { padding: 0 2rem; }
}

/* ----- Breadcrumbs ----- */
.jb-blog__crumbs {
	padding: 1rem 0 .25rem;
	color: var(--jb-blog-muted);
	font-size: .85rem;
}
.jb-blog__crumbs ol {
	list-style: none;
	margin: 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	gap: .35rem .55rem;
	align-items: center;
}
.jb-blog__crumbs li { display: inline-flex; align-items: center; gap: .55rem; }
.jb-blog__crumbs li + li::before {
	content: "/";
	color: var(--jb-blog-muted-2);
}
.jb-blog__crumbs a {
	color: var(--jb-blog-muted);
	text-decoration: none;
	border-bottom: 1px dashed transparent;
}
.jb-blog__crumbs a:hover {
	color: var(--jb-blog-blue-deep);
	border-bottom-color: var(--jb-blog-blue-deep);
}
.jb-blog__crumbs [aria-current="page"] { color: var(--jb-blog-ink); font-weight: 600; }

/* ==========================================================================
   SINGLE POST — hero + prose + sidebar
   ========================================================================== */

.jb-post {
	padding-bottom: clamp(3rem, 7vw, 6rem);
}

.jb-post__header {
	padding: 2rem 0 1.5rem;
	text-align: center;
}
.jb-post__header .jb-blog__container {
	max-width: 880px;
}

.jb-post__categories {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: .4rem;
	margin-bottom: 1.25rem;
}
.jb-post__cat {
	display: inline-flex;
	align-items: center;
	gap: .35em;
	background: var(--jb-blog-blue);
	color: #fff;
	text-decoration: none;
	font-weight: 800;
	font-size: .75rem;
	letter-spacing: .06em;
	text-transform: uppercase;
	padding: .4rem .85rem;
	border-radius: 999px;
	transition: background .15s ease, transform .15s ease;
}
.jb-post__cat:nth-child(4n+2) { background: var(--jb-blog-pink); }
.jb-post__cat:nth-child(4n+3) { background: var(--jb-blog-purple); }
.jb-post__cat:nth-child(4n+4) { background: var(--jb-blog-teal); color: var(--jb-blog-ink); }
.jb-post__cat:hover { transform: translateY(-1px); filter: brightness(1.05); }

.jb-post__title {
	font-family: var(--jb-blog-font-head);
	color: var(--jb-blog-ink);
	font-size: clamp(2rem, 5vw, 3.25rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.01em;
	margin: 0 0 1rem;
	text-wrap: balance;
}

.jb-post__dek {
	color: var(--jb-blog-muted);
	font-size: 1.125rem;
	line-height: 1.55;
	max-width: 60ch;
	margin: 0 auto 1.5rem;
	text-wrap: pretty;
}

/* Meta row */
.jb-post__meta {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	gap: .65rem 1.1rem;
	color: var(--jb-blog-muted);
	font-size: .92rem;
	padding: 1rem 0 0;
	border-top: 1px solid var(--jb-blog-line);
	margin: .5rem auto 0;
	max-width: 640px;
}
.jb-post__meta-item {
	display: inline-flex;
	align-items: center;
	gap: .45em;
}
.jb-post__meta-item strong {
	color: var(--jb-blog-ink);
	font-weight: 700;
}
.jb-post__meta-avatar {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	object-fit: cover;
	border: 2px solid #fff;
	box-shadow: 0 2px 6px rgba(13,27,61,.12);
}
.jb-post__meta-icon {
	width: 14px;
	height: 14px;
	color: var(--jb-blog-blue);
	flex-shrink: 0;
}
.jb-post__meta-sep {
	color: var(--jb-blog-muted-2);
}
.jb-post__updated {
	color: var(--jb-blog-muted);
	font-style: italic;
}

/* Featured image */
.jb-post__hero {
	position: relative;
	margin: 1.5rem auto 2.5rem;
	max-width: var(--jb-blog-max);
	padding: 0 1.25rem;
}
.jb-post__hero-img {
	width: 100%;
	height: auto;
	max-height: 620px;
	object-fit: cover;
	border-radius: var(--jb-blog-radius-lg);
	box-shadow: var(--jb-blog-shadow-lg);
	background: var(--jb-blog-bg-soft);
}
.jb-post__hero-caption {
	color: var(--jb-blog-muted);
	font-size: .85rem;
	font-style: italic;
	text-align: center;
	margin-top: .75rem;
}

/* ----- Body layout: content + sidebar ----- */
.jb-post__body {
	display: grid;
	grid-template-columns: 1fr;
	gap: 3rem;
	max-width: var(--jb-blog-max);
	margin: 0 auto;
	padding: 0 1.25rem;
}
@media (min-width: 1024px) {
	.jb-post__body {
		grid-template-columns: minmax(0, 1fr) 280px;
		gap: 4rem;
		padding: 0 2rem;
	}
}

.jb-post__main {
	min-width: 0;
}
.jb-post__main > * { max-width: var(--jb-blog-prose-max); margin-left: auto; margin-right: auto; }
@media (min-width: 1024px) {
	.jb-post__main > * { margin-left: 0; }
}

/* ==========================================================================
   PROSE — every element styled
   ========================================================================== */

.jb-prose {
	color: var(--jb-blog-ink-2);
	font-size: 1.08rem;
	line-height: 1.75;
}

.jb-prose > * + * { margin-top: 1.35em; }

/* Headings inside prose */
.jb-prose h2,
.jb-prose h3,
.jb-prose h4,
.jb-prose h5,
.jb-prose h6 {
	font-family: var(--jb-blog-font-head);
	color: var(--jb-blog-ink);
	font-weight: 800;
	letter-spacing: -0.01em;
	line-height: 1.2;
	scroll-margin-top: 100px;
}
.jb-prose h2 {
	font-size: clamp(1.5rem, 3vw, 2rem);
	margin: 2.2em 0 .6em;
	padding-top: .4em;
	position: relative;
}
.jb-prose h2::before {
	content: "";
	display: block;
	width: 48px;
	height: 4px;
	border-radius: 4px;
	background: linear-gradient(90deg, var(--jb-blog-blue), var(--jb-blog-purple));
	margin-bottom: .6em;
}
.jb-prose h3 {
	font-size: clamp(1.25rem, 2.4vw, 1.5rem);
	margin: 1.8em 0 .5em;
	color: var(--jb-blog-ink);
}
.jb-prose h4 {
	font-size: 1.15rem;
	margin: 1.6em 0 .4em;
	color: var(--jb-blog-ink);
}
.jb-prose h5 {
	font-size: 1.05rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--jb-blog-blue-deep);
	margin: 1.5em 0 .4em;
	font-weight: 800;
}
.jb-prose h6 {
	font-size: .9rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jb-blog-muted);
	margin: 1.4em 0 .4em;
}

/* Paragraphs */
.jb-prose p {
	margin: 0 0 1.35em;
	text-wrap: pretty;
}
.jb-prose p:last-child {
	margin-bottom: 0;
}

/* Lead paragraph (first paragraph) */
.jb-prose > p:first-of-type {
	font-size: 1.2rem;
	line-height: 1.6;
	color: var(--jb-blog-ink);
}
.jb-prose > p:first-of-type::first-letter {
	font-family: var(--jb-blog-font-head);
	font-weight: 800;
	float: left;
	font-size: 3.4em;
	line-height: .9;
	padding: .12em .15em 0 0;
	color: var(--jb-blog-blue-deep);
}

/* Inline text */
.jb-prose a {
	color: var(--jb-blog-blue-deep);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
	text-decoration-color: rgba(0,119,204,.35);
	transition: color .15s ease, text-decoration-color .15s ease;
	font-weight: 600;
}
.jb-prose a:hover {
	color: var(--jb-blog-red);
	text-decoration-color: var(--jb-blog-red);
}
.jb-prose strong, .jb-prose b { color: var(--jb-blog-ink); font-weight: 700; }
.jb-prose em, .jb-prose i { font-style: italic; }
.jb-prose small { font-size: .85em; color: var(--jb-blog-muted); }
.jb-prose sub, .jb-prose sup { font-size: .75em; line-height: 0; position: relative; vertical-align: baseline; }
.jb-prose sup { top: -0.5em; }
.jb-prose sub { bottom: -0.25em; }
.jb-prose abbr[title] {
	text-decoration: underline dotted;
	text-underline-offset: 3px;
	cursor: help;
	border: 0;
}
.jb-prose mark {
	background: linear-gradient(180deg, transparent 60%, var(--jb-blog-yellow) 60%);
	color: var(--jb-blog-ink);
	padding: 0 .15em;
	border-radius: 2px;
}
.jb-prose del, .jb-prose s { color: var(--jb-blog-muted-2); text-decoration: line-through; }
.jb-prose ins, .jb-prose u { text-decoration: underline; text-decoration-color: var(--jb-blog-green); text-underline-offset: 3px; }
.jb-prose kbd {
	font-family: var(--jb-blog-font-mono);
	font-size: .85em;
	background: var(--jb-blog-bg-soft);
	border: 1px solid var(--jb-blog-line);
	border-bottom-width: 2px;
	border-radius: 6px;
	padding: .1em .45em;
	color: var(--jb-blog-ink);
	white-space: nowrap;
	box-shadow: 0 1px 0 rgba(13,27,61,.05);
}
.jb-prose code:not(pre code) {
	font-family: var(--jb-blog-font-mono);
	font-size: .9em;
	background: var(--jb-blog-bg-soft);
	color: var(--jb-blog-red);
	padding: .15em .45em;
	border-radius: 6px;
	border: 1px solid var(--jb-blog-line-2);
	word-break: break-word;
}
.jb-prose q { quotes: "\201C" "\201D" "\2018" "\2019"; }
.jb-prose q::before { content: open-quote; }
.jb-prose q::after { content: close-quote; }
.jb-prose cite { font-style: italic; color: var(--jb-blog-muted); }

/* Lists */
.jb-prose ul,
.jb-prose ol {
	padding-left: 1.5em;
	margin: 1em 0;
}
.jb-prose ul > li,
.jb-prose ol > li {
	margin: .5em 0;
	padding-left: .25em;
}
.jb-prose ul > li::marker { color: var(--jb-blog-blue); }
.jb-prose ol > li::marker { color: var(--jb-blog-blue-deep); font-weight: 700; }
.jb-prose ul ul,
.jb-prose ul ol,
.jb-prose ol ul,
.jb-prose ol ol { margin: .35em 0; }

/* Task lists */
.jb-prose ul.task-list { list-style: none; padding-left: 0; }
.jb-prose ul.task-list > li { padding-left: 1.75em; position: relative; }
.jb-prose ul.task-list > li input[type="checkbox"] {
	position: absolute;
	left: 0;
	top: .35em;
	width: 1.1em;
	height: 1.1em;
	accent-color: var(--jb-blog-blue);
}

/* Description lists */
.jb-prose dl {
	margin: 1.5em 0;
	padding: 1.25em 1.5em;
	background: var(--jb-blog-bg-soft);
	border-radius: var(--jb-blog-radius);
	border-left: 4px solid var(--jb-blog-blue);
}
.jb-prose dl > div + div { margin-top: .75em; }
.jb-prose dt {
	font-weight: 800;
	color: var(--jb-blog-ink);
	font-family: var(--jb-blog-font-head);
	font-size: .95rem;
	text-transform: uppercase;
	letter-spacing: .04em;
	margin-bottom: .2em;
}
.jb-prose dd {
	margin: 0 0 .5em;
	color: var(--jb-blog-ink-2);
}

/* Blockquote */
.jb-prose blockquote {
	margin: 2em 0;
	padding: 1.5em 1.75em;
	border-radius: var(--jb-blog-radius);
	background: linear-gradient(135deg, rgba(0,166,255,.07), rgba(123,63,242,.05));
	border-left: 6px solid var(--jb-blog-blue);
	position: relative;
	font-size: 1.12rem;
	line-height: 1.6;
	color: var(--jb-blog-ink);
	font-style: italic;
}
.jb-prose blockquote::before {
	content: "\201C";
	position: absolute;
	top: -.3em;
	left: .4em;
	font-family: Georgia, serif;
	font-size: 4.5em;
	line-height: 1;
	color: var(--jb-blog-blue);
	opacity: .18;
	pointer-events: none;
}
.jb-prose blockquote p { margin: 0; }
.jb-prose blockquote p + p { margin-top: .8em; }
.jb-prose blockquote cite,
.jb-prose blockquote footer {
	display: block;
	margin-top: 1em;
	font-size: .9rem;
	color: var(--jb-blog-muted);
	font-style: normal;
	font-weight: 600;
}
.jb-prose blockquote cite::before,
.jb-prose blockquote footer::before { content: "\2014  "; }

/* Pull quote variant */
.jb-prose blockquote.pullquote,
.jb-prose blockquote.wp-block-pullquote {
	border-left: 0;
	border-top: 3px solid var(--jb-blog-ink);
	border-bottom: 3px solid var(--jb-blog-ink);
	background: transparent;
	text-align: center;
	font-family: var(--jb-blog-font-head);
	font-size: 1.5rem;
	line-height: 1.3;
	padding: 1.5em 1em;
}
.jb-prose blockquote.pullquote::before,
.jb-prose blockquote.wp-block-pullquote::before { display: none; }

/* Code blocks */
.jb-prose pre {
	background: #0d1b3d;
	color: #eaf0fb;
	border-radius: var(--jb-blog-radius);
	padding: 1.25em 1.4em;
	overflow-x: auto;
	margin: 1.8em 0;
	font-family: var(--jb-blog-font-mono);
	font-size: .92rem;
	line-height: 1.65;
	box-shadow: var(--jb-blog-shadow);
	position: relative;
}
.jb-prose pre::before {
	content: "";
	position: absolute;
	top: 10px;
	left: 14px;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: #ff5f57;
	box-shadow:
		18px 0 0 #febc2e,
		36px 0 0 #28c840;
	opacity: .7;
}
.jb-prose pre code {
	background: transparent;
	border: 0;
	color: inherit;
	padding: 0;
	font-size: inherit;
	display: block;
	margin-top: 1.5em;
}

/* Images + figures */
.jb-prose img,
.jb-prose figure img {
	width: 100%;
	height: auto;
	border-radius: var(--jb-blog-radius);
	display: block;
	box-shadow: var(--jb-blog-shadow);
}
.jb-prose figure {
	margin: 2em 0;
}
.jb-prose figure.alignwide,
.jb-prose .wp-block-image.alignwide { margin-left: -2em; margin-right: -2em; max-width: calc(100% + 4em); }
.jb-prose figure.alignfull,
.jb-prose .wp-block-image.alignfull { margin-left: calc(50% - 50vw); margin-right: calc(50% - 50vw); max-width: 100vw; }
.jb-prose figure.alignfull img,
.jb-prose .wp-block-image.alignfull img { border-radius: 0; }
.jb-prose figcaption {
	margin-top: .75em;
	font-size: .88rem;
	color: var(--jb-blog-muted);
	text-align: center;
	font-style: italic;
	line-height: 1.5;
}
.jb-prose .alignleft  { float: left;  margin: .5em 1.5em 1em 0; max-width: 50%; }
.jb-prose .alignright { float: right; margin: .5em 0 1em 1.5em; max-width: 50%; }
.jb-prose .aligncenter { margin-left: auto; margin-right: auto; text-align: center; }

/* Tables */
.jb-prose table,
.jb-prose .wp-block-table table {
	width: 100%;
	border-collapse: separate;
	border-spacing: 0;
	margin: 2em 0;
	font-size: .95rem;
	border-radius: var(--jb-blog-radius);
	overflow: hidden;
	box-shadow: var(--jb-blog-shadow);
	background: #fff;
}
.jb-prose table caption {
	caption-side: top;
	text-align: left;
	font-weight: 700;
	padding: 0 0 .5em;
	color: var(--jb-blog-muted);
	font-size: .88rem;
	text-transform: uppercase;
	letter-spacing: .05em;
}
.jb-prose th,
.jb-prose td {
	padding: .85em 1em;
	text-align: left;
	vertical-align: top;
	border-bottom: 1px solid var(--jb-blog-line);
}
.jb-prose thead th {
	background: var(--jb-blog-ink);
	color: #fff;
	font-family: var(--jb-blog-font-head);
	font-weight: 800;
	font-size: .82rem;
	text-transform: uppercase;
	letter-spacing: .06em;
	border-bottom: 0;
}
.jb-prose tbody tr:nth-child(even) { background: var(--jb-blog-bg-soft); }
.jb-prose tbody tr:hover { background: #eef6ff; }
.jb-prose tbody tr:last-child td { border-bottom: 0; }

/* Horizontal rule */
.jb-prose hr {
	border: 0;
	height: 1px;
	background: var(--jb-blog-line);
	margin: 3em auto;
	position: relative;
}
.jb-prose hr::after {
	content: "\2726 \00a0 \2726 \00a0 \2726";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	background: #fff;
	padding: 0 .9em;
	color: var(--jb-blog-blue);
	font-size: .8rem;
	letter-spacing: .2em;
}

/* Details/summary */
.jb-prose details {
	background: var(--jb-blog-bg-soft);
	border: 1px solid var(--jb-blog-line);
	border-radius: var(--jb-blog-radius);
	padding: 1em 1.25em;
	margin: 1.5em 0;
	transition: box-shadow .15s ease;
}
.jb-prose details[open] { box-shadow: var(--jb-blog-shadow); background: #fff; }
.jb-prose details summary {
	font-weight: 700;
	color: var(--jb-blog-ink);
	cursor: pointer;
	font-family: var(--jb-blog-font-head);
	list-style: none;
	display: flex;
	align-items: center;
	gap: .5em;
}
.jb-prose details summary::-webkit-details-marker { display: none; }
.jb-prose details summary::before {
	content: "+";
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: var(--jb-blog-blue);
	color: #fff;
	font-weight: 800;
	font-size: 1rem;
	transition: transform .2s ease;
}
.jb-prose details[open] summary::before { transform: rotate(45deg); }
.jb-prose details > *:not(summary) { margin-top: .75em; }

/* Embeds / iframes / video */
.jb-prose iframe,
.jb-prose video,
.jb-prose embed,
.jb-prose object {
	max-width: 100%;
	width: 100%;
	aspect-ratio: 16 / 9;
	height: auto;
	border-radius: var(--jb-blog-radius);
	border: 0;
	background: #000;
	box-shadow: var(--jb-blog-shadow);
	margin: 1.5em 0;
}

/* WordPress galleries */
.jb-prose .wp-block-gallery,
.jb-prose .gallery {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
	gap: .75em;
	margin: 2em 0;
	padding: 0;
	list-style: none;
}
.jb-prose .wp-block-gallery .blocks-gallery-item,
.jb-prose .gallery .gallery-item {
	margin: 0;
	list-style: none;
}

/* WP "more" marker */
.jb-prose .more-link {
	display: inline-block;
	margin-top: 1em;
}

/* ==========================================================================
   SIDEBAR
   ========================================================================== */

.jb-post__aside {
	min-width: 0;
}
.jb-post__aside-inner {
	position: sticky;
	top: 160px;
	display: flex;
	flex-direction: column;
	gap: 1.5rem;
}
.jb-widget {
	background: var(--jb-blog-bg-soft);
	border: 1px solid var(--jb-blog-line);
	border-radius: var(--jb-blog-radius);
	padding: 1.25rem 1.35rem;
}
.jb-widget__title {
	font-family: var(--jb-blog-font-head);
	font-size: .8rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jb-blog-blue-deep);
	margin: 0 0 .85rem;
}
.jb-widget ul {
	list-style: none;
	margin: 0;
	padding: 0;
}
.jb-widget li + li { margin-top: .55rem; padding-top: .55rem; border-top: 1px solid var(--jb-blog-line-2); }
.jb-widget a {
	color: var(--jb-blog-ink);
	text-decoration: none;
	font-weight: 600;
	font-size: .95rem;
	line-height: 1.35;
	display: block;
}
.jb-widget a:hover { color: var(--jb-blog-blue-deep); }

/* Sidebar CTA */
.jb-widget--cta .jb-widget-cta__text {
	margin: 0 0 1rem;
	color: var(--jb-blog-ink-2);
	font-size: .92rem;
	line-height: 1.55;
}
.jb-widget--cta .jb-widget-cta__btn {
	display: flex;
	width: 100%;
	padding: .75rem 1rem;
	font-size: .92rem;
}
.jb-widget--cta .jb-widget-cta__btn + .jb-widget-cta__btn {
	margin-top: .55rem;
}

/* Table of contents */
.jb-toc ol {
	list-style: none;
	counter-reset: toc;
	margin: 0;
	padding: 0;
}
.jb-toc li {
	counter-increment: toc;
	margin: 0;
	padding-left: 0;
}
.jb-toc li + li { margin-top: .35rem; padding-top: .35rem; border-top: 1px solid var(--jb-blog-line-2); }
.jb-toc a {
	display: flex;
	align-items: flex-start;
	gap: .6em;
	font-size: .9rem;
	line-height: 1.4;
	padding: .15rem 0;
}
.jb-toc a::before {
	content: counter(toc, decimal-leading-zero);
	color: var(--jb-blog-blue);
	font-family: var(--jb-blog-font-head);
	font-weight: 800;
	font-size: .85em;
	flex-shrink: 0;
	min-width: 1.8em;
}
.jb-toc li.is-h3 a { padding-left: 1.8em; font-size: .85rem; color: var(--jb-blog-muted); }
.jb-toc li.is-h3 a::before { display: none; }

/* Share widget */
.jb-share {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
}
.jb-widget a.jb-share__btn,
.jb-share__btn {
	display: inline-flex;
	align-items: center;
	gap: .4em;
	padding: .55rem .85rem;
	background: #fff;
	color: var(--jb-blog-ink);
	border: 1px solid var(--jb-blog-line);
	border-radius: 999px;
	font-size: .82rem;
	font-weight: 700;
	text-decoration: none;
	transition: background .15s ease, color .15s ease, border-color .15s ease, transform .15s ease;
}
.jb-widget a.jb-share__btn:hover,
.jb-share__btn:hover {
	background: var(--jb-blog-ink);
	color: #fff;
	border-color: var(--jb-blog-ink);
	transform: translateY(-1px);
}
.jb-share__btn svg { width: 14px; height: 14px; }

/* ==========================================================================
   TAGS + AUTHOR BIO + PREV/NEXT
   ========================================================================== */

.jb-post__tags {
	max-width: var(--jb-blog-prose-max);
	margin: 2.5rem auto 0;
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
	align-items: center;
}
@media (min-width: 1024px) {
	.jb-post__tags { margin-left: 0; }
}
.jb-post__tags-label {
	font-size: .78rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jb-blog-muted);
	margin-right: .35rem;
}
.jb-post__tag {
	display: inline-flex;
	align-items: center;
	gap: .3em;
	padding: .35rem .85rem;
	background: var(--jb-blog-bg-soft);
	border: 1px solid var(--jb-blog-line);
	border-radius: 999px;
	color: var(--jb-blog-ink);
	text-decoration: none;
	font-size: .85rem;
	font-weight: 600;
	transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.jb-post__tag::before { content: "#"; color: var(--jb-blog-blue); font-weight: 800; }
.jb-post__tag:hover {
	background: var(--jb-blog-blue);
	color: #fff;
	border-color: var(--jb-blog-blue);
}
.jb-post__tag:hover::before { color: #fff; }

.jb-author-bio {
	max-width: var(--jb-blog-prose-max);
	margin: 3rem auto 0;
	padding: 1.75rem 1.75rem;
	background: linear-gradient(135deg, #fff 60%, var(--jb-blog-bg-cream));
	border: 1px solid var(--jb-blog-line);
	border-radius: var(--jb-blog-radius-lg);
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	box-shadow: var(--jb-blog-shadow);
}
@media (min-width: 540px) {
	.jb-author-bio {
		grid-template-columns: auto 1fr;
		align-items: center;
		gap: 1.5rem;
	}
}
@media (min-width: 1024px) {
	.jb-author-bio { margin-left: 0; }
}
.jb-author-bio__avatar {
	width: 84px;
	height: 84px;
	border-radius: 50%;
	object-fit: cover;
	border: 4px solid #fff;
	box-shadow: var(--jb-blog-shadow);
}
.jb-author-bio__label {
	font-size: .75rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	font-weight: 800;
	color: var(--jb-blog-blue-deep);
	margin: 0 0 .15rem;
}
.jb-author-bio__name {
	font-family: var(--jb-blog-font-head);
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--jb-blog-ink);
	margin: 0 0 .35rem;
}
.jb-author-bio__name a { color: inherit; text-decoration: none; }
.jb-author-bio__name a:hover { color: var(--jb-blog-blue-deep); }
.jb-author-bio__desc {
	margin: 0;
	color: var(--jb-blog-ink-2);
	line-height: 1.55;
}

/* Prev / Next */
.jb-post__nav {
	max-width: var(--jb-blog-prose-max);
	margin: 3rem auto 0;
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
}
@media (min-width: 640px) {
	.jb-post__nav { grid-template-columns: 1fr 1fr; gap: 1.25rem; }
}
@media (min-width: 1024px) {
	.jb-post__nav { margin-left: 0; }
}
.jb-post__nav a {
	display: block;
	padding: 1.15rem 1.35rem;
	background: #fff;
	border: 1px solid var(--jb-blog-line);
	border-radius: var(--jb-blog-radius);
	color: var(--jb-blog-ink);
	text-decoration: none;
	transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.jb-post__nav a:hover {
	border-color: var(--jb-blog-blue);
	box-shadow: var(--jb-blog-shadow);
	transform: translateY(-2px);
}
.jb-post__nav-label {
	display: block;
	font-size: .72rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jb-blog-muted);
	font-weight: 800;
	margin-bottom: .35rem;
}
.jb-post__nav-title {
	font-family: var(--jb-blog-font-head);
	font-weight: 700;
	color: var(--jb-blog-ink);
	line-height: 1.3;
}
.jb-post__nav--next { text-align: right; }

/* ==========================================================================
   RELATED POSTS
   ========================================================================== */

.jb-related {
	padding: clamp(3rem, 6vw, 5rem) 0;
	background: var(--jb-blog-bg-soft);
	margin-top: 4rem;
}
.jb-related__head {
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	justify-content: space-between;
	gap: 1rem;
	margin-bottom: 2rem;
}
.jb-related__eyebrow {
	font-size: .78rem;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--jb-blog-blue-deep);
	font-weight: 800;
	margin: 0 0 .35rem;
}
.jb-related__title {
	font-family: var(--jb-blog-font-head);
	font-size: clamp(1.4rem, 3vw, 1.9rem);
	color: var(--jb-blog-ink);
	margin: 0;
	font-weight: 800;
	line-height: 1.2;
}
.jb-related__note {
	color: var(--jb-blog-muted);
	font-size: .85rem;
	max-width: 40ch;
}

/* ==========================================================================
   POST CARD — shared by archive, home, related
   ========================================================================== */

.jb-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1.5rem;
}
@media (min-width: 640px) { .jb-grid { grid-template-columns: repeat(2, 1fr); gap: 1.75rem; } }
@media (min-width: 1024px) { .jb-grid { grid-template-columns: repeat(3, 1fr); gap: 2rem; } }

.jb-post-card {
	display: flex;
	flex-direction: column;
	background: #fff;
	border-radius: var(--jb-blog-radius-lg);
	overflow: hidden;
	text-decoration: none;
	color: inherit;
	box-shadow: 0 2px 10px rgba(13,27,61,.06);
	border: 1px solid var(--jb-blog-line-2);
	transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
	height: 100%;
}
.jb-post-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--jb-blog-shadow-lg);
	border-color: var(--jb-blog-blue);
}
.jb-post-card__media {
	position: relative;
	aspect-ratio: 16 / 10;
	background: var(--jb-blog-bg-soft);
	overflow: hidden;
}
.jb-post-card__media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform .4s ease;
}
.jb-post-card:hover .jb-post-card__media img { transform: scale(1.04); }
.jb-post-card__media--empty {
	display: flex;
	align-items: center;
	justify-content: center;
	background:
		repeating-linear-gradient(45deg, transparent 0 12px, rgba(0,166,255,.08) 12px 13px),
		linear-gradient(135deg, #f0f9ff, #e7eefa);
	color: var(--jb-blog-blue);
}
.jb-post-card__cat {
	position: absolute;
	top: .9rem;
	left: .9rem;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: .3em;
	background: var(--jb-blog-ink);
	color: #fff;
	font-size: .7rem;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .08em;
	padding: .35rem .7rem;
	border-radius: 999px;
	text-decoration: none;
	box-shadow: 0 4px 14px rgba(13,27,61,.24);
}
.jb-post-card__body {
	padding: 1.15rem 1.35rem 1.35rem;
	display: flex;
	flex-direction: column;
	gap: .7rem;
	flex: 1;
}
.jb-post-card__title {
	font-family: var(--jb-blog-font-head);
	font-size: 1.2rem;
	line-height: 1.25;
	color: var(--jb-blog-ink);
	margin: 0;
	font-weight: 800;
	letter-spacing: -0.01em;
	text-wrap: balance;
}
.jb-post-card__excerpt {
	margin: 0;
	color: var(--jb-blog-muted);
	font-size: .94rem;
	line-height: 1.55;
	display: -webkit-box;
	-webkit-line-clamp: 3;
	-webkit-box-orient: vertical;
	overflow: hidden;
}
.jb-post-card__meta {
	margin-top: auto;
	padding-top: .6rem;
	border-top: 1px solid var(--jb-blog-line-2);
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .35rem .8rem;
	color: var(--jb-blog-muted);
	font-size: .82rem;
}
.jb-post-card__meta strong { color: var(--jb-blog-ink); font-weight: 700; }
.jb-post-card__read {
	display: inline-flex;
	align-items: center;
	gap: .3em;
	font-weight: 700;
	color: var(--jb-blog-blue-deep);
	font-size: .85rem;
	margin-left: auto;
}
.jb-post-card__read::after {
	content: "\2192";
	transition: transform .2s ease;
}
.jb-post-card:hover .jb-post-card__read::after { transform: translateX(3px); }

/* Featured card (first post on archive) */
.jb-grid--featured { grid-template-columns: 1fr; }
.jb-post-card--featured {
	grid-column: 1 / -1;
	display: grid;
	grid-template-columns: 1fr;
}
@media (min-width: 900px) {
	.jb-post-card--featured { grid-template-columns: 1.15fr 1fr; }
	.jb-post-card--featured .jb-post-card__media { aspect-ratio: auto; height: 100%; min-height: 340px; }
	.jb-post-card--featured .jb-post-card__body { padding: 2rem 2.25rem; justify-content: center; gap: 1rem; }
	.jb-post-card--featured .jb-post-card__title { font-size: clamp(1.5rem, 2.5vw, 2rem); }
	.jb-post-card--featured .jb-post-card__excerpt { font-size: 1.02rem; -webkit-line-clamp: 4; }
}

/* ==========================================================================
   BLOG HOME / ARCHIVE
   ========================================================================== */

.jb-archive__hero {
	background:
		radial-gradient(ellipse at 80% 10%, rgba(0,166,255,.35), transparent 55%),
		radial-gradient(ellipse at 5% 90%, rgba(123,63,242,.22), transparent 50%),
		linear-gradient(180deg, #0d1b3d 0%, #142a5c 100%);
	color: #fff;
	padding: clamp(3.5rem, 7vw, 5.5rem) 0 clamp(3rem, 6vw, 4.5rem);
	text-align: center;
}
.jb-archive__eyebrow {
	display: inline-block;
	font-family: var(--jb-blog-font-head);
	font-size: .82rem;
	text-transform: uppercase;
	letter-spacing: .2em;
	color: var(--jb-blog-yellow);
	font-weight: 800;
	margin: 0 0 .75rem;
}
.jb-archive__title {
	font-family: var(--jb-blog-font-head);
	font-size: clamp(2.25rem, 5vw, 3.5rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.01em;
	margin: 0 0 1rem;
	color: #fff;
	text-wrap: balance;
}
.jb-archive__lede {
	max-width: 60ch;
	margin: 0 auto;
	color: #c8d0e0;
	font-size: 1.08rem;
	line-height: 1.6;
}

.jb-archive__body {
	padding: clamp(2.5rem, 5vw, 4rem) 0;
}
.jb-archive__empty {
	text-align: center;
	padding: 3rem 1rem;
	color: var(--jb-blog-muted);
	background: var(--jb-blog-bg-soft);
	border-radius: var(--jb-blog-radius);
	border: 1px dashed var(--jb-blog-line);
}

/* Pagination */
.jb-pagination {
	margin: 3rem 0 0;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: .4rem;
}
.jb-pagination .page-numbers {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 44px;
	height: 44px;
	padding: 0 .85rem;
	border-radius: 999px;
	background: #fff;
	border: 1px solid var(--jb-blog-line);
	color: var(--jb-blog-ink);
	text-decoration: none;
	font-weight: 700;
	font-size: .92rem;
	transition: background .15s ease, color .15s ease, border-color .15s ease;
}
.jb-pagination .page-numbers:hover {
	background: var(--jb-blog-blue);
	color: #fff;
	border-color: var(--jb-blog-blue);
}
.jb-pagination .page-numbers.current {
	background: var(--jb-blog-ink);
	color: #fff;
	border-color: var(--jb-blog-ink);
}
.jb-pagination .page-numbers.dots {
	background: transparent;
	border-color: transparent;
}

/* ==========================================================================
   SEARCH FORM
   ========================================================================== */

.jb-search-form {
	max-width: 540px;
	margin: 1.5rem auto 0;
	display: flex;
	background: #fff;
	border-radius: 999px;
	overflow: hidden;
	box-shadow: var(--jb-blog-shadow-lg);
}
.jb-search-form input[type="search"] {
	flex: 1;
	border: 0;
	padding: .95rem 1.35rem;
	font-size: 1rem;
	color: var(--jb-blog-ink);
	background: transparent;
	font-family: inherit;
	min-width: 0;
}
.jb-search-form input[type="search"]:focus { outline: 0; }
.jb-search-form button {
	border: 0;
	background: var(--jb-blog-blue);
	color: #fff;
	padding: 0 1.5rem;
	font-weight: 800;
	font-family: var(--jb-blog-font-head);
	font-size: 1rem;
	cursor: pointer;
	transition: background .15s ease;
}
.jb-search-form button:hover { background: var(--jb-blog-blue-deep); }

/* ==========================================================================
   COMMENTS
   ========================================================================== */

.jb-comments {
	max-width: var(--jb-blog-prose-max);
	margin: 4rem auto 0;
	padding: 0 1.25rem;
}
@media (min-width: 1024px) {
	.jb-comments { margin-left: auto; margin-right: auto; padding: 0; }
}

.jb-comments__title {
	font-family: var(--jb-blog-font-head);
	font-size: clamp(1.35rem, 2.5vw, 1.75rem);
	font-weight: 800;
	color: var(--jb-blog-ink);
	margin: 0 0 1.5rem;
	letter-spacing: -0.01em;
}
.jb-comments__count {
	color: var(--jb-blog-blue-deep);
}

.jb-comments__list {
	list-style: none;
	padding: 0;
	margin: 0 0 2.5rem;
}
.jb-comments__list ol.children {
	list-style: none;
	padding: 1rem 0 0 clamp(1rem, 3vw, 2.5rem);
	margin: 0;
	border-left: 3px solid var(--jb-blog-line-2);
	margin-left: 20px;
}

.jb-comment {
	padding: 1.25rem 1.35rem;
	margin: 0 0 1rem;
	background: var(--jb-blog-bg-soft);
	border-radius: var(--jb-blog-radius);
	border: 1px solid var(--jb-blog-line-2);
}
.jb-comment.bypostauthor {
	background: linear-gradient(135deg, #fff 60%, var(--jb-blog-bg-cream));
	border-color: var(--jb-blog-yellow);
}
.jb-comment__head {
	display: flex;
	align-items: center;
	gap: .85rem;
	margin-bottom: .75rem;
}
.jb-comment__avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	flex-shrink: 0;
	border: 2px solid #fff;
	box-shadow: 0 2px 6px rgba(13,27,61,.1);
}
.jb-comment__who {
	display: flex;
	flex-direction: column;
	min-width: 0;
}
.jb-comment__author {
	font-weight: 800;
	color: var(--jb-blog-ink);
	font-family: var(--jb-blog-font-head);
	font-size: 1rem;
	line-height: 1.2;
}
.jb-comment__author a { color: inherit; text-decoration: none; }
.jb-comment__author a:hover { color: var(--jb-blog-blue-deep); }
.jb-comment__badge {
	display: inline-block;
	margin-left: .4em;
	padding: .1rem .5rem;
	font-size: .65rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	background: var(--jb-blog-yellow);
	color: var(--jb-blog-ink);
	border-radius: 999px;
	font-weight: 800;
	vertical-align: 2px;
}
.jb-comment__date {
	color: var(--jb-blog-muted);
	font-size: .82rem;
	text-decoration: none;
}
.jb-comment__date:hover { color: var(--jb-blog-blue-deep); }
.jb-comment__body {
	color: var(--jb-blog-ink-2);
	line-height: 1.65;
}
.jb-comment__body > * + * { margin-top: .8em; }
.jb-comment__body p { margin: 0; }
.jb-comment__body a { color: var(--jb-blog-blue-deep); }
.jb-comment__footer {
	margin-top: .85rem;
	display: flex;
	gap: 1rem;
	font-size: .82rem;
}
.jb-comment__reply a,
.jb-comment__edit a {
	color: var(--jb-blog-blue-deep);
	text-decoration: none;
	font-weight: 700;
}
.jb-comment__reply a:hover,
.jb-comment__edit a:hover {
	text-decoration: underline;
	color: var(--jb-blog-red);
}
.jb-comment--awaiting {
	color: var(--jb-blog-muted);
	font-style: italic;
	font-size: .88rem;
	margin: .5rem 0 0;
}

/* Comment form */
.jb-comment-form {
	background: #fff;
	border: 1px solid var(--jb-blog-line);
	border-radius: var(--jb-blog-radius-lg);
	padding: 1.75rem;
	box-shadow: var(--jb-blog-shadow);
}
.jb-comment-form__title {
	font-family: var(--jb-blog-font-head);
	font-size: 1.25rem;
	font-weight: 800;
	color: var(--jb-blog-ink);
	margin: 0 0 .5rem;
}
.jb-comment-form__note {
	margin: 0 0 1.25rem;
	color: var(--jb-blog-muted);
	font-size: .9rem;
}
.jb-comment-form .comment-notes,
.jb-comment-form .logged-in-as {
	color: var(--jb-blog-muted);
	font-size: .9rem;
	margin: 0 0 1.25rem;
}
.jb-comment-form .logged-in-as a { color: var(--jb-blog-blue-deep); font-weight: 700; }
.jb-comment-form .comment-form-fields {
	display: grid;
	grid-template-columns: 1fr;
	gap: 1rem;
	margin-bottom: 1.25rem;
}
@media (min-width: 640px) {
	.jb-comment-form .comment-form-fields { grid-template-columns: 1fr 1fr; }
	.jb-comment-form .comment-form-url { grid-column: 1 / -1; }
}
.jb-comment-form p { margin: 0 0 1rem; }
.jb-comment-form p:last-child { margin-bottom: 0; }
.jb-comment-form label {
	display: block;
	font-weight: 700;
	color: var(--jb-blog-ink);
	font-size: .85rem;
	letter-spacing: .02em;
	margin-bottom: .35rem;
	font-family: var(--jb-blog-font-head);
}
.jb-comment-form input[type="text"],
.jb-comment-form input[type="email"],
.jb-comment-form input[type="url"],
.jb-comment-form textarea {
	width: 100%;
	padding: .75rem .95rem;
	border: 1px solid var(--jb-blog-line);
	border-radius: 10px;
	font-size: .98rem;
	font-family: inherit;
	color: var(--jb-blog-ink);
	background: #fff;
	transition: border-color .15s ease, box-shadow .15s ease;
}
.jb-comment-form input[type="text"]:focus,
.jb-comment-form input[type="email"]:focus,
.jb-comment-form input[type="url"]:focus,
.jb-comment-form textarea:focus {
	outline: 0;
	border-color: var(--jb-blog-blue);
	box-shadow: 0 0 0 3px rgba(0,166,255,.2);
}
.jb-comment-form textarea {
	min-height: 140px;
	resize: vertical;
	line-height: 1.55;
}
.jb-comment-form .comment-form-cookies-consent {
	display: flex;
	align-items: center;
	gap: .55rem;
	font-size: .88rem;
	color: var(--jb-blog-muted);
}
.jb-comment-form .comment-form-cookies-consent label {
	font-weight: 500;
	font-family: inherit;
	color: var(--jb-blog-muted);
	font-size: .88rem;
	margin: 0;
}
.jb-comment-form .form-submit { margin: 1.25rem 0 0; }
.jb-comment-form .submit {
	background: var(--jb-blog-blue);
	color: #fff;
	border: 0;
	padding: .85rem 1.75rem;
	border-radius: 999px;
	font-family: var(--jb-blog-font-head);
	font-size: 1rem;
	font-weight: 800;
	letter-spacing: .02em;
	cursor: pointer;
	box-shadow: 0 6px 18px rgba(0,166,255,.3);
	transition: background .15s ease, transform .15s ease;
}
.jb-comment-form .submit:hover {
	background: var(--jb-blog-blue-deep);
	transform: translateY(-2px);
}

.jb-comments__no {
	padding: 1.25rem 1.5rem;
	background: var(--jb-blog-bg-soft);
	border-radius: var(--jb-blog-radius);
	color: var(--jb-blog-muted);
	text-align: center;
	font-style: italic;
	margin: 1rem 0 2rem;
	border: 1px dashed var(--jb-blog-line);
}
.jb-comments__closed {
	padding: 1rem 1.25rem;
	background: var(--jb-blog-bg-soft);
	border-radius: var(--jb-blog-radius);
	color: var(--jb-blog-muted);
	text-align: center;
	font-size: .9rem;
	font-style: italic;
}

.jb-comments__nav {
	display: flex;
	justify-content: space-between;
	margin: 1.5rem 0;
	font-size: .9rem;
}
.jb-comments__nav a {
	color: var(--jb-blog-blue-deep);
	text-decoration: none;
	font-weight: 700;
}
.jb-comments__nav a:hover { color: var(--jb-blog-red); }
