/* ============================================================
   LEAD MAGNET — A4 PRINT STYLES
   ============================================================ */

@import url("https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@500;600;700&family=Inter:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap");

@page { size: A4; margin: 0; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bf-gray-100);
  color: var(--bf-text);
  font-family: var(--bf-font-body);
  font-size: 11pt;
  line-height: 1.55;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}

.book {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
  padding: 24px 0;
}

.page {
  width: 210mm;
  height: 297mm;
  padding: 18mm 18mm 22mm;
  position: relative;
  background: #fff;
  box-shadow: 0 10px 28px rgba(15, 30, 77, 0.12);
  overflow: hidden;
  page-break-after: always;
  page-break-inside: avoid;
  break-after: page;
  break-inside: avoid;
  display: flex;
  flex-direction: column;
}
.page:last-child { page-break-after: auto; }

@media print {
  body { background: #fff; }
  .book { padding: 0; gap: 0; }
  .page { box-shadow: none; margin: 0; }
}

/* ---------- FOOTER + PAGE NUMBERS ---------- */
.foot {
  position: absolute;
  left: 18mm; right: 18mm; bottom: 10mm;
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  color: var(--bf-text-subtle);
  letter-spacing: 0.04em;
}
.foot .brand { color: var(--bf-blue); font-weight: 600; }
.foot .pn { font-feature-settings: "tnum"; color: var(--bf-gray-700); font-weight: 600; }
.foot--invert { color: rgba(255,255,255,.55); }
.foot--invert .brand { color: var(--bf-cyan); }
.foot--invert .pn { color: rgba(255,255,255,.85); }

/* ---------- COVER (PAGE 1) ---------- */
.cover {
  padding: 0;
  background:
    radial-gradient(ellipse at top right, rgba(6,182,212,0.35) 0%, transparent 55%),
    linear-gradient(160deg, #0F1E4D 0%, #1E3A8A 60%, #1C347A 100%);
  color: #fff;
  display: grid;
  grid-template-rows: auto 1fr auto;
}
.cover::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events: none;
  mask-image: radial-gradient(ellipse at top right, #000 25%, transparent 78%);
}
.cover__top {
  padding: 22mm 22mm 0;
  display: flex; justify-content: space-between; align-items: flex-start;
  position: relative; z-index: 1;
}
.cover__edition {
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--bf-cyan);
}
.cover__edition .ed-vol { color: rgba(255,255,255,.6); display: block; margin-top: 6px; }
.cover .bf-logo { color: #fff; font-size: 14pt; }
.cover .bf-logo__mark { background: #fff; }
.cover .bf-logo__mark::before, .cover .bf-logo__mark::after { background: var(--bf-blue); }
.cover .bf-logo__mark::after { background: transparent; border-color: var(--bf-blue); }

.cover__hero {
  padding: 8mm 22mm;
  position: relative; z-index: 1;
  display: flex; flex-direction: column; justify-content: center;
}
.cover__kicker {
  font-family: var(--bf-font-mono);
  font-size: 10pt;
  color: var(--bf-cyan);
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.cover__title {
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 64pt;
  line-height: 0.95;
  letter-spacing: -0.035em;
  margin: 14mm 0 0;
  color: #fff;
  max-width: 14ch;
}
.cover__title em {
  font-style: normal;
  color: var(--bf-cyan);
  display: block;
}
.cover__sub {
  font-size: 14pt;
  line-height: 1.45;
  color: rgba(255,255,255,.78);
  max-width: 38ch;
  margin-top: 12mm;
}
.cover__chips {
  display: flex; gap: 8px; flex-wrap: wrap; margin-top: 12mm;
}
.cover__chip {
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  color: rgba(255,255,255,.85);
  background: rgba(255,255,255,.04);
}
.cover__chip--accent { background: var(--bf-cyan); border-color: var(--bf-cyan); color: #052029; }

.cover__bottom {
  padding: 0 22mm 22mm;
  position: relative; z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6mm;
  border-top: 1px solid rgba(255,255,255,.12);
  padding-top: 12mm;
  margin: 0 22mm;
}
.cover__metric .lbl {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  color: rgba(255,255,255,.55);
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.cover__metric .val {
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 22pt;
  color: #fff;
  margin-top: 4px;
  letter-spacing: -0.02em;
}
.cover__metric .val span { color: var(--bf-cyan); }

.cover__brandline {
  margin: 0 22mm 22mm;
  padding-bottom: 16mm;
  display: flex; justify-content: space-between; align-items: flex-end;
  position: relative; z-index: 1;
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  color: rgba(255,255,255,.55);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

/* ---------- INTERIOR HEADERS ---------- */
.page__head {
  display: flex; justify-content: space-between; align-items: flex-end;
  padding-bottom: 6mm;
  border-bottom: 1px solid var(--bf-border);
  margin-bottom: 8mm;
}
.page__eyebrow {
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
}
.page__title {
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 26pt;
  letter-spacing: -0.02em;
  line-height: 1.05;
  color: var(--bf-blue-900);
  margin-top: 6px;
}
.page__title em { color: var(--bf-cyan-600); font-style: normal; }
.page__meta {
  text-align: right;
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  color: var(--bf-text-subtle);
  letter-spacing: 0.06em;
}
.page__meta strong { color: var(--bf-blue); display: block; font-size: 11pt; margin-top: 2px; }

.lead {
  font-size: 13pt;
  line-height: 1.55;
  color: var(--bf-gray-700);
  max-width: 60ch;
}

/* ---------- ABOUT (P2) ---------- */
.about-grid {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: 8mm;
  margin-top: 6mm;
  flex: 1;
}
.about-block h3 {
  font-family: var(--bf-font-display);
  font-size: 14pt;
  color: var(--bf-blue-900);
  margin-bottom: 4mm;
  letter-spacing: -0.01em;
}
.about-block p { color: var(--bf-gray-700); font-size: 11pt; line-height: 1.6; }
.about-block p + p { margin-top: 3mm; }

.about-card {
  background: var(--bf-blue-50);
  border: 1px solid var(--bf-blue-100);
  border-radius: 12px;
  padding: 8mm;
  display: flex; flex-direction: column; gap: 5mm;
}
.about-card h4 {
  font-family: var(--bf-font-display);
  font-size: 13pt;
  color: var(--bf-blue-900);
  letter-spacing: -0.01em;
}
.about-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.about-list li {
  display: flex; gap: 10px; align-items: flex-start;
  font-size: 10.5pt; line-height: 1.45; color: var(--bf-gray-800);
}
.about-list li::before {
  content: "";
  width: 14px; height: 14px;
  flex-shrink: 0; margin-top: 3px;
  border-radius: 50%;
  background: var(--bf-cyan);
  box-shadow: inset 0 0 0 3px var(--bf-blue-900);
}

.callout {
  margin-top: 6mm;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 4mm 6mm;
  padding: 6mm 7mm;
  border-left: 3px solid var(--bf-cyan);
  background: var(--bf-cyan-50);
  border-radius: 0 8px 8px 0;
}
.callout .tag {
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
  font-weight: 600;
  align-self: start;
  margin-top: 2px;
}
.callout p { font-size: 10.5pt; color: var(--bf-gray-800); line-height: 1.55; }

/* ---------- FRAMEWORK (P3) ---------- */
.tier-flow {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6mm;
  margin-top: 4mm;
  flex: 1;
}
.tier-card {
  border: 1px solid var(--bf-border);
  border-radius: 14px;
  padding: 7mm;
  background: #fff;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
}
.tier-card .tier-num {
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 56pt;
  line-height: 0.85;
  color: var(--bf-blue);
  letter-spacing: -0.03em;
}
.tier-card.t-2 .tier-num { color: var(--bf-cyan-600); }
.tier-card.t-3 .tier-num { color: var(--bf-gray-700); }
.tier-card .tier-num span {
  font-size: 14pt; color: var(--bf-text-subtle);
  font-family: var(--bf-font-mono); display: block; letter-spacing: 0.12em; text-transform: uppercase;
  margin-bottom: 2mm;
}
.tier-card h3 {
  font-family: var(--bf-font-display);
  font-size: 16pt;
  color: var(--bf-blue-900);
  letter-spacing: -0.01em;
  margin-top: 4mm;
}
.tier-card .tier-desc {
  font-size: 10pt; color: var(--bf-gray-700); line-height: 1.55;
  margin-top: 3mm;
}
.tier-card ul {
  list-style: none; padding: 0; margin: 6mm 0 0;
  display: flex; flex-direction: column; gap: 5px;
  font-size: 9.5pt;
  border-top: 1px dashed var(--bf-border);
  padding-top: 4mm;
}
.tier-card ul li {
  display: flex; justify-content: space-between; gap: 8px;
  color: var(--bf-gray-700);
  font-family: var(--bf-font-mono);
  letter-spacing: 0.02em;
}
.tier-card ul li span { color: var(--bf-text-subtle); }

.framework-foot {
  margin-top: 6mm;
  padding: 5mm 6mm;
  background: var(--bf-blue-900);
  color: #fff;
  border-radius: 12px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6mm;
  position: relative;
  overflow: hidden;
}
.framework-foot::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at top right, #000 30%, transparent 75%);
  pointer-events: none;
}
.framework-foot .ff-item { position: relative; }
.framework-foot .lbl { font-family: var(--bf-font-mono); font-size: 8pt; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bf-cyan); }
.framework-foot .val { font-family: var(--bf-font-display); font-weight: 600; font-size: 18pt; margin-top: 3px; letter-spacing: -0.01em; }
.framework-foot .sub { font-size: 9pt; color: rgba(255,255,255,.65); margin-top: 2px; }

/* ---------- TOOL CARD ---------- */
.tools-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6mm;
  align-content: start;
  flex: 1;
}
.tools-grid--detail { grid-template-columns: 1fr 1fr; }

.tcard {
  border: 1px solid var(--bf-border);
  border-radius: 12px;
  padding: 5mm;
  background: #fff;
  display: flex; flex-direction: column;
  gap: 3mm;
  position: relative;
  break-inside: avoid;
}
.tcard__head {
  display: flex; gap: 4mm; align-items: flex-start;
}
.tcard__logo {
  width: 36px; height: 36px;
  border-radius: 8px;
  background: var(--bf-blue-50);
  border: 1px solid var(--bf-blue-100);
  display: grid; place-items: center;
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 13pt;
  color: var(--bf-blue);
  flex-shrink: 0;
  letter-spacing: -0.02em;
}
.tcard__id {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.1em;
  color: var(--bf-text-subtle);
  text-transform: uppercase;
}
.tcard__name {
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 16pt;
  letter-spacing: -0.02em;
  color: var(--bf-blue-900);
  line-height: 1.05;
  margin-top: 2px;
}
.tcard__head-right { margin-left: auto; display: flex; flex-direction: column; align-items: flex-end; gap: 4px; }

.price {
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.08em;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 999px;
  background: var(--bf-gray-100);
  color: var(--bf-gray-700);
  border: 1px solid var(--bf-border);
  text-transform: uppercase;
}
.price--free { background: var(--bf-success-bg); color: var(--bf-success); border-color: rgba(4,120,87,.2); }
.price--low  { background: var(--bf-cyan-50); color: var(--bf-cyan-600); border-color: rgba(6,182,212,.25); }
.price--mid  { background: var(--bf-blue-50); color: var(--bf-blue); border-color: var(--bf-blue-100); }
.price--high { background: var(--bf-warning-bg); color: var(--bf-warning); border-color: rgba(180,83,9,.2); }
.price em { font-style: normal; opacity: 0.35; }

.tcard__desc {
  font-size: 10pt;
  line-height: 1.5;
  color: var(--bf-gray-700);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.bestfor {
  display: inline-flex; align-items: center; gap: 6px;
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
  background: var(--bf-cyan-50);
  border-radius: 6px;
  padding: 4px 8px;
  align-self: flex-start;
  border: 1px solid rgba(6,182,212,.18);
}
.bestfor::before {
  content: "BEST FOR"; font-weight: 700; color: var(--bf-blue-900); margin-right: 4px;
}

.tcard__feats {
  list-style: none; padding: 0; margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 3px 8px;
  font-size: 9pt;
  color: var(--bf-gray-800);
}
.tcard__feats li {
  display: flex; gap: 6px; align-items: center;
}
.tcard__feats li::before {
  content: "";
  width: 12px; height: 12px;
  flex-shrink: 0;
  border-radius: 3px;
  background: var(--bf-cyan);
  position: relative;
}
.tcard__feats li::after {
  content: "";
  position: absolute;
  width: 5px; height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg) translate(-1px, -1px);
  margin-left: 4px;
  margin-top: 1px;
}
.tcard__feats li {
  position: relative;
}

.tcard__link {
  margin-top: auto;
  padding: 8px 10px;
  border-top: 1px dashed var(--bf-border);
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  color: var(--bf-text-subtle);
  letter-spacing: 0.04em;
}
.tcard__link .url {
  color: var(--bf-blue);
  text-decoration: underline;
  text-underline-offset: 3px;
  font-weight: 500;
}
.tcard__link .arrow {
  font-family: var(--bf-font-display);
  color: var(--bf-cyan-600);
  font-weight: 700;
}

/* Featured / large detail card variant for Tier 1 */
.tcard--detail .tcard__name { font-size: 18pt; }
.tcard--detail .tcard__desc { -webkit-line-clamp: 2; font-size: 10pt; line-height: 1.45; }
.tcard--detail .tcard__feats { grid-template-columns: 1fr 1fr; }

/* Screenshot placeholder */
.shot {
  border: 1.5px dashed var(--bf-border-strong);
  border-radius: 12px;
  background:
    repeating-linear-gradient(135deg, var(--bf-gray-50) 0 12px, var(--bf-gray-100) 12px 24px);
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 6mm;
  min-height: 100%;
}
.shot__tag {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  color: var(--bf-text-subtle);
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.shot__center {
  margin: auto;
  text-align: center;
  font-family: var(--bf-font-mono);
  font-size: 10pt;
  color: var(--bf-blue);
}
.shot__center .square {
  width: 38px; height: 38px;
  border: 1.5px solid var(--bf-blue);
  margin: 0 auto 8px;
  border-radius: 6px;
  background: #fff;
  position: relative;
}
.shot__center .square::before, .shot__center .square::after {
  content: ""; position: absolute;
  background: var(--bf-blue);
}
.shot__center .square::before { left: 6px; top: 6px; width: 12px; height: 4px; }
.shot__center .square::after  { left: 14px; top: 14px; width: 12px; height: 12px; border: 2px solid var(--bf-blue); background: transparent; }
.shot__center .label { display: block; margin-top: 4px; color: var(--bf-text-muted); font-size: 9pt; letter-spacing: 0.04em; }
.shot__foot {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  color: var(--bf-text-subtle);
  letter-spacing: 0.06em;
}

/* Section opener band */
.tier-band {
  margin: -8mm -18mm 6mm;
  padding: 7mm 18mm;
  background: linear-gradient(90deg, var(--bf-blue-900) 0%, var(--bf-blue) 60%, var(--bf-blue-700) 100%);
  color: #fff;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 6mm;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.tier-band::after {
  content: ""; position: absolute; right: 0; top: 0; bottom: 0; width: 50%;
  background-image:
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 22px 22px;
  mask-image: linear-gradient(90deg, transparent, #000);
  pointer-events: none;
}
.tier-band__num {
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 30pt;
  letter-spacing: -0.03em;
  color: var(--bf-cyan);
  line-height: 1;
}
.tier-band__title {
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 20pt;
  letter-spacing: -0.01em;
  line-height: 1;
}
.tier-band__title small {
  display: block;
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bf-cyan);
  margin-bottom: 4px;
  font-weight: 500;
}
.tier-band__count {
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.7);
  border: 1px solid rgba(255,255,255,.25);
  padding: 5px 12px;
  border-radius: 999px;
  position: relative; z-index: 1;
}

/* Quiet sub-band for non-opener pages */
.tier-rule {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-text-subtle);
  margin-top: -2mm;
  margin-bottom: 4mm;
  padding-bottom: 3mm;
  border-bottom: 1px solid var(--bf-border);
}
.tier-rule strong { color: var(--bf-blue); font-family: var(--bf-font-display); font-weight: 700; letter-spacing: -0.01em; text-transform: none; font-size: 13pt; }

/* ---------- WORKFLOW PAGES ---------- */
.flow {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6mm;
}
.flow__intro {
  background: var(--bf-blue-50);
  border: 1px solid var(--bf-blue-100);
  border-radius: 12px;
  padding: 6mm 7mm;
  display: grid;
  grid-template-columns: 1fr auto auto auto;
  gap: 6mm;
  align-items: center;
}
.flow__intro p {
  font-size: 10.5pt;
  color: var(--bf-gray-800);
  line-height: 1.5;
  max-width: 60ch;
}
.flow__metric .lbl { font-family: var(--bf-font-mono); font-size: 8pt; letter-spacing: 0.12em; text-transform: uppercase; color: var(--bf-text-subtle); }
.flow__metric .val { font-family: var(--bf-font-display); font-weight: 700; font-size: 16pt; color: var(--bf-blue); margin-top: 2px; letter-spacing: -0.01em; }

.flow__chain {
  display: grid;
  grid-template-columns: 1fr;
  gap: 4mm;
  flex: 1;
}
.flow__step {
  display: grid;
  grid-template-columns: 26mm 1fr 38mm;
  gap: 6mm;
  align-items: stretch;
  position: relative;
}
.flow__step::after {
  content: "";
  position: absolute;
  left: 13mm; bottom: -4mm;
  width: 0; height: 4mm;
  border-left: 2px dashed var(--bf-cyan);
}
.flow__step:last-child::after { display: none; }

.flow__num {
  background: var(--bf-blue-900);
  color: #fff;
  border-radius: 12px;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  padding: 4mm;
  font-family: var(--bf-font-display);
  position: relative;
  overflow: hidden;
}
.flow__num::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 16px 16px; pointer-events: none;
}
.flow__num .n { font-size: 28pt; line-height: 0.9; letter-spacing: -0.04em; color: var(--bf-cyan); font-weight: 700; }
.flow__num .l { font-family: var(--bf-font-mono); font-size: 8pt; letter-spacing: 0.14em; color: rgba(255,255,255,.7); text-transform: uppercase; margin-top: 4px; }

.flow__body {
  background: #fff;
  border: 1px solid var(--bf-border);
  border-radius: 12px;
  padding: 5mm 6mm;
  display: flex; flex-direction: column; gap: 3mm;
  justify-content: center;
}
.flow__body h4 {
  font-family: var(--bf-font-display);
  font-size: 13pt;
  letter-spacing: -0.01em;
  color: var(--bf-blue-900);
}
.flow__body h4 small {
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  font-weight: 500;
  color: var(--bf-cyan-600);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-left: 8px;
}
.flow__body p {
  font-size: 10pt;
  color: var(--bf-gray-700);
  line-height: 1.5;
}

.flow__tools {
  background: var(--bf-cyan-50);
  border: 1px solid rgba(6,182,212,0.2);
  border-radius: 12px;
  padding: 4mm 5mm;
  display: flex; flex-direction: column; gap: 4px;
  justify-content: center;
}
.flow__tools .lbl {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
  font-weight: 600;
}
.flow__tools .tool {
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 11pt;
  color: var(--bf-blue-900);
  display: flex; justify-content: space-between;
}
.flow__tools .tool span {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  color: var(--bf-text-subtle);
  font-weight: 500;
  align-self: center;
}

/* ---------- BACK COVER (P16) ---------- */
.back {
  background:
    radial-gradient(ellipse at bottom left, rgba(6,182,212,0.3) 0%, transparent 55%),
    linear-gradient(170deg, #0F1E4D 0%, #1E3A8A 100%);
  color: #fff;
  padding: 0;
  display: grid;
  grid-template-rows: auto 1fr auto;
}
.back::before {
  content: ""; position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(ellipse at bottom left, #000 25%, transparent 75%);
  pointer-events: none;
}
.back__top { padding: 22mm 22mm 0; display: flex; justify-content: space-between; align-items: flex-start; position: relative; z-index: 1; }
.back__top .bf-logo { color: #fff; font-size: 14pt; }
.back__top .bf-logo__mark { background: #fff; }
.back__top .bf-logo__mark::before, .back__top .bf-logo__mark::after { background: var(--bf-blue); }
.back__top .bf-logo__mark::after { background: transparent; border-color: var(--bf-blue); }

.back__main { padding: 6mm 22mm; position: relative; z-index: 1; display: flex; flex-direction: column; justify-content: center; }
.back__kicker {
  font-family: var(--bf-font-mono);
  font-size: 10pt;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--bf-cyan);
}
.back__title {
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 44pt;
  letter-spacing: -0.025em;
  line-height: 1;
  margin: 8mm 0 6mm;
  color: #fff;
  max-width: 16ch;
}
.back__title em { color: var(--bf-cyan); font-style: normal; }
.back__sub { font-size: 13pt; color: rgba(255,255,255,.78); max-width: 50ch; line-height: 1.5; }

.back__cta {
  margin-top: 10mm;
  display: flex; gap: 4mm; align-items: center; flex-wrap: wrap;
}
.back__cta .btn {
  font-family: var(--bf-font-body);
  font-weight: 600;
  font-size: 11pt;
  background: var(--bf-cyan);
  color: #052029;
  padding: 12px 22px;
  border-radius: 8px;
  text-decoration: none;
  letter-spacing: 0.01em;
}
.back__cta .url {
  font-family: var(--bf-font-mono);
  font-size: 10pt;
  color: rgba(255,255,255,.65);
  letter-spacing: 0.06em;
}

.disclaimer {
  margin: 8mm 22mm 0;
  position: relative; z-index: 1;
  border-top: 1px solid rgba(255,255,255,.14);
  padding-top: 6mm;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6mm 8mm;
}
.disclaimer h5 {
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bf-cyan);
  font-weight: 600;
  margin-bottom: 3mm;
}
.disclaimer p { font-size: 9.5pt; line-height: 1.55; color: rgba(255,255,255,.72); }

.back__bottom {
  margin: 0 22mm;
  padding: 8mm 0 16mm;
  position: relative; z-index: 1;
  display: flex; justify-content: space-between; align-items: flex-end;
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.back__bottom .pn { color: var(--bf-cyan); font-weight: 600; }

/* PRINT TOOLBAR (screen only) */
.toolbar {
  position: fixed; right: 18px; bottom: 18px;
  z-index: 50;
  display: flex; gap: 8px;
}
.toolbar button {
  font-family: var(--bf-font-body);
  font-weight: 600;
  background: var(--bf-blue-900);
  color: #fff;
  border: 0;
  border-radius: 999px;
  padding: 12px 18px;
  font-size: 13px;
  cursor: pointer;
  box-shadow: var(--bf-shadow-lg);
}
.toolbar button:hover { background: var(--bf-blue); }
.toolbar button.accent { background: var(--bf-cyan); color: #052029; }
.toolbar button.accent:hover { background: #22D3EE; }
@media print { .toolbar { display: none; } }

/* ============================================================
   IMAGE-LM ADDITIONS  (cyan-forward variant)
   ============================================================ */

/* Cyan-forward cover */
.cover--cyan {
  background:
    radial-gradient(ellipse at top right, rgba(255,255,255,0.18) 0%, transparent 55%),
    linear-gradient(165deg, #06B6D4 0%, #0E7490 35%, #155E75 65%, #0F1E4D 100%);
}
.cover--cyan::before {
  background-image:
    linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(ellipse at top right, #000 30%, transparent 80%);
}
.cover--cyan .cover__edition { color: #ECFEFF; }
.cover--cyan .cover__kicker { color: #ECFEFF; }
.cover--cyan .cover__title em { color: #052029; }
.cover--cyan .cover__sub { color: rgba(255,255,255,.85); }
.cover--cyan .cover__chip--accent { background: #052029; color: var(--bf-cyan); border-color: #052029; }
.cover--cyan .cover__metric .val span { color: #052029; }

/* Output-type badges */
.otype {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.08em;
  font-weight: 600;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  border: 1px solid;
  white-space: nowrap;
}
.otype::before {
  content: "";
  width: 8px; height: 8px;
  border-radius: 2px;
  background: currentColor;
}
.otype--photo  { background: #EEF2FB; color: #1E3A8A; border-color: #DCE3F4; }
.otype--illust { background: #ECFEFF; color: #0E7490; border-color: #CFFAFE; }
.otype--vector { background: #ECFDF5; color: #047857; border-color: rgba(4,120,87,.18); }
.otype--video  { background: #FFFBEB; color: #B45309; border-color: rgba(180,83,9,.18); }
.otype--cutout { background: #FAF5FF; color: #6B21A8; border-color: rgba(107,33,168,.18); }

/* Card head: output badge + price stacked */
.tcard__head-right .otype + .price { margin-top: 2px; }

/* CATEGORIES PAGE — 3 big visual cards */
.catgrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6mm;
  flex: 1;
  margin-top: 4mm;
}
.cat {
  border-radius: 14px;
  padding: 7mm;
  display: flex; flex-direction: column;
  position: relative;
  overflow: hidden;
  border: 1px solid var(--bf-border);
  background: #fff;
}
.cat__shape {
  width: 64px; height: 64px;
  margin-bottom: 5mm;
  position: relative;
}
.cat--gen .cat__shape {
  background: var(--bf-cyan);
  border-radius: 50%;
  box-shadow: inset 0 0 0 6px var(--bf-blue-900);
}
.cat--edit .cat__shape {
  background: var(--bf-blue);
  transform: rotate(45deg);
  margin-top: 6mm;
}
.cat--edit .cat__shape::after {
  content: ""; position: absolute;
  inset: 12px;
  background: var(--bf-cyan);
}
.cat--vec .cat__shape {
  width: 0; height: 0;
  border-left: 32px solid transparent;
  border-right: 32px solid transparent;
  border-bottom: 56px solid var(--bf-blue-900);
  background: transparent;
}
.cat--vec .cat__shape::after {
  content: ""; position: absolute;
  left: -16px; bottom: -56px;
  width: 0; height: 0;
  border-left: 16px solid transparent;
  border-right: 16px solid transparent;
  border-bottom: 28px solid var(--bf-cyan);
}
.cat__num {
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
  font-weight: 600;
}
.cat h3 {
  font-family: var(--bf-font-display);
  font-size: 18pt;
  letter-spacing: -0.01em;
  color: var(--bf-blue-900);
  margin-top: 3mm;
  line-height: 1;
}
.cat__count {
  font-family: var(--bf-font-display);
  font-size: 32pt;
  font-weight: 700;
  color: var(--bf-blue);
  letter-spacing: -0.03em;
  line-height: 1;
  margin-top: 5mm;
}
.cat__count small {
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-text-subtle);
  font-weight: 500;
  display: block;
  margin-top: 3mm;
}
.cat__desc {
  font-size: 10pt;
  line-height: 1.55;
  color: var(--bf-gray-700);
  margin-top: 6mm;
  flex: 1;
}
.cat__pills {
  display: flex; gap: 4px; flex-wrap: wrap;
  margin-top: 5mm;
  padding-top: 4mm;
  border-top: 1px dashed var(--bf-border);
}
.cat__pill {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.06em;
  color: var(--bf-gray-700);
  background: var(--bf-gray-50);
  padding: 3px 7px;
  border-radius: 4px;
  border: 1px solid var(--bf-border);
}

/* IMAGE GRID PLACEHOLDER */
.imgrid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 4mm;
  grid-column: span 2;
  margin-top: 2mm;
}
.imgrid__head {
  grid-column: 1 / -1;
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bf-text-subtle);
  padding-bottom: 2mm;
  border-bottom: 1px solid var(--bf-border);
}
.imgrid__head strong {
  font-family: var(--bf-font-display);
  font-size: 12pt;
  font-weight: 600;
  letter-spacing: -0.01em;
  color: var(--bf-blue-900);
  text-transform: none;
}
.thumb {
  aspect-ratio: 1 / 1;
  border-radius: 8px;
  background:
    repeating-linear-gradient(45deg, var(--bf-cyan-50) 0 8px, var(--bf-cyan-100) 8px 16px);
  border: 1px solid rgba(6,182,212,.25);
  padding: 3mm;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative;
}
.thumb__no {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  color: var(--bf-cyan-600);
  font-weight: 700;
  letter-spacing: 0.1em;
}
.thumb__prompt {
  font-family: var(--bf-font-mono);
  font-size: 7.5pt;
  color: var(--bf-blue-900);
  line-height: 1.35;
  background: rgba(255,255,255,.9);
  padding: 4px 6px;
  border-radius: 4px;
  border: 1px solid rgba(6,182,212,.2);
}
.thumb__prompt em { color: var(--bf-cyan-600); font-style: normal; }
.thumb--blue {
  background:
    repeating-linear-gradient(45deg, var(--bf-blue-50) 0 8px, var(--bf-blue-100) 8px 16px);
  border-color: var(--bf-blue-100);
}
.thumb--blue .thumb__no { color: var(--bf-blue); }
.thumb--blue .thumb__prompt { border-color: var(--bf-blue-100); }
.thumb--dark {
  background:
    repeating-linear-gradient(45deg, #0F1E4D 0 8px, #1C347A 8px 16px);
  border-color: var(--bf-blue-900);
  color: #fff;
}
.thumb--dark .thumb__no { color: var(--bf-cyan); }
.thumb--dark .thumb__prompt { background: rgba(15,30,77,.85); color: #fff; border-color: rgba(6,182,212,.4); }
.thumb--dark .thumb__prompt em { color: var(--bf-cyan); }

/* CHEAT SHEET TABLE */
.cheat {
  border: 1px solid var(--bf-border);
  border-radius: 12px;
  overflow: hidden;
  background: #fff;
}
.cheat__row {
  display: grid;
  grid-template-columns: 1fr 1.4fr 1fr 0.8fr;
  gap: 4mm;
  padding: 3.5mm 5mm;
  align-items: center;
  border-bottom: 1px solid var(--bf-border);
  font-size: 9.5pt;
}
.cheat__row:last-child { border-bottom: 0; }
.cheat__row--head {
  background: var(--bf-blue-900);
  color: #fff;
  font-family: var(--bf-font-mono);
  font-size: 8.5pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-weight: 600;
}
.cheat__row:nth-child(odd):not(.cheat__row--head) { background: var(--bf-gray-50); }
.cheat__row .uc {
  font-family: var(--bf-font-display);
  font-weight: 600;
  color: var(--bf-blue-900);
  font-size: 10.5pt;
  letter-spacing: -0.01em;
}
.cheat__row .tool {
  font-weight: 600;
  color: var(--bf-blue);
}
.cheat__row .tool small {
  display: block;
  font-weight: 400;
  color: var(--bf-text-muted);
  font-size: 8.5pt;
  margin-top: 1px;
}
.cheat__row .runner { color: var(--bf-text-muted); font-size: 9pt; }
.cheat__row .pricec {
  font-family: var(--bf-font-mono);
  font-size: 9pt;
  color: var(--bf-cyan-600);
  font-weight: 600;
  text-align: right;
  letter-spacing: 0.04em;
}

/* ============================================================
   AUTOMATION-LM ADDITIONS  (blueprint + circuit motif)
   ============================================================ */

/* Circuit cover overlay */
.cover--circuit {
  background:
    radial-gradient(ellipse at 80% 0%, rgba(6,182,212,0.25) 0%, transparent 50%),
    linear-gradient(160deg, #0F1E4D 0%, #1E3A8A 70%, #1C347A 100%);
}
.cover--circuit::before {
  background-image:
    linear-gradient(rgba(255,255,255,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.05) 1px, transparent 1px),
    radial-gradient(circle at center, rgba(6,182,212,0.45) 1.5px, transparent 2px);
  background-size: 32px 32px, 32px 32px, 32px 32px;
  background-position: 0 0, 0 0, 16px 16px;
  mask-image: radial-gradient(ellipse at top right, #000 25%, transparent 80%);
}
.cover__circuit-svg {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.35;
}

/* Automation-type badges (extends otype family) */
.otype--visual { background: var(--bf-cyan-50); color: var(--bf-cyan-600); border-color: rgba(6,182,212,.18); }
.otype--code   { background: var(--bf-blue-50); color: var(--bf-blue-900); border-color: var(--bf-blue-100); }
.otype--agent  { background: #FAF5FF; color: #6B21A8; border-color: rgba(107,33,168,.18); }
.otype--hybrid { background: var(--bf-gray-100); color: var(--bf-gray-700); border-color: var(--bf-border); }

/* DECISION TREE */
.tree {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3mm;
  margin-top: 3mm;
  position: relative;
}
.tree__row {
  display: grid;
  gap: 4mm;
  align-items: stretch;
}
.tree__row--1 { grid-template-columns: 1fr; }
.tree__row--2 { grid-template-columns: 1fr 1fr; }
.tree__row--3 { grid-template-columns: 1fr 1fr 1fr; }
.tree__row--4 { grid-template-columns: 1fr 1fr 1fr 1fr; }

.node {
  border: 1.5px solid var(--bf-border-strong);
  border-radius: 10px;
  padding: 3mm 4mm;
  background: #fff;
  display: flex; flex-direction: column;
  gap: 1.5mm;
  position: relative;
}
.node__q {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bf-text-subtle);
  font-weight: 600;
}
.node__t {
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 12pt;
  color: var(--bf-blue-900);
  letter-spacing: -0.01em;
  line-height: 1.15;
}
.node__d {
  font-size: 9.5pt;
  color: var(--bf-gray-700);
  line-height: 1.45;
}
.node--root {
  background: var(--bf-blue-900);
  color: #fff;
  border-color: var(--bf-blue-900);
  text-align: center;
  align-items: center;
}
.node--root .node__q { color: var(--bf-cyan); }
.node--root .node__t { color: #fff; font-size: 14pt; }
.node--root .node__d { color: rgba(255,255,255,.78); }
.node--cyan {
  background: var(--bf-cyan-50);
  border-color: rgba(6,182,212,.3);
}
.node--cyan .node__q { color: var(--bf-cyan-600); }
.node--leaf {
  background: var(--bf-gray-50);
}
.node--leaf .node__t { font-size: 10.5pt; }
.node--no { border-color: rgba(180,83,9,.3); background: var(--bf-warning-bg); }
.node--no .node__q { color: var(--bf-warning); }
.node--yes { border-color: rgba(4,120,87,.3); background: var(--bf-success-bg); }
.node--yes .node__q { color: var(--bf-success); }

.tree__branch {
  display: flex; justify-content: center; align-items: center;
  font-family: var(--bf-font-mono);
  font-size: 7.5pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
  font-weight: 600;
  padding: 0;
  position: relative;
}
.tree__branch::before, .tree__branch::after {
  content: "";
  height: 1.5px;
  background: var(--bf-cyan);
  flex: 1;
  margin: 0 4mm;
}

/* CODE BLOCK */
.code {
  background: #0B1430;
  color: #E5E7EB;
  font-family: var(--bf-font-mono);
  font-size: 7pt;
  line-height: 1.5;
  padding: 5mm 6mm 5mm;
  border-radius: 10px;
  border: 1px solid #1C347A;
  overflow: hidden;
  position: relative;
  white-space: pre;
  flex: 1;
}
.code::before {
  content: "";
  position: absolute; left: 0; right: 0; top: 0; height: 28px;
  background: linear-gradient(180deg, rgba(255,255,255,.04), transparent);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.code__head {
  position: absolute; top: 7px; left: 12px; right: 12px;
  display: flex; justify-content: space-between; align-items: center;
  font-family: var(--bf-font-mono);
  font-size: 7pt;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--bf-cyan);
  z-index: 1;
}
.code__head .dots {
  display: inline-flex; gap: 4px;
}
.code__head .dots span {
  width: 7px; height: 7px; border-radius: 50%;
  background: rgba(255,255,255,0.18);
}
.code__head .dots span:first-child { background: #EF4444; }
.code__head .dots span:nth-child(2) { background: #F59E0B; }
.code__head .dots span:nth-child(3) { background: #22C55E; }
.code__inner {
  padding-top: 4mm;
}
.code .k { color: #06B6D4; }     /* keys */
.code .s { color: #84CC16; }     /* strings */
.code .n { color: #F59E0B; }     /* numbers / booleans */
.code .c { color: #6B7280; font-style: italic; }   /* comments */
.code .p { color: #9CA3AF; }     /* punctuation */
.code .id { color: #FBBF24; }    /* node ids */

/* TEMPLATE PAGE LAYOUT */
.tmpl {
  display: grid;
  grid-template-columns: 1fr 1.15fr;
  gap: 5mm;
  flex: 1;
  min-height: 0;
}
.tmpl__brief {
  display: flex; flex-direction: column; gap: 4mm;
  min-height: 0;
}
.tmpl__brief p {
  font-size: 10pt !important;
  line-height: 1.5 !important;
}
.tmpl__diagram {
  background: var(--bf-blue-50);
  border: 1px solid var(--bf-blue-100);
  border-radius: 12px;
  padding: 5mm;
  display: flex; flex-direction: column; gap: 3mm;
}
.tmpl__diagram h5 {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--bf-cyan-600);
  font-weight: 600;
}
.tmpl__steps {
  display: flex; flex-direction: column; gap: 0;
  list-style: none; padding: 0; margin: 0;
}
.tmpl__step {
  display: grid;
  grid-template-columns: 22px 1fr;
  gap: 3mm;
  padding: 1.5mm 0;
  align-items: start;
  position: relative;
}
.tmpl__step + .tmpl__step::before {
  content: "";
  position: absolute;
  left: 10px; top: -2.5mm;
  width: 1.5px; height: 2.5mm;
  background: var(--bf-cyan);
}
.tmpl__step::after {
  content: "";
  position: absolute;
  left: 10px; bottom: -2.5mm;
  width: 1.5px; height: 2.5mm;
  background: var(--bf-cyan);
}
.tmpl__step:last-child::after { display: none; }
.tmpl__step .dot {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: var(--bf-blue-900);
  color: var(--bf-cyan);
  display: grid; place-items: center;
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  font-weight: 700;
}
.tmpl__step .body strong {
  display: block;
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 11pt;
  color: var(--bf-blue-900);
  letter-spacing: -0.01em;
}
.tmpl__step .body span {
  font-size: 9.5pt;
  color: var(--bf-gray-700);
  line-height: 1.45;
}
.tmpl__brief p {
  font-size: 10.5pt;
  color: var(--bf-gray-700);
  line-height: 1.55;
}
.tmpl__meta {
  display: grid; grid-template-columns: 1fr 1fr; gap: 4mm;
  background: var(--bf-bg-alt);
  border: 1px solid var(--bf-border);
  border-radius: 10px;
  padding: 4mm 5mm;
}
.tmpl__meta .lbl {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--bf-text-subtle);
}
.tmpl__meta .val {
  font-family: var(--bf-font-display);
  font-weight: 600;
  font-size: 12pt;
  color: var(--bf-blue);
  letter-spacing: -0.01em;
  margin-top: 2px;
}

/* "Killer use case" line under tcard feats */
.tcard__killer {
  font-size: 8pt;
  line-height: 1.35;
  color: var(--bf-gray-700);
  padding: 1.5mm 2.5mm;
  background: var(--bf-cyan-50);
  border-left: 2px solid var(--bf-cyan);
  border-radius: 0 4px 4px 0;
  margin-top: -1mm;
}
.tcard__killer strong { color: var(--bf-blue-900); font-weight: 700; }

/* in-page section divider for tools-grid section transitions */
.section-divider {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  gap: 4mm;
  margin: 1mm 0;
  padding-top: 2mm;
  border-top: 1.5px dashed var(--bf-blue-100);
}
.section-divider .badge {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: #fff;
  background: var(--bf-blue);
  padding: 4px 10px;
  border-radius: 4px;
  font-weight: 600;
}
.section-divider .name {
  font-family: var(--bf-font-display);
  font-size: 12pt;
  font-weight: 600;
  color: var(--bf-blue-900);
  letter-spacing: -0.01em;
}
.section-divider .count {
  margin-left: auto;
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  letter-spacing: 0.1em;
  color: var(--bf-text-subtle);
}

/* Stack recipes / cheat (re-uses .cheat) — small tweaks */
.recipe {
  border: 1px solid var(--bf-border);
  border-radius: 12px;
  padding: 5mm 6mm;
  background: #fff;
  display: flex; flex-direction: column; gap: 3mm;
}
.recipe h4 {
  font-family: var(--bf-font-display);
  font-size: 13pt;
  letter-spacing: -0.01em;
  color: var(--bf-blue-900);
}
.recipe h4 small {
  font-family: var(--bf-font-mono);
  font-size: 8pt;
  font-weight: 500;
  color: var(--bf-cyan-600);
  letter-spacing: 0.12em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 2px;
}
.recipe ul {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 6px;
}
.recipe li {
  display: flex; justify-content: space-between; gap: 8px;
  font-size: 10pt;
  color: var(--bf-gray-800);
  padding: 4px 0;
  border-bottom: 1px dashed var(--bf-border);
}
.recipe li:last-child { border-bottom: 0; }
.recipe li span {
  color: var(--bf-text-subtle);
  font-family: var(--bf-font-mono);
  font-size: 9pt;
}
.recipe__total {
  margin-top: auto;
  padding-top: 3mm;
  border-top: 1.5px solid var(--bf-blue);
  display: flex; justify-content: space-between;
  font-family: var(--bf-font-display);
  font-weight: 700;
  font-size: 12pt;
  color: var(--bf-blue);
}

/* compact back-cover variant for combined sheet+back page */
.back--compact .back__main { padding-top: 0; }
.back--compact .back__title { font-size: 30pt; margin: 4mm 0; }
.back--compact .back__sub { font-size: 11pt; }
.back--compact .disclaimer { margin-top: 4mm; padding-top: 4mm; }
.back--compact .disclaimer p { font-size: 9pt; }

