/* ══════════════════════════════════════════════════════════════════
   STOBOX — blog-post-v3.css
   Per-page styles for /blog/<slug>.html article pages.
   Loads AFTER /css/v3-system.css.
   ══════════════════════════════════════════════════════════════════ */

/* ── HERO — clean dark band, typography only ────────────────────
   Earlier this hero stretched a generic Nodes.webp behind every
   post and overlaid the title on it. Many posts have feature
   images that already include text — overlaying ALSO put title
   text on top of image text. Now: hero is solid dark, the post's
   native feature image displays cleanly in .bp-feature below. */
.bp-hero{
  position: relative;
  background: var(--bg-dark);
  color: var(--bg);
  overflow: hidden;
  padding: 96px var(--gutter) 64px;
  display: flex;
  align-items: flex-end;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.bp-hero-inner{
  position: relative;
  max-width: var(--maxw);
  margin: 0 auto;
  width: 100%;
}

.bl-crumb{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
  margin-bottom: 26px;
}
.bl-crumb a{ color: rgba(255,255,255,0.75); transition: color var(--t-fast) }
.bl-crumb a:hover{ color: var(--accent-hi) }
.bl-crumb span{ margin: 0 8px; color: rgba(255,255,255,0.32) }

.bp-meta-top{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent-hi);
  margin-bottom: 22px;
  display: inline-flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
.bp-meta-top::before{
  content: '';
  width: 24px; height: 2px;
  background: var(--accent-hi);
}
.bp-meta-top a{
  color: var(--accent-hi);
  border-bottom: 1px solid rgba(165,180,252,0.4);
  padding-bottom: 1px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.bp-meta-top a:hover{ color: var(--bg); border-color: var(--bg) }
.bp-meta-top span{ color: rgba(255,255,255,0.5); letter-spacing: .14em }
.bp-meta-top span:first-child + span{ color: rgba(255,255,255,0.85) }

.bp-hero h1{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(40px, 5.5vw, 96px);
  line-height: 0.95;
  letter-spacing: -0.022em;
  color: var(--bg);
  text-transform: uppercase;
  margin: 0 0 22px;
  max-width: 22ch;
}
.bp-hero h1 em{ font-style: italic; color: var(--accent-hi); font-weight: 800 }

.bp-excerpt{
  font-family: var(--body);
  font-weight: 400;
  font-size: clamp(15px, 1.15vw, 18px);
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  max-width: 64ch;
  margin: 0 0 36px;
}

.bp-author{
  display: inline-flex;
  align-items: center;
  gap: 14px;
  padding-top: 26px;
  border-top: 1px solid rgba(255,255,255,0.10);
  margin-top: 6px;
}
.bp-author-avatar img{
  width: 42px;
  height: 42px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}
.bp-author-name{
  font-family: var(--body);
  font-size: 14px;
  font-weight: 600;
  color: var(--bg);
  margin-bottom: 2px;
}
.bp-author-meta{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,0.55);
}

/* ── FEATURE IMAGE STRIP (between hero and body) ──────────────────── */
/* ── FEATURE IMAGE — sits between hero and body ────────────────
   No overlap with the hero. No border frame. Image is the subject;
   it stands alone with breathing room. Many posts ship images that
   already contain text/headlines — we treat them as editorial
   covers, not as decorative bg. */
.bp-feature{
  background: var(--bg);
  padding: 56px var(--gutter) 0;
  border-bottom: 1px solid var(--rule);
}
.bp-feature-img{
  max-width: 1280px;
  margin: 0 auto;
  position: relative;
  background: var(--bg-3);
}
.bp-feature-img img{
  display: block;
  width: 100%;
  height: auto;
  max-height: 640px;
  object-fit: cover;
  object-position: center;
}

/* ── BODY — single column article ─────────────────────────────────── */
.bp-body-wrap{
  background: var(--bg);
  padding: 80px var(--gutter) 80px;
  border-bottom: 1px solid var(--rule);
}
.bp-body{
  max-width: 720px;
  margin: 0 auto;
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink-2);
}
.bp-body > *:first-child{ margin-top: 0 }

