/* =========================================================
   CXO Technology — Resources hub + Field Notes (article)
   Builds on styles.css tokens
   ========================================================= */

/* ---------- shared topbar strip (matches case studies) ---------- */
.kit-strip { position: sticky; top: 60px; z-index: 40; background: oklch(0.16 0.008 260 / 0.85); backdrop-filter: blur(18px) saturate(140%); -webkit-backdrop-filter: blur(18px) saturate(140%); border-bottom: 1px solid var(--hairline); }
.kit-strip-inner { max-width: var(--maxw); margin: 0 auto; padding: 12px var(--gutter); display: flex; align-items: center; gap: 22px; font-family: 'JetBrains Mono', monospace; font-size: 11px; letter-spacing: 0.04em; overflow-x: auto; scrollbar-width: none; }
.kit-strip-inner::-webkit-scrollbar { display: none; }
.kit-strip .tt { color: var(--accent); text-transform: uppercase; flex-shrink: 0; display: inline-flex; align-items: center; gap: 8px; }
.kit-strip .tt::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 10px var(--accent); }
.kit-strip .ptag { color: var(--text-mute); flex-shrink: 0; }
.kit-strip .ptag b { color: var(--text); font-weight: 500; letter-spacing: 0; }
.kit-strip .sep { color: var(--text-dim); opacity: 0.4; }

/* =========================================================
   HUB — Hero
   ========================================================= */
.res-hero { padding-top: 150px; padding-bottom: 64px; position: relative; overflow: hidden; }
.res-hero .bg-grid {
  position: absolute; inset: 0; pointer-events: none;
  background-image: linear-gradient(to right, var(--hairline) 1px, transparent 1px), linear-gradient(to bottom, var(--hairline) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(ellipse at 50% 0%, black 0%, transparent 62%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 0%, black 0%, transparent 62%);
  opacity: 0.3;
}
.res-hero h1 { margin: 22px 0 22px; max-width: 17ch; }
.res-hero h1 .dim { color: var(--text-dim); }
.res-hero .lead { max-width: 60ch; }
.res-metarow { display: flex; gap: 40px; flex-wrap: wrap; margin-top: 44px; padding-top: 26px; border-top: 1px solid var(--hairline); }
.res-metarow .it .v { font-family: 'Inter Tight'; font-size: 32px; font-weight: 500; letter-spacing: -0.025em; line-height: 1; }
.res-metarow .it .v small { font-size: 14px; color: var(--text-mute); font-weight: 400; margin-left: 3px; }
.res-metarow .it .k { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); letter-spacing: 0.06em; margin-top: 8px; }

.sec-num { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--accent); letter-spacing: 0.14em; text-transform: uppercase; }

/* =========================================================
   WEBINARS
   ========================================================= */
