/* Purpose: Journal collection + article (blog detail). Figma 2540:6223 / 2540:7159.
   Dark, BEM, tokens only, mobile-first. */

.journal { background-color: var(--color-bg); color: var(--color-text); }

/* Shared eyebrow (reuses .about-eyebrow markup). */
.journal .about-eyebrow { display: flex; align-items: center; gap: var(--space-3); font-size: var(--text-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--color-primary); margin: 0 0 var(--space-5); }
.journal .about-eyebrow__rule { display: inline-block; width: 28px; height: 1px; background: var(--color-primary); }
.journal .accent { color: var(--color-primary); }

/* ---------------------------------------------------------------- Collection hero */
.jhero { position: relative; padding-block: var(--space-24) var(--space-12); background: radial-gradient(120% 90% at 0% 0%, rgba(255,0,18,0.16), transparent 55%), var(--color-bg); }
.jhero__heading { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: clamp(2.5rem, 6vw, 5rem); line-height: 1.04; letter-spacing: var(--tracking-tight); color: var(--color-text-strong); margin: 0 0 var(--space-7); max-width: 1007px; }
.jhero__intro { font-size: var(--text-md); line-height: var(--leading-normal); color: var(--color-text-muted); max-width: 540px; margin: 0; }

/* ---------------------------------------------------------------- Filters */
.jfilters { border-block: 1px solid var(--color-border); }
.jfilters__inner { display: flex; align-items: center; justify-content: space-between; gap: var(--space-5); padding-block: var(--space-5); flex-wrap: wrap; }
.jfilters__pills { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.jpill { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-muted); border: 1px solid var(--color-border); border-radius: var(--radius-full); padding: var(--space-2) var(--space-5); text-decoration: none; transition: color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out); }
.jpill:hover { color: var(--color-text-strong); border-color: var(--color-text-muted); }
.jpill.is-active { color: #fff; background-color: var(--color-primary); border-color: var(--color-primary); }
.jfilters__sort { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-muted); }
.jfilters__sort strong { color: var(--color-text); font-weight: var(--weight-medium); }

/* ---------------------------------------------------------------- Featured */
.jfeatured { padding-block: var(--space-16); }
.jfeatured__card { display: grid; grid-template-columns: 1fr; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; text-decoration: none; color: inherit; transition: border-color var(--duration-fast) var(--ease-out); }
@media (min-width: 900px) { .jfeatured__card { grid-template-columns: 1fr 1fr; } }
.jfeatured__card:hover { border-color: var(--color-primary); }
.jfeatured__media { position: relative; min-height: 280px; aspect-ratio: 16/12; background: radial-gradient(90% 90% at 60% 30%, rgba(255,0,18,0.25), transparent 60%), var(--color-surface); overflow: hidden; }
.jfeatured__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.jfeatured__flag { position: absolute; top: var(--space-6); left: var(--space-6); font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-strong); background: rgba(0,0,0,0.45); border: 1px solid var(--color-border); border-radius: var(--radius-full); padding: var(--space-2) var(--space-3); backdrop-filter: blur(6px); }
.jfeatured__body { display: flex; flex-direction: column; padding: var(--space-12) var(--space-12) var(--space-10); }
.jfeatured__cat { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-primary); }
.jfeatured__title { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-3xl); line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); color: var(--color-text-strong); margin: var(--space-5) 0; }
.jfeatured__dek { font-size: var(--text-md); line-height: var(--leading-normal); color: var(--color-text-muted); margin: 0 0 var(--space-7); }
.jfeatured__meta { display: flex; flex-wrap: wrap; gap: var(--space-5); font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-8); }
.jfeatured__cta { align-self: flex-start; margin-top: auto; }

/* ---------------------------------------------------------------- Grid */
.jgrid-section { padding-block: var(--space-12) var(--space-24); }
.jgrid__head { display: flex; align-items: baseline; justify-content: space-between; gap: var(--space-5); margin-bottom: var(--space-12); }
.jgrid__heading { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-3xl); color: var(--color-text-strong); margin: 0; }
.jgrid__count { font-size: var(--text-sm); color: var(--color-text-muted); }
.jgrid { display: grid; grid-template-columns: repeat(auto-fill, minmax(min(320px, 100%), 1fr)); gap: var(--space-8); }
.jgrid__empty { color: var(--color-text-muted); }