.bp-body p{
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.7;
  color: var(--ink-2);
  margin: 0 0 1.1em;
}
.bp-body p strong{ color: var(--ink); font-weight: 600 }
.bp-body a{
  color: var(--accent);
  border-bottom: 1px solid var(--accent-bd);
  padding-bottom: 1px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.bp-body a:hover{ color: var(--accent-lo); border-color: var(--accent-lo) }

.bp-body h2{
  font-family: var(--display);
  font-weight: 700;
  font-size: 32px;
  line-height: 1.05;
  letter-spacing: -0.018em;
  color: var(--ink);
  text-transform: uppercase;
  margin: 2em 0 0.6em;
}
.bp-body h3{
  font-family: var(--display);
  font-weight: 700;
  font-size: 24px;
  line-height: 1.1;
  letter-spacing: -0.014em;
  color: var(--ink);
  text-transform: uppercase;
  margin: 1.7em 0 0.5em;
}
.bp-body h4{
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.15;
  color: var(--ink);
  text-transform: uppercase;
  letter-spacing: -0.008em;
  margin: 1.4em 0 0.5em;
}
.bp-body h5, .bp-body h6{
  font-family: var(--body);
  font-weight: 600;
  font-size: 16px;
  color: var(--ink);
  margin: 1.4em 0 0.5em;
}

.bp-body ul, .bp-body ol{
  margin: 0 0 1.1em 1.2em;
  padding: 0;
}
.bp-body li{
  margin: 0 0 0.5em;
  font-family: var(--body);
  font-size: 17px;
  line-height: 1.65;
  color: var(--ink-2);
}
.bp-body li::marker{ color: var(--accent) }

.bp-body blockquote{
  margin: 1.5em 0;
  padding: 6px 0 6px 24px;
  border-left: 4px solid var(--accent);
  font-family: var(--body);
  font-style: italic;
  font-size: 20px;
  line-height: 1.55;
  color: var(--ink);
}
.bp-body blockquote p{
  font-size: 20px;
  font-style: italic;
  margin: 0 0 0.6em;
}
.bp-body blockquote p:last-child{ margin: 0 }

.bp-body figure{ margin: 1.6em 0 }
.bp-body img{
  display: block;
  width: 100%;
  height: auto;
  margin: 0 auto;
  border: 1px solid var(--rule);
}
.bp-body figcaption{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-top: 10px;
  text-align: center;
}

.bp-body hr{
  border: 0;
  border-top: 1px solid var(--rule-hard);
  margin: 60px auto;
  max-width: 60%;
}

.bp-body code{
  font-family: var(--mono);
  font-size: 0.92em;
  background: var(--bg-3);
  border: 1px solid var(--rule);
  padding: 1px 6px;
  border-radius: 1px;
  color: var(--ink);
}
.bp-body pre{
  background: var(--bg-dark-2);
  color: rgba(255,255,255,0.92);
  font-family: var(--mono);
  font-size: 13.5px;
  line-height: 1.55;
  padding: 18px 20px;
  border-radius: 1px;
  overflow-x: auto;
  margin: 1.4em 0;
  border: 1px solid var(--bg-dark-2);
}
.bp-body pre code{
  background: transparent;
  border: 0;
  padding: 0;
  color: inherit;
  font-size: inherit;
}

/* Wrap each table in a horizontal-scroll container so wide tables
   don't overflow body width on phones. The wrapper is also ::before/::after
   trimmed to the rule-soft border so it reads as a scrollable region. */
.bp-body table{
  width: 100%;
  border-collapse: collapse;
  margin: 1.4em 0;
  font-size: 14.5px;
  display: block;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
/* When the table is wide enough to scroll, give the user a visual cue
   via a subtle right-edge fade — pure CSS, no JS. */
.bp-body table{
  background:
    linear-gradient(to right, var(--bg) 30%, transparent),
    linear-gradient(to right, transparent, var(--bg) 70%) 100% 0,
    radial-gradient(farthest-side at 0 50%, rgba(10,14,44,0.12), transparent),
    radial-gradient(farthest-side at 100% 50%, rgba(10,14,44,0.12), transparent) 100% 0;
  background-repeat: no-repeat;
  background-size: 40px 100%, 40px 100%, 14px 100%, 14px 100%;
  background-attachment: local, local, scroll, scroll;
}
.bp-body th, .bp-body td{
  text-align: left;
  padding: 12px 14px;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.bp-body th{
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-3);
  font-weight: 500;
  border-bottom-color: var(--ink);
}
@media (max-width: 600px){
  .bp-body table{ font-size: 13px; margin: 1.2em -16px; width: calc(100% + 32px); }
  .bp-body th, .bp-body td{ padding: 10px 12px; }
  .bp-body th{ font-size: 10px; letter-spacing: .1em; }
}

/* Ghost embed/figure tweaks */
.bp-body .kg-card,
.bp-body .kg-image-card{ margin: 1.6em 0 }
.bp-body .kg-bookmark-card{
  border: 1px solid var(--rule);
  padding: 16px 18px;
  margin: 1.6em 0;
  display: block;
  background: var(--bg-2);
  text-decoration: none;
}
.bp-body .kg-bookmark-card:hover{ border-color: var(--accent) }
.bp-body .kg-bookmark-content{ display: block }
.bp-body .kg-bookmark-title{
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: 6px;
  letter-spacing: -0.012em;
}
.bp-body .kg-bookmark-description{
  font-family: var(--body);
  font-size: 13.5px;
  color: var(--ink-2);
  line-height: 1.5;
}
.bp-body .kg-bookmark-thumbnail img{ display: none }
.bp-body iframe{
  width: 100%;
  max-width: 100%;
  aspect-ratio: 16 / 9;
  border: 1px solid var(--rule);
  margin: 1.6em 0;
  display: block;
}

/* ── POST FOOTER (tags + back) ────────────────────────────────────── */
.bp-tags{
  max-width: 720px;
  margin: 48px auto 0;
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 30px;
  border-top: 1px solid var(--rule);
}
.bp-tags-label{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-right: 4px;
}
.bl-tag-chip,
.bp-tags .bl-tag-chip{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-2);
  background: var(--bg-3);
  border: 1px solid var(--rule-hard);
  padding: 6px 11px;
  border-radius: 1px;
  transition: background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
}
.bl-tag-chip:hover,
.bp-tags .bl-tag-chip:hover{
  color: var(--accent);
  border-color: var(--accent);
  background: var(--accent-bg);
}

.bp-back{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-2);
  border-bottom: 1px solid var(--rule);
  padding-bottom: 4px;
  display: inline-block;
  margin-top: 36px;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.bp-back:hover{ color: var(--accent); border-color: var(--accent) }

/* ── SHARE ROW ────────────────────────────────────────────────────── */
.bp-share{
  max-width: 720px;
  margin: 30px auto 0;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bp-share-label{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-right: 4px;
}
.bp-share-btn{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--ink-2);
  background: var(--bg);
  border: 1px solid var(--rule-hard);
  padding: 7px 12px;
  border-radius: 1px;
  cursor: pointer;
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.bp-share-btn:hover{ color: var(--accent); border-color: var(--accent); background: var(--accent-bg) }

/* ── PREV / NEXT NAV ──────────────────────────────────────────────── */
.bp-nav-wrap{
  background: var(--bg-2);
  padding: 50px var(--gutter);
  border-bottom: 1px solid var(--rule);
}
.bp-nav-inner{
  max-width: 1100px;
  margin: 0 auto;
}
.bp-nav{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
.bp-nav-item{
  background: var(--bg);
  padding: 28px 26px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-decoration: none;
  color: inherit;
  transition: background var(--t-base) var(--ease);
}
.bp-nav-item:hover{ background: var(--blue-ice) }
.bp-nav-empty{ background: var(--bg-2) }
.bp-nav-prev{ text-align: left }
.bp-nav-next{ text-align: right }
.bp-nav-dir{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
}
.bp-nav-title{
  font-family: var(--display);
  font-weight: 700;
  font-size: 18px;
  line-height: 1.15;
  letter-spacing: -0.014em;
  text-transform: uppercase;
  color: var(--ink);
}
@media (max-width: 760px){
  .bp-nav{ grid-template-columns: 1fr }
  .bp-nav-next{ text-align: left }
}

/* ── RELATED POSTS (3-up cards using ref-card pattern) ────────────── */
.bp-related{
  background: var(--bg);
  padding: 80px var(--gutter);
  border-bottom: 1px solid var(--rule);
}
.bp-related-label{
  font-family: var(--mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
  max-width: var(--maxw);
  margin: 0 auto 28px;
  display: flex;
  align-items: center;
  gap: 12px;
}
.bp-related-label::before{
  content: '';
  width: 24px; height: 2px;
  background: var(--accent);
}
.bp-related-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
  max-width: var(--maxw);
  margin: 0 auto;
}
.bl-card{
  background: var(--bg);
  display: flex;
  flex-direction: column;
  text-decoration: none;
  color: inherit;
  transition: background var(--t-base) var(--ease),
              padding-left var(--t-fast) var(--ease),
              box-shadow .45s cubic-bezier(.22,1,.36,1);
}
.bl-card:hover{
  background: var(--bg);
  box-shadow: 0 18px 40px rgba(10,14,44,0.10);
}
.bl-card-img{
  aspect-ratio: 16 / 9;
  overflow: hidden;
  border-bottom: 1px solid var(--rule);
}
.bl-card-img img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform .8s var(--ease);
}
.bl-card:hover .bl-card-img img{ transform: scale(1.04) }
.bl-card-body{ padding: 24px 22px 26px; display: flex; flex-direction: column; gap: 10px; flex: 1 }
.bl-card-meta{
  display: inline-flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.bl-card-tag{
  font-family: var(--mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--accent);
}
.bl-card-dot{ color: var(--ink-4); font-size: 11px }
.bl-card-meta > span:not(.bl-card-tag):not(.bl-card-dot){
  font-family: var(--mono);
  font-size: 10px;
  letter-spacing: .12em;
  color: var(--ink-3);
  text-transform: uppercase;
}
.bl-card h3{
  font-family: var(--display);
  font-weight: 700;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -0.014em;
  text-transform: uppercase;
  color: var(--ink);
}
.bl-card-excerpt{
  font-family: var(--body);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-2);
  flex: 1;
}
.bl-card-read{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink);
  margin-top: 6px;
  border-bottom: 1px solid var(--rule);
  padding-bottom: 4px;
  align-self: flex-start;
  transition: color var(--t-fast), border-color var(--t-fast);
}
.bl-card:hover .bl-card-read{ color: var(--accent); border-color: var(--accent) }

@media (max-width: 920px){
  .bp-related-grid{ grid-template-columns: 1fr 1fr }
}
@media (max-width: 600px){
  .bp-related-grid{ grid-template-columns: 1fr }
}

/* ── BLOG INDEX (used by blog.html and tag/page archives) ─────────── */
.bl-hero{
  position: relative;
  background: var(--bg-dark);
  color: var(--bg);
  overflow: hidden;
  padding: 120px var(--gutter) 100px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}
.bl-hero::before{
  content: '';
  position: absolute;
  inset: 0;
  background:
    linear-gradient(rgba(255,255,255,0.03) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.03) 1px, transparent 1px);
  background-size: 80px 80px;
  mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, black, transparent 80%);
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 50% 50%, black, transparent 80%);
  pointer-events: none;
  z-index: 0;
}
.bl-hero-inner{
  position: relative;
  z-index: 1;
  max-width: var(--maxw);
  margin: 0 auto;
}
.bl-hero h1{
  font-family: var(--display);
  font-weight: 800;
  font-size: clamp(40px, 5.5vw, 96px);
  line-height: 0.95;
  letter-spacing: -0.022em;
  color: var(--bg);
  text-transform: uppercase;
  margin: 0 0 20px;
  max-width: 22ch;
}
.bl-hero h1 em{ font-style: italic; color: var(--accent-hi) }
.bl-hero-lead{
  font-family: var(--body);
  font-weight: 400;
  font-size: clamp(15px, 1.1vw, 17px);
  line-height: 1.6;
  color: rgba(255,255,255,0.78);
  max-width: 64ch;
  margin: 0;
}