/* featured upcoming webinar */
.wb-feature {
  display: grid; grid-template-columns: 1.15fr 1fr; gap: 0;
  border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden;
  background: linear-gradient(180deg, oklch(0.19 0.010 260 / 0.7), oklch(0.16 0.008 260 / 0.4));
}
.wb-feature-main { padding: 44px 46px; display: flex; flex-direction: column; gap: 20px; }
.wb-live { display: inline-flex; align-items: center; gap: 9px; align-self: flex-start; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--accent); padding: 5px 11px; border-radius: 999px; background: var(--accent-soft); border: 1px solid var(--accent-line); }
.wb-live .pulse { width: 7px; height: 7px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 10px var(--accent); animation: wbPulse 1.8s ease-in-out infinite; }
@keyframes wbPulse { 0%,100% { opacity: 0.5; transform: scale(0.85);} 50% { opacity: 1; transform: scale(1.15);} }
.wb-feature-main h2 { margin: 0; font-family: 'Inter Tight'; font-size: clamp(28px, 3vw, 40px); font-weight: 500; letter-spacing: -0.028em; line-height: 1.08; }
.wb-feature-main .desc { color: var(--text-mute); font-size: 15px; line-height: 1.6; max-width: 52ch; margin: 0; }
.wb-feature-main .with { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-dim); letter-spacing: 0.03em; }
.wb-feature-main .with b { color: var(--text); font-weight: 500; }
.wb-speakers { display: flex; flex-direction: column; gap: 10px; margin-top: 4px; }
.wb-speaker { display: flex; align-items: center; gap: 12px; font-size: 13px; }
.wb-speaker .av { width: 30px; height: 30px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--violet)); flex-shrink: 0; }
.wb-speaker .nm { color: var(--text); font-weight: 500; }
.wb-speaker .ro { color: var(--text-dim); font-family: 'JetBrains Mono', monospace; font-size: 11px; }
.wb-feature-main .cta-row { display: flex; gap: 14px; align-items: center; margin-top: 8px; flex-wrap: wrap; }
.wb-feature-side { border-left: 1px solid var(--hairline); padding: 44px 38px; display: flex; flex-direction: column; gap: 1px; background: oklch(0.13 0.006 260 / 0.4); justify-content: center; }
.wb-fact { padding: 18px 4px; display: flex; flex-direction: column; gap: 6px; border-bottom: 1px solid var(--hairline); }
.wb-fact:last-child { border-bottom: none; }
.wb-fact .k { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 0.1em; text-transform: uppercase; }
.wb-fact .v { font-family: 'Inter Tight'; font-size: 22px; font-weight: 500; letter-spacing: -0.02em; }
.wb-fact .v small { font-size: 13px; color: var(--text-mute); font-weight: 400; }

/* on-demand grid */
.wb-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; margin-top: 24px; }
.wb-card { --brand: var(--accent); background: var(--bg); padding: 0; display: flex; flex-direction: column; min-height: 248px; position: relative; text-decoration: none; transition: background .3s ease; overflow: hidden; }
.wb-card:hover { background: var(--bg-2); }
.wb-card::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--brand), transparent); transform: scaleX(0); transition: transform .45s ease; z-index: 3; }
.wb-card:hover::after { transform: scaleX(1); }

/* === branded banner (faux thumbnail) === */
.wb-banner { position: relative; height: 122px; display: flex; align-items: center; justify-content: center; border-bottom: 1px solid var(--hairline); overflow: hidden;
  background:
    radial-gradient(130% 150% at 82% 0%, color-mix(in oklab, var(--brand) 34%, transparent), transparent 58%),
    linear-gradient(155deg, color-mix(in oklab, var(--brand) 20%, var(--bg)), var(--bg) 78%);
  transition: background .3s ease; }
.wb-banner::before { content: ""; position: absolute; inset: 0; pointer-events: none; opacity: 0.5;
  background-image: linear-gradient(to right, var(--hairline) 1px, transparent 1px), linear-gradient(to bottom, var(--hairline) 1px, transparent 1px);
  background-size: 26px 26px;
  mask-image: radial-gradient(ellipse at 82% 0%, black, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at 82% 0%, black, transparent 70%); }