/* Card */
.jcard { border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; background-color: var(--color-surface); transition: border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out); }
.jcard:hover { border-color: var(--color-primary); transform: translateY(-4px); }
.jcard__link { display: flex; flex-direction: column; height: 100%; text-decoration: none; color: inherit; }
.jcard__media { position: relative; aspect-ratio: 16/10; background: radial-gradient(90% 90% at 60% 30%, rgba(255,0,18,0.18), transparent 60%), var(--color-bg-alt); overflow: hidden; }
.jcard__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; transition: transform var(--duration-slow) var(--ease-out); }
.jcard:hover .jcard__img { transform: scale(1.05); }
.jcard__ph { position: absolute; inset: 0; display: flex; align-items: center; justify-content: center; font-size: var(--text-sm); letter-spacing: var(--tracking-wider); color: var(--color-text-muted); }
.jcard__badge { position: absolute; top: var(--space-5); left: var(--space-5); font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-primary); background: rgba(0,0,0,0.5); border: 1px solid var(--color-border); border-radius: var(--radius-full); padding: 2px var(--space-3); }
.jcard__body { display: flex; flex-direction: column; gap: var(--space-3); padding: var(--space-7); flex: 1 1 auto; }
.jcard__title { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-xl); line-height: var(--leading-snug); color: var(--color-text-strong); margin: 0; }
.jcard__dek { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--color-text-muted); margin: 0; }
.jcard__meta { display: flex; justify-content: space-between; gap: var(--space-3); margin-top: auto; padding-top: var(--space-5); border-top: 1px solid var(--color-border); font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-muted); }

/* Load more */
.jloadmore { display: flex; flex-direction: column; align-items: center; gap: var(--space-5); margin-top: var(--space-16); }
.jloadmore__page { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-muted); }

/* ---------------------------------------------------------------- Newsletter */
.jnews { position: relative; padding-block: var(--space-24); text-align: center; border-top: 1px solid var(--color-border); background: radial-gradient(60% 80% at 50% 40%, rgba(255,0,18,0.20), transparent 70%), var(--color-bg); }
.jnews__inner { max-width: 640px; margin-inline: auto; }
.jnews__heading { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: clamp(2rem, 4vw, 3rem); line-height: var(--leading-tight); color: var(--color-text-strong); margin: 0 0 var(--space-5); }
.jnews__body { font-size: var(--text-md); line-height: var(--leading-normal); color: var(--color-text-muted); margin: 0 auto var(--space-10); max-width: 46ch; }
.jnews__form { display: flex; gap: var(--space-3); max-width: 480px; margin-inline: auto; }
.jnews__input { flex: 1 1 auto; background-color: var(--color-surface); border: 1px solid var(--color-border); border-radius: var(--radius-full); padding: var(--space-4) var(--space-6); color: var(--color-text); font-size: var(--text-md); }
.jnews__input:focus-visible { outline: 2px solid var(--color-primary); outline-offset: 2px; }
.jnews__submit { flex: 0 0 auto; }
.jnews__status { font-size: var(--text-sm); color: var(--color-success); margin-top: var(--space-5); min-height: 1.2em; }

/* ================================================================ ARTICLE (single) */
.jprogress { position: fixed; top: 0; left: 0; height: 3px; width: 0; background: var(--color-primary); z-index: var(--z-overlay); transition: width 80ms linear; }