.bl-filter{
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  padding: 22px var(--gutter);
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  position: sticky;
  top: 51px;
  z-index: 50;
}
.bl-filter-label{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 500;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--ink-3);
  margin-right: 4px;
}
.bl-filter .bl-tag-chip.active{
  background: var(--ink);
  border-color: var(--ink);
  color: var(--bg);
}

.bl-grid-section{
  background: var(--bg);
  padding: 60px var(--gutter) 90px;
}
.bl-grid-inner{
  max-width: var(--maxw);
  margin: 0 auto;
}
.bl-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--rule);
  border: 1px solid var(--rule);
}
@media (max-width: 920px){
  .bl-grid{ grid-template-columns: 1fr 1fr }
}
@media (max-width: 600px){
  .bl-grid{ grid-template-columns: 1fr }
}

.bl-pager{
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  margin-top: 50px;
  flex-wrap: wrap;
}
.bl-pager a, .bl-pager .current, .bl-pager .disabled, .bl-pager .bl-pager-ellipsis{
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 9px 13px;
  border: 1px solid var(--rule-hard);
  color: var(--ink-2);
  background: var(--bg);
  border-radius: 1px;
  transition: color var(--t-fast), border-color var(--t-fast), background var(--t-fast);
}
.bl-pager a:hover{ color: var(--accent); border-color: var(--accent) }
.bl-pager .current{
  background: var(--ink);
  border-color: var(--ink);
  color: var(--bg);
}
.bl-pager .disabled{ color: var(--ink-4); border-color: var(--rule); cursor: not-allowed }
.bl-pager .bl-pager-ellipsis{ border: 0; color: var(--ink-3); padding: 9px 6px; background: transparent }