.wb-logo { position: relative; z-index: 1; display: flex; align-items: center; gap: 11px; }
.wb-logo img { height: 30px; width: auto; filter: drop-shadow(0 2px 12px rgb(0 0 0 / 0.4)); }
.wb-logo .word { font-family: 'Inter Tight'; font-weight: 600; font-size: 24px; letter-spacing: -0.03em; color: #fff; }
.wb-banner .tag2 { position: absolute; top: 12px; left: 14px; z-index: 1; font-family: 'JetBrains Mono', monospace; font-size: 9.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-mute); display: inline-flex; align-items: center; gap: 6px; }
.wb-banner .tag2 .d { width: 5px; height: 5px; border-radius: 50%; background: var(--brand); box-shadow: 0 0 8px var(--brand); }
.wb-banner .dur2 { position: absolute; bottom: 11px; right: 13px; z-index: 1; white-space: nowrap; font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text); background: oklch(0.13 0.006 260 / 0.7); border: 1px solid var(--hairline-2); border-radius: 999px; padding: 3px 9px; backdrop-filter: blur(6px); }
.wb-play { position: absolute; bottom: 11px; left: 13px; z-index: 1; width: 30px; height: 30px; border-radius: 50%; border: 1px solid color-mix(in oklab, var(--brand) 60%, var(--hairline-2)); background: oklch(0.13 0.006 260 / 0.55); display: grid; place-items: center; color: var(--brand); backdrop-filter: blur(6px); transition: background .25s ease, transform .25s ease; }
.wb-play svg { width: 10px; height: 10px; margin-left: 1px; }
.wb-card:hover .wb-play { background: var(--brand); color: #0b0c10; transform: scale(1.08); }

/* === body === */
.wb-body { padding: 22px 24px 20px; display: flex; flex-direction: column; gap: 12px; flex: 1; }
.wb-card h3 { margin: 0; font-family: 'Inter Tight'; font-size: 18px; font-weight: 500; letter-spacing: -0.018em; line-height: 1.28; color: var(--text); }
.wb-card p { margin: 0; font-size: 13px; color: var(--text-mute); line-height: 1.55; flex: 1; }
.wb-card .foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 14px; border-top: 1px solid var(--hairline); }
.wb-card .with { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); display: inline-flex; align-items: center; gap: 8px; }
.wb-card .with img { height: 14px; width: auto; }
.wb-card .with b { color: var(--brand); font-weight: 500; }
.wb-card .views { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); white-space: nowrap; }

/* =========================================================
   FIELD NOTES (stories) — list
   ========================================================= */
.fn-list { display: flex; flex-direction: column; gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; }
.fn-row {
  background: var(--bg); display: grid; grid-template-columns: 78px 1fr 220px; gap: 28px; align-items: center;
  padding: 30px 34px; text-decoration: none; position: relative; transition: background .3s ease;
}
.fn-row:hover { background: var(--bg-2); }
.fn-row .fn-ix { font-family: 'Inter Tight'; font-size: 34px; font-weight: 500; color: var(--text-dim); letter-spacing: -0.03em; line-height: 1; opacity: 0.55; transition: color .3s ease, opacity .3s ease; }
.fn-row:hover .fn-ix { color: var(--accent); opacity: 1; }
.fn-mid { display: flex; flex-direction: column; gap: 10px; min-width: 0; }
.fn-tags { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.fn-role { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--accent); padding: 3px 9px; border-radius: 4px; background: var(--accent-soft); border: 1px solid var(--accent-line); }
.fn-topic { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); }
.fn-mid h3 { margin: 0; font-family: 'Inter Tight'; font-size: 23px; font-weight: 500; letter-spacing: -0.022em; line-height: 1.2; color: var(--text); }
.fn-mid p { margin: 0; font-size: 14px; color: var(--text-mute); line-height: 1.55; max-width: 64ch; }
.fn-meta { text-align: right; display: flex; flex-direction: column; gap: 10px; align-items: flex-end; }
.fn-vendor { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-mute); display: inline-flex; align-items: center; gap: 9px; }
.fn-vendor img { height: 18px; width: auto; opacity: 0.85; }
.fn-vendor .word { font-family: 'Inter Tight'; font-weight: 600; font-size: 16px; letter-spacing: -0.02em; color: var(--text); }
.fn-read { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); }
.fn-arrow { font-family: 'JetBrains Mono', monospace; color: var(--accent); font-size: 13px; transition: transform .25s ease; }
.fn-row:hover .fn-arrow { transform: translateX(4px); }