.jarticle-hero { position: relative; padding-block: var(--space-16) var(--space-12); background: radial-gradient(120% 90% at 0% 0%, rgba(255,0,18,0.16), transparent 55%), var(--color-bg); }
.jbreadcrumb { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-3); font-size: var(--text-sm); color: var(--color-text-muted); margin-bottom: var(--space-8); }
.jbreadcrumb a { color: var(--color-text-muted); text-decoration: none; }
.jbreadcrumb a:hover { color: var(--color-text-strong); }
.jbreadcrumb__current { color: var(--color-text-strong); }
.jarticle-hero__badge { display: inline-block; font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-primary); border: 1px solid var(--color-primary); border-radius: var(--radius-full); padding: var(--space-2) var(--space-5); margin-bottom: var(--space-7); }
.jarticle-hero__title { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: clamp(2.25rem, 5vw, 4rem); line-height: 1.06; letter-spacing: var(--tracking-tight); color: var(--color-text-strong); margin: 0 0 var(--space-7); max-width: 880px; }
.jarticle-hero__dek { font-size: var(--text-xl); line-height: var(--leading-normal); color: var(--color-text-muted); max-width: 680px; margin: 0 0 var(--space-10); }
.jarticle-hero__bar { display: flex; flex-wrap: wrap; align-items: center; gap: var(--space-8); padding-top: var(--space-7); border-top: 1px solid var(--color-border); }
.jauthor { display: flex; align-items: center; gap: var(--space-3); }
.jauthor__avatar { width: 44px; height: 44px; flex: 0 0 auto; display: flex; align-items: center; justify-content: center; border: 1px solid var(--color-border); border-radius: var(--radius-full); overflow: hidden; background-color: var(--color-surface); font-size: var(--text-sm); font-weight: var(--weight-medium); color: var(--color-text-strong); }
.jauthor__img { width: 100%; height: 100%; object-fit: cover; }
.jauthor__meta { display: flex; flex-direction: column; }
.jauthor__name { color: var(--color-text-strong); }
.jauthor__role { font-size: var(--text-sm); color: var(--color-text-muted); }
.jarticle-hero__facts { display: flex; flex-wrap: wrap; gap: var(--space-5); font-size: var(--text-sm); color: var(--color-text-muted); }
.jshare { display: flex; gap: var(--space-3); margin-left: auto; }
.jshare__btn { width: 38px; height: 38px; display: flex; align-items: center; justify-content: center; border: 1px solid var(--color-border); border-radius: var(--radius-full); background: none; color: var(--color-text-muted); cursor: pointer; transition: color var(--duration-fast) var(--ease-out), border-color var(--duration-fast) var(--ease-out); }
.jshare__btn:hover { color: var(--color-text-strong); border-color: var(--color-text-muted); }
.jshare__btn svg { width: 16px; height: 16px; }

/* Hero media */
.jarticle-media { margin: 0; padding-block: var(--space-12); }
.jarticle-media__frame { position: relative; aspect-ratio: 16/9; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; background: radial-gradient(80% 80% at 50% 30%, rgba(255,0,18,0.20), transparent 65%), var(--color-surface); }
.jarticle-media__img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.jbracket { position: absolute; width: 16px; height: 16px; border: 2px solid var(--color-primary); z-index: 2; }
.jbracket--tl { top: 14px; left: 14px; border-right: 0; border-bottom: 0; }
.jbracket--br { bottom: 14px; right: 14px; border-left: 0; border-top: 0; }
.jarticle-media__caption { text-align: center; font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-5); }