/* ── RESPONSIVE FOR HERO ──────────────────────────────────────────── */
@media (max-width: 760px){
  .bp-hero{ padding: 70px var(--gutter) 50px }
  .bp-feature{ padding: 36px var(--gutter) 0 }
  .bp-body-wrap{ padding: 50px var(--gutter) 60px }
  .bp-body{ font-size: 16.5px }
  .bp-body p, .bp-body li{ font-size: 16.5px }
}

/* ══════════════════════════════════════════════════════════════════
   COMPASS LAUNCH — mid-post inline nudge
   Injected by scripts/build-blog.js after the 2nd </h2> on any post
   with 3+ h2s. Brutalist accent-tinted card, sharp corners, single
   CTA. Designed to read AS PART OF the article, not as a popup.
   ══════════════════════════════════════════════════════════════════ */
.bp-compass-nudge{
  margin: 36px 0;
  padding: 26px 28px;
  background: var(--accent-bg);
  border: 1px solid var(--accent-bd);
  border-left: 4px solid var(--accent);
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.bp-compass-nudge-eye{
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--accent);
}
.bp-compass-nudge-row{
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  gap: 24px;
}
.bp-compass-nudge-body{ display: flex; flex-direction: column; gap: 6px }
.bp-compass-nudge-title{
  font-family: var(--display);
  font-weight: 800;
  font-size: 22px;
  line-height: 1.1;
  letter-spacing: -0.018em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0;
}
.bp-compass-nudge-desc{
  font-family: var(--body);
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--ink-2);
  margin: 0;
}
.bp-compass-nudge-cta{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 13px 22px;
  background: var(--accent);
  color: var(--bg);
  font-family: var(--body);
  font-size: 13.5px;
  font-weight: 500;
  letter-spacing: -0.005em;
  text-decoration: none;
  border: 1px solid var(--accent);
  white-space: nowrap;
  transition: background var(--t-base) var(--ease), border-color var(--t-base);
}
.bp-compass-nudge-cta:hover{
  background: var(--accent-lo);
  border-color: var(--accent-lo);
}
@media (max-width: 600px){
  .bp-compass-nudge{ padding: 22px 20px }
  .bp-compass-nudge-row{ grid-template-columns: 1fr; gap: 16px }
  .bp-compass-nudge-cta{ align-self: flex-start }
  .bp-compass-nudge-title{ font-size: 19px }
}