/* === FIELD NOTES — branded story cards (banner treatment) === */
.fn-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; }
.story-card { --brand: var(--accent); background: var(--bg); display: flex; flex-direction: column; min-height: 372px; text-decoration: none; position: relative; overflow: hidden; transition: background .3s ease; }
.story-card:hover { background: var(--bg-2); }
.story-card::after { content: ""; position: absolute; left: 0; right: 0; bottom: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--brand), transparent); transform: scaleX(0); transition: transform .45s ease; z-index: 3; }
.story-card:hover::after { transform: scaleX(1); }
/* banner reuses .wb-banner; just adjust height */
.story-banner { height: 132px; }
.story-go { position: absolute; bottom: 11px; left: 13px; z-index: 1; width: 30px; height: 30px; border-radius: 50%; border: 1px solid color-mix(in oklab, var(--brand) 60%, var(--hairline-2)); background: oklch(0.13 0.006 260 / 0.55); display: grid; place-items: center; color: var(--brand); backdrop-filter: blur(6px); transition: background .25s ease, transform .25s ease; font-family: 'JetBrains Mono', monospace; font-size: 13px; }
.story-card:hover .story-go { background: var(--brand); color: #0b0c10; transform: translateX(2px); }
.story-body { padding: 22px 26px 20px; display: flex; flex-direction: column; gap: 13px; flex: 1; }
.story-tags { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.story-card h3 { margin: 0; font-family: 'Inter Tight'; font-size: 22px; font-weight: 500; letter-spacing: -0.022em; line-height: 1.22; color: var(--text); }
.story-card .excerpt { margin: 0; font-size: 14px; color: var(--text-mute); line-height: 1.55; flex: 1; }
.story-foot { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 14px; border-top: 1px solid var(--hairline); }
.story-foot .sv { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); display: inline-flex; align-items: center; gap: 8px; }
.story-foot .sv img { height: 15px; width: auto; }
.story-foot .sv b { color: var(--brand); font-weight: 500; }
.story-foot .sv .word { font-family: 'Inter Tight'; font-weight: 600; font-size: 15px; letter-spacing: -0.02em; color: var(--brand); }
.story-foot .sr { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-mute); display: inline-flex; align-items: center; gap: 6px; white-space: nowrap; }
.story-card:hover .story-foot .sr { color: var(--brand); }

@media (max-width: 720px) {
  .fn-grid { grid-template-columns: 1fr; }
}

/* =========================================================
   NEWSLETTER strip
   ========================================================= */
.nl-strip { border: 1px solid var(--accent-line); border-radius: var(--r-lg); padding: 48px 52px; background: radial-gradient(ellipse at 0% 0%, oklch(0.80 0.130 235 / 0.10), transparent 65%), linear-gradient(180deg, oklch(0.19 0.010 260 / 0.7), oklch(0.16 0.008 260 / 0.4)); display: grid; grid-template-columns: 1.1fr 1fr; gap: 44px; align-items: center; }
.nl-strip h2 { margin: 12px 0 12px; }
.nl-strip .lead { margin: 0; }
.nl-form { display: flex; flex-direction: column; gap: 12px; }
.nl-form .row { display: flex; gap: 10px; }
.nl-form input { flex: 1; background: oklch(0.13 0.006 260 / 0.6); border: 1px solid var(--hairline); border-radius: 999px; padding: 13px 18px; color: #fff; font-family: 'Inter', sans-serif; font-size: 15px; outline: none; transition: border-color .2s ease, box-shadow .2s ease; }
.nl-form input::placeholder { color: var(--text-dim); }
.nl-form input:focus { border-color: var(--accent-line); box-shadow: 0 0 0 3px oklch(0.80 0.130 235 / 0.12); }
.nl-form button { appearance: none; cursor: pointer; border: 1px solid transparent; background: var(--text); color: var(--bg); border-radius: 999px; padding: 13px 22px; font-family: 'Inter', sans-serif; font-size: 14px; font-weight: 500; white-space: nowrap; transition: all .25s cubic-bezier(.2,.7,.2,1); }
.nl-form button:hover { background: oklch(1 0 0); transform: translateY(-1px); box-shadow: 0 8px 30px oklch(0.80 0.130 235 / 0.25); }
.nl-form .note { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); }
.nl-thanks { display: none; font-family: 'JetBrains Mono', monospace; font-size: 13px; color: var(--accent); padding-top: 6px; }
.nl-thanks.show { display: block; }