/* ---------------- Article body (the_content) ---------------- */
.jarticle-body { padding-block: var(--space-8) var(--space-16); }
.journal-content { max-width: 760px; margin-inline: auto; color: var(--color-text); }
.journal-content > * { margin-inline: auto; }
.journal-content p { font-size: var(--text-md); line-height: var(--leading-loose); color: var(--color-text-muted); margin: 0 0 var(--space-7); }
.journal-content p:first-of-type { font-size: var(--text-lg); color: var(--color-text); }
.journal-content h2 { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-2xl); line-height: var(--leading-tight); letter-spacing: var(--tracking-tight); color: var(--color-text-strong); margin: var(--space-16) 0 var(--space-5); }
.journal-content h3 { font-family: var(--font-body); font-weight: var(--weight-bold); font-size: var(--text-lg); color: var(--color-text-strong); margin: var(--space-10) 0 var(--space-3); }
.journal-content .jsubhead { font-size: var(--text-xs); letter-spacing: var(--tracking-wider); text-transform: uppercase; color: var(--color-primary); margin: var(--space-10) 0 var(--space-3); }
.journal-content a { color: var(--color-primary); text-decoration: underline; text-underline-offset: 3px; }
.journal-content strong { color: var(--color-text-strong); }
.journal-content ul, .journal-content ol { margin: 0 0 var(--space-7); padding-left: var(--space-7); color: var(--color-text-muted); }
.journal-content li { margin-bottom: var(--space-3); line-height: var(--leading-normal); }
.journal-content img, .journal-content figure { max-width: 100%; border-radius: var(--radius-lg); }
.journal-content figure { margin: var(--space-10) 0; }
.journal-content figcaption { font-size: var(--text-sm); color: var(--color-text-muted); margin-top: var(--space-3); text-align: center; }
.journal-content blockquote { margin: var(--space-12) 0; padding: var(--space-8) var(--space-10); border-left: 2px solid var(--color-primary); background-color: var(--color-surface); border-radius: var(--radius-md); }
.journal-content blockquote p { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-xl); line-height: var(--leading-snug); color: var(--color-text-strong); margin: 0; }
.journal-content blockquote cite { display: block; margin-top: var(--space-5); font-style: normal; font-size: var(--text-sm); color: var(--color-text-muted); }

/* In-body stat trio (.jstats) */
.journal-content .jstats { display: grid; grid-template-columns: 1fr; border: 1px solid var(--color-border); border-radius: var(--radius-lg); margin: var(--space-10) 0; max-width: none; }
@media (min-width: 640px) { .journal-content .jstats { grid-template-columns: repeat(3, 1fr); } }
.journal-content .jstat { padding: var(--space-8); border-bottom: 1px solid var(--color-border); }
@media (min-width: 640px) { .journal-content .jstat { border-bottom: 0; border-right: 1px solid var(--color-border); } .journal-content .jstat:last-child { border-right: 0; } }
.journal-content .jstat__value { display: block; font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-3xl); color: var(--color-primary); margin-bottom: var(--space-3); }
.journal-content .jstat__label { display: block; font-size: var(--text-sm); line-height: var(--leading-snug); color: var(--color-text-muted); margin: 0; }
.journal-content .jfig { margin: var(--space-10) 0; border: 1px solid var(--color-border); border-radius: var(--radius-lg); overflow: hidden; }
.journal-content .jfig__media { aspect-ratio: 16/6; background: radial-gradient(80% 90% at 50% 30%, rgba(255,0,18,0.16), transparent 65%), var(--color-surface); }
.journal-content .jfig__cap { display: flex; justify-content: space-between; gap: var(--space-5); padding: var(--space-5) var(--space-7); border-top: 1px solid var(--color-border); font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-text-muted); }

/* Product callout */
.jcallout { max-width: 760px; margin: var(--space-16) auto 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: var(--space-7); padding: var(--space-10); border: 1px solid var(--color-border); border-radius: var(--radius-lg); background: radial-gradient(80% 160% at 0% 0%, rgba(255,0,18,0.16), transparent 60%), var(--color-surface); }
.jcallout__kicker { font-size: var(--text-xs); letter-spacing: var(--tracking-wide); text-transform: uppercase; color: var(--color-primary); }
.jcallout__title { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-2xl); color: var(--color-text-strong); margin: var(--space-3) 0; }
.jcallout__desc { font-size: var(--text-sm); line-height: var(--leading-normal); color: var(--color-text-muted); margin: 0; max-width: 60ch; }
.jcallout__cta { flex: 0 0 auto; }

/* Keep reading */
.jrelated { padding-block: var(--space-16) var(--space-24); border-top: 1px solid var(--color-border); }
.jrelated__heading { font-family: var(--font-heading); font-weight: var(--weight-light); font-size: var(--text-3xl); color: var(--color-text-strong); margin: 0 0 var(--space-12); }

@media (prefers-reduced-motion: reduce) {
	.jcard, .jcard__img, .jfeatured__card { transition: none; }
	.jcard:hover { transform: none; }
	.jprogress { transition: none; }
}