@media (max-width: 1024px) {
  .wb-feature { grid-template-columns: 1fr; }
  .wb-feature-side { border-left: none; border-top: 1px solid var(--hairline); }
  .wb-grid { grid-template-columns: 1fr 1fr; }
  .fn-row { grid-template-columns: 56px 1fr; }
  .fn-meta { grid-column: 2; flex-direction: row; align-items: center; justify-content: flex-start; gap: 18px; text-align: left; }
  .nl-strip { grid-template-columns: 1fr; gap: 24px; }
}
@media (max-width: 720px) {
  .wb-grid { grid-template-columns: 1fr; }
  .wb-feature-main { padding: 32px 26px; }
  .fn-row { padding: 24px 22px; gap: 18px; }
}

/* =========================================================
   ARTICLE (Field Note) page
   ========================================================= */
.read-progress { position: fixed; top: 0; left: 0; height: 2px; width: 0; background: linear-gradient(90deg, var(--accent), var(--violet)); z-index: 60; transition: width .1s linear; }

.art-wrap { max-width: 720px; margin: 0 auto; padding: 0 var(--gutter); position: relative; z-index: 1; }
.art-head { padding-top: 140px; padding-bottom: 8px; }
.art-back { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); text-decoration: none; letter-spacing: 0.04em; display: inline-flex; align-items: center; gap: 7px; transition: color .2s ease; }
.art-back:hover { color: var(--text); }
.art-tags { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; margin: 32px 0 22px; }
.art-role { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); padding: 4px 10px; border-radius: 4px; background: var(--accent-soft); border: 1px solid var(--accent-line); }
.art-topic { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); }
.art-title { font-family: 'Inter Tight'; font-size: clamp(34px, 4.6vw, 54px); font-weight: 500; letter-spacing: -0.032em; line-height: 1.04; margin: 0 0 26px; }
.art-standfirst { font-size: 20px; line-height: 1.55; color: var(--text-mute); margin: 0 0 30px; letter-spacing: -0.005em; }
.art-byline { display: flex; align-items: center; gap: 14px; padding: 22px 0; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); }
.art-byline .av { width: 38px; height: 38px; border-radius: 50%; background: linear-gradient(135deg, var(--accent), var(--violet)); flex-shrink: 0; }
.art-byline .who { display: flex; flex-direction: column; gap: 3px; }
.art-byline .who .nm { font-size: 14px; font-weight: 500; }
.art-byline .who .ro { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); }
.art-byline .meta { margin-left: auto; text-align: right; font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); line-height: 1.6; }
.art-byline .meta .vendor { color: var(--accent); }

/* article body */
.art-body { padding: 44px 0 40px; }
.art-body > p { font-size: 19px; line-height: 1.72; color: var(--text-mute); margin: 0 0 26px; letter-spacing: -0.003em; }
.art-body > p b, .art-body > p strong { color: var(--text); font-weight: 600; }
.art-body em { color: var(--text); font-style: italic; }
.art-body .vendor-name { color: var(--accent); font-weight: 500; font-style: normal; }
/* drop cap on first paragraph */
.art-body > p.lede::first-letter { float: left; font-family: 'Inter Tight'; font-size: 76px; line-height: 0.78; font-weight: 500; padding: 6px 12px 0 0; color: var(--text); letter-spacing: -0.03em; }
.art-body h2 { font-family: 'Inter Tight'; font-size: 27px; font-weight: 500; letter-spacing: -0.022em; line-height: 1.2; color: var(--text); margin: 44px 0 18px; }
.art-body blockquote { margin: 36px 0; padding: 4px 0 4px 28px; border-left: 2px solid var(--accent); }
.art-body blockquote p { font-family: 'Inter Tight'; font-size: 25px; line-height: 1.34; letter-spacing: -0.02em; color: var(--text); margin: 0; }
.art-body blockquote cite { display: block; margin-top: 14px; font-family: 'JetBrains Mono', monospace; font-size: 11px; font-style: normal; color: var(--text-dim); letter-spacing: 0.03em; }
.art-body hr { border: none; border-top: 1px solid var(--hairline); margin: 40px 0; }
.art-body .aside { font-family: 'JetBrains Mono', monospace; font-size: 13px; line-height: 1.65; color: var(--text-dim); background: oklch(0.16 0.008 260 / 0.6); border: 1px solid var(--hairline); border-radius: var(--r-md); padding: 20px 22px; margin: 32px 0; }
.art-body .aside b { color: var(--text-mute); }

/* vendor callout card */
.vendor-card { display: grid; grid-template-columns: 54px 1fr; gap: 20px; align-items: center; border: 1px solid var(--hairline); border-radius: var(--r-lg); padding: 26px 28px; margin: 38px 0; background: linear-gradient(180deg, oklch(0.19 0.010 260 / 0.6), oklch(0.16 0.008 260 / 0.3)); }
.vendor-card .mark { width: 54px; height: 54px; border-radius: var(--r-md); background: oklch(0.13 0.006 260 / 0.7); border: 1px solid var(--hairline); display: grid; place-items: center; }
.vendor-card .mark img { width: 30px; height: 30px; }
.vendor-card .mark .word { font-family: 'Inter Tight'; font-weight: 600; font-size: 15px; color: var(--text); letter-spacing: -0.02em; }
.vendor-card .vc-k { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--accent); margin-bottom: 6px; }
.vendor-card .vc-t { font-size: 15px; line-height: 1.55; color: var(--text-mute); margin: 0; }
.vendor-card .vc-t b { color: var(--text); font-weight: 600; }

/* article footer / next */
.art-foot { padding: 0 0 30px; }
.art-share { display: flex; align-items: center; gap: 14px; padding: 26px 0; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--text-dim); flex-wrap: wrap; }
.art-share .tags { display: flex; gap: 8px; flex-wrap: wrap; }
.art-share .chip { padding: 4px 10px; border-radius: 999px; border: 1px solid var(--hairline); color: var(--text-mute); }
.art-next { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-lg); overflow: hidden; margin-top: 40px; }
.art-next a { background: var(--bg); padding: 26px 28px; text-decoration: none; display: flex; flex-direction: column; gap: 10px; transition: background .3s ease; }
.art-next a:hover { background: var(--bg-2); }
.art-next a.next { text-align: right; align-items: flex-end; }
.art-next .dir { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); }
.art-next .t { font-family: 'Inter Tight'; font-size: 17px; font-weight: 500; letter-spacing: -0.018em; line-height: 1.25; color: var(--text); }

@media (max-width: 720px) {
  .art-body > p { font-size: 17px; }
  .art-body > p.lede::first-letter { font-size: 58px; }
  .art-next { grid-template-columns: 1fr; }
  .art-byline .meta { display: none; }
}

/* =========================================================
   Q&A INTERVIEW FORMAT
   ========================================================= */
/* intro paragraph(s) before the Q&A begins */
.art-body .intro { font-size: 19px; line-height: 1.72; color: var(--text-mute); margin: 0 0 14px; }
.art-body .intro b { color: var(--text); font-weight: 600; }

/* Question block */
.qa-q { display: grid; grid-template-columns: 46px 1fr; gap: 18px; align-items: start; margin: 48px 0 22px; padding: 22px 24px 22px 20px; border: 1px solid var(--hairline); border-radius: var(--r-md); background: linear-gradient(180deg, oklch(0.19 0.010 260 / 0.6), oklch(0.16 0.008 260 / 0.3)); }
.qa-q .qm { width: 46px; height: 46px; border-radius: 11px; background: var(--accent-soft); border: 1px solid var(--accent-line); color: var(--accent); display: grid; place-items: center; font-family: 'Inter Tight'; font-weight: 600; font-size: 21px; letter-spacing: -0.02em; }
.qa-q .qx .who { font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-dim); display: block; margin-bottom: 8px; }
.qa-q .qx .qt { font-family: 'Inter Tight'; font-size: 22px; font-weight: 500; letter-spacing: -0.02em; line-height: 1.28; color: var(--text); }

/* Answer block */
.qa-a { border-left: 2px solid var(--hairline-2); padding-left: 24px; margin: 0 0 12px; }
.qa-a > p { font-size: 18px; line-height: 1.7; color: var(--text-mute); margin: 0 0 20px; letter-spacing: -0.003em; }
.qa-a > p:last-child { margin-bottom: 0; }
.qa-a > p b, .qa-a > p strong { color: var(--text); font-weight: 600; }
.qa-a > p.kicker { color: var(--text); font-weight: 500; }
.qa-a > p:first-child::before { content: "A"; font-family: 'Inter Tight'; font-weight: 600; font-size: 14px; color: var(--accent); background: oklch(1 0 0 / 0.04); border: 1px solid var(--hairline); border-radius: 6px; padding: 2px 8px; margin-right: 12px; vertical-align: 2px; }
.qa-a .vendor-name { color: var(--accent); font-weight: 500; }
.qa-a em { color: var(--text); font-style: italic; }

/* keep blockquote / vendor-card usable inside answers */
.qa-a blockquote { margin: 28px 0; padding: 4px 0 4px 24px; border-left: 2px solid var(--accent); }
.qa-a blockquote p { font-family: 'Inter Tight'; font-size: 23px; line-height: 1.34; letter-spacing: -0.02em; color: var(--text); margin: 0; }

/* =========================================================
   VISUAL BLOCKS (live inside answers or body)
   ========================================================= */
/* stat band — row of big numbers */
.v-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-md); overflow: hidden; margin: 30px 0; }
.v-stats.two { grid-template-columns: repeat(2, 1fr); }
.v-stats .s { background: var(--bg); padding: 22px 20px; display: flex; flex-direction: column; gap: 8px; }
.v-stats .s .vv { font-family: 'Inter Tight'; font-size: 34px; font-weight: 500; letter-spacing: -0.03em; line-height: 1; color: var(--text); }
.v-stats .s .vv small { font-size: 15px; color: var(--text-mute); font-weight: 400; margin-left: 2px; }
.v-stats .s .vv.accent { color: var(--accent); }
.v-stats .s .kk { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 0.04em; line-height: 1.45; }

/* before / after */
.v-ba { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; background: var(--hairline); border: 1px solid var(--hairline); border-radius: var(--r-md); overflow: hidden; margin: 30px 0; }
.v-ba .col { background: var(--bg); padding: 24px 24px; display: flex; flex-direction: column; gap: 14px; }
.v-ba .col .ttag { align-self: flex-start; font-family: 'JetBrains Mono', monospace; font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; padding: 4px 10px; border-radius: 4px; }
.v-ba .col.before .ttag { color: var(--text-dim); background: oklch(1 0 0 / 0.04); border: 1px solid var(--hairline); }
.v-ba .col.after .ttag { color: var(--accent); background: var(--accent-soft); border: 1px solid var(--accent-line); }
.v-ba .col h4 { margin: 0; font-family: 'Inter Tight'; font-size: 17px; font-weight: 500; letter-spacing: -0.015em; line-height: 1.25; color: var(--text); }
.v-ba .col ul { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 11px; }
.v-ba .col li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; line-height: 1.45; color: var(--text-mute); }
.v-ba .col li svg { width: 15px; height: 15px; flex-shrink: 0; margin-top: 2px; }
.v-ba .col.before li svg { color: var(--text-dim); }
.v-ba .col.after li { color: var(--text); }
.v-ba .col.after li svg { color: var(--accent); }

/* horizontal flow / steps */
.v-flow { display: flex; align-items: stretch; border: 1px solid var(--hairline); border-radius: var(--r-md); overflow: hidden; margin: 30px 0; }
.v-flow .step { flex: 1; background: var(--bg); padding: 20px 18px; border-right: 1px solid var(--hairline); display: flex; flex-direction: column; gap: 9px; position: relative; }
.v-flow .step:last-child { border-right: none; }
.v-flow .step.on { background: oklch(0.19 0.010 260 / 0.55); }
.v-flow .step .n { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--text-dim); letter-spacing: 0.08em; }
.v-flow .step.on .n { color: var(--accent); }
.v-flow .step .lab { font-family: 'Inter Tight'; font-size: 15px; font-weight: 500; letter-spacing: -0.01em; color: var(--text); line-height: 1.2; }
.v-flow .step .sub { font-size: 12px; color: var(--text-mute); line-height: 1.4; }

/* labeled bars */
.v-bars { border: 1px solid var(--hairline); border-radius: var(--r-md); background: oklch(0.16 0.008 260 / 0.5); padding: 22px 24px; margin: 30px 0; display: flex; flex-direction: column; gap: 14px; }
.v-bars .bl { display: grid; grid-template-columns: 130px 1fr 56px; gap: 14px; align-items: center; }
.v-bars .bl .bk { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--text-mute); }
.v-bars .bl .bt { height: 8px; border-radius: 999px; background: oklch(0.22 0.012 260); overflow: hidden; }
.v-bars .bl .bt span { display: block; height: 100%; border-radius: inherit; background: linear-gradient(90deg, var(--accent), var(--violet)); }
.v-bars .bl .bt.dim span { background: var(--hairline-2); }
.v-bars .bl .bv { font-family: 'JetBrains Mono', monospace; font-size: 12px; color: var(--accent); text-align: right; }
.v-bars .bl .bv.dim { color: var(--text-dim); }

/* figure caption shared by visual blocks */
.v-cap { font-family: 'JetBrains Mono', monospace; font-size: 10.5px; letter-spacing: 0.04em; color: var(--text-dim); margin: -18px 0 30px; padding-left: 2px; }
.v-cap b { color: var(--text-mute); font-weight: 500; }

/* big pull stat */
.v-pull { display: grid; grid-template-columns: auto 1fr; gap: 22px; align-items: center; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); padding: 26px 0; margin: 30px 0; }
.v-pull .big { font-family: 'Inter Tight'; font-size: 64px; font-weight: 500; letter-spacing: -0.04em; line-height: 0.85; color: var(--accent); }
.v-pull .big small { font-size: 26px; color: var(--text-mute); }
.v-pull .txt { font-size: 15px; line-height: 1.5; color: var(--text-mute); }
.v-pull .txt b { color: var(--text); font-weight: 600; }

@media (max-width: 720px) {
  .qa-q { grid-template-columns: 1fr; }
  .qa-q .qm { display: none; }
  .qa-q .qx .qt { font-size: 20px; }
  .qa-a { padding-left: 16px; }
  .qa-a > p { font-size: 17px; }
  .v-stats, .v-ba, .v-flow { grid-template-columns: 1fr; flex-direction: column; }
  .v-flow .step { border-right: none; border-bottom: 1px solid var(--hairline); }
  .v-pull { grid-template-columns: 1fr; gap: 12px; }
  .v-pull .big { font-size: 48px; }
  .v-bars .bl { grid-template-columns: 88px 1fr 44px; gap: 10px; }
}
