/* ==========================================================================
   DocProc — Two-pager (A4 portrait, print-to-PDF)
   Extends colors_and_type.css. Designed to print cleanly across 2 pages.
   ========================================================================== */

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

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: #e6e8ee;
  font-family: var(--bi-font-body);
  font-size: 10pt;
  line-height: 1.4;
  color: var(--bi-fg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

a { color: inherit; text-decoration: none; }

/* ---------- A4 page shell -------------------------------------------------- */
.tp-page {
  width: 210mm;
  height: 297mm;
  background: var(--bi-white);
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  margin: 16mm auto;
  box-shadow: 0 22px 60px rgba(5,10,50,.22);
}
.tp-page__bleed {
  padding: 12mm 14mm 22mm;
  display: block;
  height: 100%;
}
.tp-page--p1 .tp-page__bleed { padding: 13mm 14mm 22mm; display: flex; flex-direction: column; justify-content: center; gap: 11mm; }
.tp-page--p2 .tp-page__bleed { padding: 12mm 14mm 22mm; }

/* ---------- Print toolbar (screen only) ----------------------------------- */
.tp-toolbar {
  position: fixed;
  top: 12px;
  right: 12px;
  z-index: 50;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 8px 8px 16px;
  background: var(--bi-navy);
  color: var(--bi-white);
  border-radius: 999px;
  box-shadow: 0 8px 24px rgba(5,10,50,.35);
  font-family: var(--bi-font-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
}
.tp-toolbar__lang {
  display: inline-flex;
  border: 1px solid rgba(255,255,255,.25);
  border-radius: 999px;
  padding: 3px;
  margin-right: 4px;
}
.tp-toolbar__lang a {
  padding: 4px 10px;
  border-radius: 999px;
  color: rgba(255,255,255,.7);
  transition: background-color .2s ease, color .2s ease;
}
.tp-toolbar__lang a.is-active {
  background: var(--bi-white);
  color: var(--bi-navy);
}
.tp-toolbar__lang a:hover { color: var(--bi-white); }
.tp-toolbar__lang a.is-active:hover { color: var(--bi-navy); }
.tp-toolbar button {
  appearance: none;
  border: 0;
  background: var(--bi-blue-bright);
  color: var(--bi-white);
  font: inherit;
  letter-spacing: inherit;
  text-transform: inherit;
  padding: 10px 18px;
  border-radius: 999px;
  cursor: pointer;
  transition: background-color .2s ease;
}
.tp-toolbar button:hover { background: var(--bi-blue-mid); }
.tp-toolbar__back {
  color: rgba(255,255,255,.65);
  font-family: var(--bi-font-display);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 0 4px 0 8px;
  transition: color .2s ease;
}
.tp-toolbar__back:hover { color: var(--bi-white); }

/* ---------- Page header band --------------------------------------------- */
.tp-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-bottom: 6mm;
  border-bottom: 1px solid var(--bi-border);
}
.tp-head__brand {
  display: flex;
  align-items: center;
  gap: 10px;
}
.tp-head__logo {
  height: 24px;
  width: auto;
}
.tp-head__product {
  font-family: var(--bi-font-display);
  font-size: 12pt;
  font-weight: 700;
  letter-spacing: -.01em;
  color: var(--bi-navy);
  padding-left: 12px;
  border-left: 1px solid var(--bi-border);
  line-height: 1;
}
.tp-head__product small {
  display: block;
  font-family: var(--bi-font-body);
  font-size: 8pt;
  font-weight: 500;
  letter-spacing: 0;
  color: var(--bi-fg-muted);
  margin-top: 3px;
  text-transform: none;
}
.tp-head__meta {
  font-family: var(--bi-font-display);
  font-size: 8.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-fg-muted);
  text-align: right;
}
.tp-head__meta strong {
  display: block;
  color: var(--bi-blue-bright);
  font-weight: 700;
  margin-bottom: 3px;
}

/* ---------- Hero block (page 1) ------------------------------------------ */
.tp-hero {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 9mm;
  align-items: stretch;
  padding: 9mm 0 8mm;
  border-bottom: 1px solid var(--bi-border);
}
.tp-hero__copy {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 6mm;
}
.tp-eyebrow {
  font-family: var(--bi-font-display);
  font-size: 8.5pt;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 4px;
}
.tp-eyebrow::before {
  content: "";
  width: 24px;
  height: 2px;
  background: var(--bi-blue-bright);
}
.tp-hero__title {
  font-family: var(--bi-font-display);
  font-size: 30pt;
  font-weight: 600;
  line-height: 1.02em;
  letter-spacing: -.012em;
  margin: 0;
  color: var(--bi-navy);
}
.tp-hero__title b {
  font-weight: 600;
  color: var(--bi-blue-bright);
  display: block;
}
.tp-hero__lead {
  font-size: 11.5pt;
  font-weight: 500;
  line-height: 1.35em;
  color: var(--bi-fg-subtle);
  margin: 0;
  max-width: 100mm;
}
.tp-hero__sub {
  font-size: 9.5pt;
  font-weight: 500;
  line-height: 1.45em;
  color: var(--bi-fg-subtle);
  padding: 10px 14px;
  border-left: 2px solid var(--bi-blue-bright);
  background: rgba(0,149,242,.04);
  border-radius: 0 8px 8px 0;
  margin: 0;
}
.tp-hero__sub strong {
  display: block;
  font-family: var(--bi-font-display);
  font-weight: 600;
  font-size: 8.5pt;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
  margin-bottom: 6px;
}

/* Hero photo column (page 1) */
.tp-hero__photo {
  position: relative;
  border-radius: 12px;
  background-color: var(--bi-navy);
  background-size: cover;
  background-position: center;
  overflow: hidden;
  min-height: 90mm;
  box-shadow: 0 12px 32px rgba(5,10,50,.18);
}
.tp-hero__photo::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(5,10,50,0) 40%, rgba(5,10,50,.65) 100%),
              linear-gradient(120deg, rgba(70,50,150,.25), rgba(0,149,242,.10) 70%);
}
.tp-hero__photo-tag {
  position: absolute;
  left: 8mm;
  bottom: 8mm;
  right: 8mm;
  z-index: 1;
  color: var(--bi-white);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.tp-hero__photo-tag strong {
  font-family: var(--bi-font-display);
  font-size: 8.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
}
.tp-hero__photo-tag span {
  font-family: var(--bi-font-display);
  font-size: 13pt;
  font-weight: 600;
  letter-spacing: -.005em;
  line-height: 1.1em;
}
.tp-hero__photo-chip {
  position: absolute;
  top: 7mm;
  left: 7mm;
  z-index: 1;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px 6px 8px;
  background: rgba(255,255,255,.95);
  border-radius: 999px;
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-navy);
}
.tp-hero__photo-chip::before {
  content: "";
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #1f8a5b;
  box-shadow: 0 0 0 3px rgba(31,138,91,.22);
}

/* ---------- Stats strip --------------------------------------------------- */
.tp-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 8mm 0 7mm;
  border-bottom: 1px solid var(--bi-border);
}
.tp-stat {
  padding: 0 6mm;
  border-left: 1px solid var(--bi-border);
}
.tp-stat:first-child { padding-left: 0; border-left: 0; }
.tp-stat__value {
  font-family: var(--bi-font-display);
  font-size: 19pt;
  font-weight: 700;
  line-height: 1.05em;
  color: var(--bi-navy);
  letter-spacing: -.012em;
  margin-bottom: 6px;
}
.tp-stat__label {
  font-size: 9pt;
  font-weight: 500;
  line-height: 1.3em;
  color: var(--bi-fg-muted);
}

/* ---------- Section heading row ------------------------------------------ */
.tp-sechead {
  padding: 2mm 0 1mm;
}
.tp-page--p1 .tp-sechead { padding: 7mm 0 5mm; }
.tp-sechead__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12mm;
}
.tp-sechead__title {
  font-family: var(--bi-font-display);
  font-size: 13pt;
  font-weight: 600;
  letter-spacing: -.005em;
  color: var(--bi-navy);
  margin: 0;
  line-height: 1.15em;
}
.tp-page--p1 .tp-sechead__title { font-size: 17pt; line-height: 1.1em; }
.tp-sechead__lead {
  font-size: 9.5pt;
  font-weight: 500;
  line-height: 1.3em;
  color: var(--bi-fg-subtle);
  max-width: 95mm;
  margin: 0;
}
.tp-page--p1 .tp-sechead__lead { font-size: 10.5pt; line-height: 1.4em; max-width: 105mm; }

/* ---------- Value-prop pillars (page 1) ---------------------------------- */
.tp-pillars {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 5mm;
}
.tp-pillar {
  border: 1px solid var(--bi-border);
  border-radius: 10px;
  padding: 7mm 6mm 6mm;
  display: flex;
  flex-direction: column;
  position: relative;
  background: var(--bi-white);
}
.tp-pillar::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 30%;
  height: 2px;
  background: var(--bi-blue-bright);
}
.tp-pillar__num {
  font-family: var(--bi-font-display);
  font-size: 22pt;
  font-weight: 700;
  color: var(--bi-blue-bright);
  line-height: 1em;
  letter-spacing: -.02em;
  margin: 0 0 8px;
}
.tp-pillar__title {
  font-family: var(--bi-font-display);
  font-size: 13pt;
  font-weight: 600;
  line-height: 1.2em;
  margin: 0 0 8px;
  color: var(--bi-navy);
}
.tp-pillar__body {
  font-size: 10pt;
  font-weight: 500;
  line-height: 1.42em;
  color: var(--bi-fg-subtle);
  margin: 0;
}

/* ---------- Pipeline row (page 2) ---------------------------------------- */

/* Page-2 hero banner (replaces the first sechead) */
.tp-banner {
  position: relative;
  margin: 2mm 0 4mm;
  flex-shrink: 0;
  height: 22mm;
  min-height: 22mm;
  border-radius: 10px;
  overflow: hidden;
  background-color: var(--bi-navy);
  background-size: cover;
  background-position: center;
  display: flex;
  align-items: center;
  padding: 0 7mm;
  color: var(--bi-white);
  box-shadow: 0 8px 20px rgba(5,10,50,.18);
}
.tp-banner::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(100deg, rgba(5,10,50,.85) 0%, rgba(5,10,50,.55) 45%, rgba(5,10,50,.20) 100%);
}
.tp-banner__copy {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 3px;
  max-width: 130mm;
}
.tp-banner__eyebrow {
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 600;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
  display: flex;
  align-items: center;
  gap: 10px;
}
.tp-banner__eyebrow::before {
  content: "";
  width: 24px;
  height: 2px;
  background: var(--bi-blue-light);
}
.tp-banner__title {
  font-family: var(--bi-font-display);
  font-size: 13pt;
  font-weight: 600;
  line-height: 1.1em;
  letter-spacing: -.005em;
  margin: 0;
}
.tp-banner__title b {
  font-weight: 600;
  color: var(--bi-blue-light);
}
.tp-banner__count {
  position: absolute;
  right: 7mm;
  top: 50%;
  transform: translateY(-50%);
  z-index: 1;
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.65);
  text-align: right;
  line-height: 1.3em;
}
.tp-banner__count strong {
  display: block;
  color: var(--bi-white);
  font-size: 17pt;
  font-weight: 700;
  letter-spacing: -.01em;
  line-height: 1em;
  margin-bottom: 2px;
}

.tp-pipeline {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 4mm;
  position: relative;
  padding: 0 0 2mm;
}
.tp-pipeline::before {
  content: "";
  position: absolute;
  left: 4%;
  right: 4%;
  top: 9mm;
  height: 1px;
  background: linear-gradient(90deg, rgba(0,149,242,.25), var(--bi-blue-bright) 50%, rgba(123,218,255,.25));
}
.tp-step {
  display: flex;
  flex-direction: column;
  gap: 5px;
  position: relative;
  z-index: 1;
}
.tp-step__icon {
  width: 8mm;
  height: 8mm;
  border-radius: 7px;
  background: var(--bi-blue-bright);
  color: var(--bi-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--bi-font-display);
  font-size: 10pt;
  font-weight: 700;
  margin-bottom: 2px;
  box-shadow: 0 2px 4px rgba(0,149,242,.25);
}
.tp-step--review .tp-step__icon {
  background: var(--bi-purple-600);
  box-shadow: 0 2px 4px rgba(110,80,210,.25);
}
.tp-step__label {
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-fg-muted);
}
.tp-step__title {
  font-family: var(--bi-font-display);
  font-size: 10pt;
  font-weight: 600;
  line-height: 1.15em;
  margin: 0;
  color: var(--bi-navy);
}
.tp-step__body {
  font-size: 8pt;
  font-weight: 500;
  line-height: 1.28em;
  color: var(--bi-fg-subtle);
  margin: 0;
}
.tp-step__meta {
  margin-top: auto;
  padding-top: 4px;
  border-top: 1px dashed var(--bi-border);
  font-family: var(--bi-font-display);
  font-size: 6.8pt;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
}
.tp-step--review .tp-step__meta { color: var(--bi-purple-600); }

/* ---------- Page 3 two-column bottom ------------------------------------ */
.tp-p3-bottom {
  display: grid;
  grid-template-columns: 3fr 2fr;
  gap: 6mm;
  margin-top: 5mm;
}
.tp-p3-doctypes .tp-eyebrow,
.tp-p3-integrations .tp-eyebrow { margin: 0 0 3mm; }
.tp-doclist {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2mm;
}
.tp-doclist__item {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 2.5mm 3mm;
  background: var(--bi-bg-muted);
  border-radius: 6px;
  font-family: var(--bi-font-display);
  font-size: 9pt;
  font-weight: 600;
  color: var(--bi-navy);
  line-height: 1.2em;
}
.tp-doclist__item span {
  font-family: var(--bi-font-body);
  font-size: 7.5pt;
  font-weight: 500;
  color: var(--bi-fg-muted);
}
.tp-p3-integrations .tp-integrations {
  grid-template-columns: 1fr;
  gap: 2.5mm;
}
.tp-p3-integrations .tp-integration {
  display: grid;
  grid-template-columns: 16mm 1fr;
  align-items: start;
  gap: 2mm;
  padding: 2.5mm 3mm;
}
.tp-p3-integrations .tp-integration__list {
  flex-direction: row;
  flex-wrap: wrap;
  gap: 2px 8px;
}


.tp-doctypes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4mm;
}
.tp-doctype {
  border: 1px solid var(--bi-border);
  border-radius: 8px;
  padding: 3mm 4mm;
  display: flex;
  flex-direction: column;
  gap: 2px;
  position: relative;
}
.tp-doctype__icon {
  width: 8mm;
  height: 9mm;
  border-radius: 3px;
  border: 1.4px solid var(--bi-blue-bright);
  background: rgba(0,149,242,.06);
  position: relative;
  margin-bottom: 3px;
}
.tp-doctype__icon::before,
.tp-doctype__icon::after {
  content: "";
  position: absolute;
  left: 1.4mm;
  right: 1.4mm;
  height: 1.2px;
  background: var(--bi-blue-bright);
  opacity: .55;
}
.tp-doctype__icon::before { top: 2.6mm; }
.tp-doctype__icon::after { top: 4.4mm; right: 3.2mm; }
.tp-doctype__title {
  font-family: var(--bi-font-display);
  font-size: 10pt;
  font-weight: 600;
  line-height: 1.18em;
  margin: 0;
  color: var(--bi-navy);
}
.tp-doctype__body {
  font-size: 8pt;
  font-weight: 500;
  line-height: 1.3em;
  color: var(--bi-fg-subtle);
  margin: 0;
}

/* ---------- Integrations strip (page 2) ---------------------------------- */
.tp-integrations {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4mm;
}
.tp-integration {
  background: var(--bi-bg-muted);
  border-radius: 8px;
  padding: 3mm 5mm;
}
.tp-integration__title {
  font-family: var(--bi-font-display);
  font-size: 8.5pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
  margin: 0 0 6px;
}
.tp-integration__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px 10px;
}
.tp-integration__list li {
  font-size: 8.5pt;
  font-weight: 600;
  color: var(--bi-fg);
  display: flex;
  align-items: center;
  gap: 6px;
}
.tp-integration__list li::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--bi-blue-bright);
  flex-shrink: 0;
}

/* ---------- Contact ribbon (page bottom) -------------------------------- */
.tp-contact {
  flex-shrink: 0;
  background: linear-gradient(135deg, #463296, #050a32);
  color: var(--bi-white);
  border-radius: 10px;
  padding: 4mm 6mm;
  display: grid;
  grid-template-columns: 18mm 1.2fr 1fr;
  gap: 6mm;
  align-items: center;
  position: relative;
  overflow: hidden;
}
.tp-contact__art {
  height: 100%;
  min-height: 18mm;
  border-radius: 8px;
  background-color: rgba(255,255,255,.06);
  background-size: cover;
  background-position: center;
  position: relative;
  overflow: hidden;
}
.tp-contact__art::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(70,50,150,.35), rgba(5,10,50,.10));
}
.tp-contact::before {
  content: "";
  position: absolute;
  right: -30mm;
  bottom: -30mm;
  width: 80mm;
  height: 80mm;
  background: radial-gradient(circle, rgba(123,218,255,.18), transparent 70%);
}
.tp-contact__eyebrow {
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
  margin-bottom: 5px;
}
.tp-contact__title {
  font-family: var(--bi-font-display);
  font-size: 12pt;
  font-weight: 600;
  line-height: 1.1em;
  margin: 0 0 3px;
  letter-spacing: -.005em;
}
.tp-contact__lead {
  font-size: 8pt;
  font-weight: 500;
  line-height: 1.32em;
  color: rgba(255,255,255,.85);
  margin: 0;
  max-width: 100mm;
}
.tp-contact__sidebar {
  position: relative;
  z-index: 1;
  display: flex;
  flex-direction: column;
  gap: 3mm;
}
.tp-contact__channel {
  display: flex;
  flex-direction: column;
  gap: 1px;
  padding: 2.5mm 4mm;
  background: rgba(255,255,255,.07);
  border-left: 2px solid var(--bi-blue-light);
  border-radius: 0 6px 6px 0;
}
.tp-contact__channel-label {
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
}
.tp-contact__channel-value {
  font-family: var(--bi-font-display);
  font-size: 10pt;
  font-weight: 600;
  color: var(--bi-white);
  letter-spacing: -.005em;
}

/* Footers always pinned to page bottom */
.tp-page { position: relative; }
.tp-foot {
  position: absolute;
  bottom: 8mm;
  left: 14mm;
  right: 14mm;
  margin-top: 0;
  border-top: 1px solid var(--bi-border);
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 500;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-fg-muted);
}
.tp-foot__page {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.tp-foot__page strong {
  font-weight: 700;
  color: var(--bi-navy);
}
.tp-foot__link {
  color: var(--bi-blue-bright);
}

/* ==========================================================================
   WHITE-PAPER ADDITIONS — animation depiction · ROI table · goodie steps
   ========================================================================== */

/* ---------- Inline TOC strip (page 1) ------------------------------------ */
.tp-toc {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  border-top: 1px solid var(--bi-border);
  border-bottom: 1px solid var(--bi-border);
  padding: 4mm 0;
  margin: 4mm 0 0;
}
.tp-toc__item {
  padding: 0 5mm;
  border-left: 1px solid var(--bi-border);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.tp-toc__item:first-child { padding-left: 0; border-left: 0; }
.tp-toc__num {
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 700;
  letter-spacing: .14em;
  color: var(--bi-blue-bright);
}
.tp-toc__title {
  font-family: var(--bi-font-display);
  font-size: 10pt;
  font-weight: 600;
  color: var(--bi-navy);
  line-height: 1.2em;
}
.tp-toc__page {
  font-family: var(--bi-font-display);
  font-size: 7pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-fg-muted);
  margin-top: 2px;
}

/* ---------- Animation depiction (page 1, vertical) ----------------------- */
.tp-anim {
  position: relative;
  border-radius: 12px;
  background: linear-gradient(150deg, #050a32 0%, #1a1860 55%, #3a2a82 100%);
  padding: 5mm 5mm 5mm;
  color: var(--bi-white);
  overflow: hidden;
  box-shadow: 0 12px 32px rgba(5,10,50,.18);
  display: flex;
  flex-direction: column;
  gap: 2mm;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}
.tp-anim::after {
  content: "";
  position: absolute;
  top: -25mm;
  right: -15mm;
  width: 75mm;
  height: 75mm;
  background: radial-gradient(circle, rgba(0,149,242,.22), transparent 65%);
  pointer-events: none;
}
.tp-anim::before {
  content: "";
  position: absolute;
  left: -15mm;
  bottom: -20mm;
  width: 60mm;
  height: 60mm;
  background: radial-gradient(circle, rgba(123,218,255,.10), transparent 65%);
  pointer-events: none;
}
.tp-anim__head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4mm;
}
.tp-anim__chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 10px 3px 8px;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(123,218,255,.30);
  border-radius: 999px;
  font-family: var(--bi-font-display);
  font-size: 6.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
}
.tp-anim__chip::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--bi-blue-light);
  box-shadow: 0 0 0 3px rgba(123,218,255,.20);
}
.tp-anim__caption {
  font-family: var(--bi-font-display);
  font-size: 6pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  text-align: right;
  line-height: 1.3em;
}
.tp-anim__caption strong {
  display: block;
  color: var(--bi-white);
  font-size: 7.5pt;
  font-weight: 700;
  letter-spacing: .04em;
  margin-bottom: 1px;
}

/* Vertical connector between depiction tiles */
.tp-anim__connector {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 6mm;
  margin: -1mm 0;
}
.tp-anim__connector::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 1.4px;
  background: linear-gradient(180deg, rgba(123,218,255,.15), rgba(123,218,255,.65) 40%, rgba(123,218,255,.65) 60%, rgba(123,218,255,.15));
  transform: translateX(-50%);
}
.tp-anim__connector-label {
  position: relative;
  z-index: 1;
  font-family: var(--bi-font-display);
  font-size: 6pt;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
  background: #1a1860;
  padding: 1.5px 8px;
  border-radius: 999px;
  border: 1px solid rgba(123,218,255,.40);
  white-space: nowrap;
}
.tp-anim__connector::after {
  content: "";
  position: absolute;
  bottom: 1mm;
  left: 50%;
  transform: translateX(-50%);
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 6px solid rgba(123,218,255,.85);
}

/* Document tile (left) */
.tp-anim__doc {
  background: var(--bi-white);
  color: var(--bi-fg);
  border-radius: 6px;
  padding: 2.5mm 3mm;
  display: flex;
  flex-direction: column;
  gap: 1mm;
  box-shadow: 0 8px 22px rgba(0,0,0,.20);
  font-family: var(--bi-font-body);
  font-size: 6.5pt;
  line-height: 1.35em;
  position: relative;
  z-index: 1;
}
.tp-anim__doc-corner {
  position: absolute;
  top: 0;
  right: 0;
  width: 6mm;
  height: 6mm;
  background:
    linear-gradient(225deg, #f6f7fa 50%, transparent 50%);
  border-bottom-left-radius: 3px;
}
.tp-anim__doc-bar {
  display: flex;
  align-items: center;
  gap: 4px;
  margin-bottom: 1.5mm;
  padding-bottom: 1.5mm;
  border-bottom: 1px solid rgba(0,0,0,.08);
}
.tp-anim__doc-bar i {
  display: inline-block;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: #dde1ea;
}
.tp-anim__doc-bar span {
  margin-left: 2mm;
  font-family: var(--bi-font-display);
  font-size: 6pt;
  font-weight: 600;
  letter-spacing: .04em;
  color: var(--bi-fg-muted);
}
.tp-anim__doc-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 3mm;
  margin-bottom: 0.6mm;
}
.tp-anim__doc-brand {
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 700;
  color: var(--bi-navy);
  line-height: 1.1em;
}
.tp-anim__doc-brand small {
  display: block;
  font-family: var(--bi-font-body);
  font-size: 5.5pt;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: var(--bi-fg-muted);
  margin-top: 0.5mm;
}
.tp-anim__doc-meta {
  text-align: right;
  font-family: var(--bi-font-body);
  font-size: 5.5pt;
  color: var(--bi-fg-muted);
  line-height: 1.4em;
}
.tp-anim__doc-meta strong {
  display: block;
  font-family: var(--bi-font-display);
  font-size: 6pt;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--bi-navy);
  margin-bottom: 0.5mm;
}
.tp-anim__doc-row {
  display: flex;
  justify-content: space-between;
  gap: 4px;
  padding: 0.7mm 0;
  font-size: 5.8pt;
  color: var(--bi-fg-subtle);
  border-bottom: 1px dotted rgba(0,0,0,.06);
}
.tp-anim__doc-row strong {
  font-weight: 600;
  color: var(--bi-navy);
}
.tp-anim__doc-row--hl {
  background: rgba(0,149,242,.10);
  margin: 0 -1.5mm;
  padding-left: 1.5mm;
  padding-right: 1.5mm;
  border-radius: 2px;
  border-bottom-color: transparent;
  outline: 1px solid rgba(0,149,242,.45);
  outline-offset: -1px;
}
.tp-anim__doc-total {
  display: flex;
  justify-content: space-between;
  margin-top: auto;
  padding-top: 1mm;
  border-top: 1.2px solid var(--bi-navy);
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 700;
  color: var(--bi-navy);
}

/* Extracted-fields tile (middle-right) */
.tp-anim__fields {
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(123,218,255,.22);
  border-radius: 6px;
  padding: 2.5mm 3mm;
  display: flex;
  flex-direction: column;
  gap: 1.2mm;
  backdrop-filter: none;
}
.tp-anim__fields-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-bottom: 1.4mm;
  border-bottom: 1px solid rgba(123,218,255,.18);
}
.tp-anim__fields-title {
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 700;
  color: var(--bi-white);
  letter-spacing: -.005em;
}
.tp-anim__fields-meta {
  font-family: var(--bi-font-display);
  font-size: 5.5pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
}
.tp-anim__field {
  display: grid;
  grid-template-columns: 14mm 1fr auto;
  align-items: center;
  gap: 1.5mm;
  padding: 1.2mm 2mm;
  border: 1px solid rgba(123,218,255,.25);
  background: rgba(0,149,242,.10);
  border-radius: 3px;
}
.tp-anim__field-label {
  font-family: var(--bi-font-display);
  font-size: 5.5pt;
  font-weight: 600;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
}
.tp-anim__field-value {
  font-family: var(--bi-font-display);
  font-size: 7pt;
  font-weight: 600;
  color: var(--bi-white);
  letter-spacing: -.005em;
}
.tp-anim__field-conf {
  font-family: var(--bi-font-display);
  font-size: 5.8pt;
  font-weight: 700;
  letter-spacing: .04em;
  color: var(--bi-blue-light);
  background: rgba(123,218,255,.10);
  border: 1px solid rgba(123,218,255,.35);
  padding: 0.8mm 2mm;
  border-radius: 999px;
  white-space: nowrap;
}
.tp-anim__field--review {
  border-color: rgba(168,139,250,.45);
  background: rgba(168,139,250,.10);
}
.tp-anim__field--review .tp-anim__field-conf {
  color: #d6c4ff;
  background: rgba(168,139,250,.15);
  border-color: rgba(168,139,250,.45);
}

/* Output column (right / bottom row) */
.tp-anim__out {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5mm;
  position: relative;
  z-index: 1;
}
.tp-anim__out-card {
  display: flex;
  align-items: center;
  gap: 2.5mm;
  padding: 2.5mm 3mm;
  border-radius: 6px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.18);
  color: var(--bi-white);
}
.tp-anim__out-card--erp {
  background: linear-gradient(135deg, rgba(0,149,242,.20), rgba(0,149,242,.06));
  border-color: rgba(0,149,242,.40);
}
.tp-anim__out-icon {
  flex-shrink: 0;
  width: 7mm;
  height: 7mm;
  border-radius: 4px;
  background: var(--bi-blue-bright);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--bi-white);
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 700;
}
.tp-anim__out-card--dms .tp-anim__out-icon {
  background: var(--bi-purple-600);
}
.tp-anim__out-card-text strong {
  display: block;
  font-family: var(--bi-font-display);
  font-size: 8pt;
  font-weight: 700;
  letter-spacing: -.005em;
  color: var(--bi-white);
}
.tp-anim__out-card-text small {
  display: block;
  font-family: var(--bi-font-body);
  font-size: 5.8pt;
  font-weight: 500;
  letter-spacing: 0;
  text-transform: none;
  color: rgba(255,255,255,.70);
  margin-top: 0.5mm;
}

/* ---------- Page-2 problem stats (4 cards) ------------------------------- */
.tp-probstats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 3mm;
  margin: 4mm 0 5mm;
}
.tp-probstat {
  padding: 4mm 4.5mm;
  border: 1px solid var(--bi-border);
  border-radius: 8px;
  background: var(--bi-white);
  display: flex;
  flex-direction: column;
  gap: 1mm;
  position: relative;
}
.tp-probstat::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, rgba(217,70,70,.85), rgba(217,70,70,.15));
  border-top-left-radius: 8px;
  border-top-right-radius: 8px;
}
.tp-probstat__value {
  font-family: var(--bi-font-display);
  font-size: 17pt;
  font-weight: 700;
  line-height: 1.05em;
  letter-spacing: -.012em;
  color: var(--bi-navy);
}
.tp-probstat__label {
  font-size: 8.5pt;
  font-weight: 500;
  line-height: 1.3em;
  color: var(--bi-fg-subtle);
  margin-top: auto;
}
.tp-probstat__sub {
  font-family: var(--bi-font-display);
  font-size: 6.5pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #b34c4c;
  margin-bottom: 1mm;
}

/* ---------- Page-2 narrative two-column ---------------------------------- */
.tp-narr {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6mm;
  padding: 4mm 0 5mm;
}
.tp-narr__col h4 {
  font-family: var(--bi-font-display);
  font-size: 11pt;
  font-weight: 600;
  margin: 0 0 2mm;
  color: var(--bi-navy);
  line-height: 1.2em;
}
.tp-narr__col p {
  font-size: 9.5pt;
  line-height: 1.45em;
  color: var(--bi-fg-subtle);
  margin: 0 0 2.5mm;
}
.tp-narr__col p:last-child { margin-bottom: 0; }
.tp-narr__col p strong { color: var(--bi-navy); font-weight: 600; }

/* Pull-quote-style callout (the 36.7% return note) */
.tp-callout {
  padding: 5mm 6mm;
  background: linear-gradient(135deg, rgba(0,149,242,.07), rgba(0,149,242,.02));
  border-left: 3px solid var(--bi-blue-bright);
  border-radius: 0 10px 10px 0;
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 6mm;
  align-items: center;
  margin: 0 0 5mm;
}
.tp-callout__big {
  font-family: var(--bi-font-display);
  font-size: 26pt;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--bi-blue-bright);
  line-height: 1em;
}
.tp-callout__big small {
  display: block;
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
  margin-top: 2mm;
  line-height: 1.2em;
}
.tp-callout__body {
  font-size: 9pt;
  line-height: 1.45em;
  color: var(--bi-fg-subtle);
}
.tp-callout__body strong {
  color: var(--bi-navy);
  font-weight: 600;
}

/* Page 2 — spread the problem blocks evenly down the sheet so there is no
   single jarring mid-page gap */
.tp-page--p2 .tp-page__bleed {
  display: flex;
  flex-direction: column;
}
.tp-page--p2 .tp-probstats,
.tp-page--p2 .tp-narr,
.tp-page--p2 .tp-compare-block { margin-top: auto; }

/* ---------- Compare table (page 2) -------------------------------------- */
.tp-compare {
  width: 100%;
  border-collapse: collapse;
  margin-top: 2mm;
  font-size: 9pt;
}
.tp-compare th,
.tp-compare td {
  padding: 2.8mm 4mm;
  text-align: left;
  border-bottom: 1px solid var(--bi-border);
}
.tp-compare thead th {
  font-family: var(--bi-font-display);
  font-size: 8.5pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-fg-muted);
  background: var(--bi-bg-muted);
  border-bottom: 1.5px solid var(--bi-border);
}
.tp-compare thead th:nth-child(3) {
  color: var(--bi-blue-bright);
  background: rgba(0,149,242,.06);
}
.tp-compare th:first-child { border-top-left-radius: 6px; }
.tp-compare th:last-child { border-top-right-radius: 6px; }
.tp-compare tbody th {
  font-family: var(--bi-font-display);
  font-weight: 600;
  font-size: 9pt;
  color: var(--bi-navy);
  width: 38%;
}
.tp-compare td {
  font-family: var(--bi-font-display);
  font-weight: 600;
  font-size: 9.5pt;
  color: var(--bi-fg);
  letter-spacing: -.005em;
}
.tp-compare td:last-child {
  color: var(--bi-blue-bright);
  background: rgba(0,149,242,.04);
}
.tp-compare tbody tr:last-child td,
.tp-compare tbody tr:last-child th { border-bottom: 0; }

/* ---------- Goodie steps (page 4) ---------------------------------------- */
.tp-goodie-hero {
  position: relative;
  border-radius: 10px;
  background: linear-gradient(135deg, #050a32 0%, #2f1f78 60%, #6e50d2 100%);
  color: var(--bi-white);
  padding: 6mm 7mm;
  margin: 2mm 0 5mm;
  overflow: hidden;
  -webkit-print-color-adjust: exact;
  print-color-adjust: exact;
}
.tp-goodie-hero::after {
  content: "";
  position: absolute;
  right: -20mm;
  top: -20mm;
  width: 80mm;
  height: 80mm;
  background: radial-gradient(circle, rgba(123,218,255,.20), transparent 65%);
  pointer-events: none;
}
.tp-goodie-hero__chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 3px 12px 3px 9px;
  background: rgba(123,218,255,.10);
  border: 1px solid rgba(123,218,255,.30);
  border-radius: 999px;
  font-family: var(--bi-font-display);
  font-size: 7pt;
  font-weight: 700;
  letter-spacing: .16em;
  text-transform: uppercase;
  color: var(--bi-blue-light);
  margin-bottom: 3mm;
}
.tp-goodie-hero__chip::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--bi-blue-light);
}
.tp-goodie-hero__title {
  font-family: var(--bi-font-display);
  font-size: 17pt;
  font-weight: 600;
  line-height: 1.1em;
  letter-spacing: -.008em;
  margin: 0 0 2.5mm;
  position: relative;
  z-index: 1;
}
.tp-goodie-hero__title b {
  font-weight: 600;
  color: var(--bi-blue-light);
}
.tp-goodie-hero__lead {
  font-size: 9.5pt;
  font-weight: 500;
  line-height: 1.45em;
  color: rgba(255,255,255,.85);
  margin: 0;
  max-width: 150mm;
  position: relative;
  z-index: 1;
}

.tp-goodie {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 4mm;
  margin-bottom: 5mm;
}
.tp-goodie-step {
  border: 1px solid var(--bi-border);
  border-radius: 10px;
  padding: 5mm 5mm 4mm;
  display: flex;
  flex-direction: column;
  gap: 2mm;
  background: var(--bi-white);
  position: relative;
}
.tp-goodie-step__num {
  position: absolute;
  top: -6mm;
  left: 5mm;
  width: 11mm;
  height: 11mm;
  border-radius: 50%;
  background: var(--bi-blue-bright);
  color: var(--bi-white);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--bi-font-display);
  font-size: 13pt;
  font-weight: 700;
  box-shadow: 0 4px 10px rgba(0,149,242,.30);
}
.tp-goodie-step__label {
  margin-top: 7mm;
  font-family: var(--bi-font-display);
  font-size: 7pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-fg-muted);
}
.tp-goodie-step__title {
  font-family: var(--bi-font-display);
  font-size: 11pt;
  font-weight: 600;
  line-height: 1.2em;
  margin: 0;
  color: var(--bi-navy);
}
.tp-goodie-step__body {
  font-size: 8.5pt;
  line-height: 1.4em;
  color: var(--bi-fg-subtle);
  margin: 0;
}
.tp-goodie-step__body code {
  font-family: var(--bi-font-office-mono, ui-monospace, "SFMono-Regular", Menlo, monospace);
  font-size: 7.5pt;
  background: var(--bi-bg-muted);
  padding: 0.4mm 1.5mm;
  border-radius: 3px;
  color: var(--bi-navy);
}
.tp-goodie-step__result {
  font-size: 8pt;
  line-height: 1.35em;
  color: var(--bi-fg-subtle);
  padding: 2.5mm 3mm;
  background: rgba(0,149,242,.05);
  border-left: 2px solid var(--bi-blue-bright);
  border-radius: 0 4px 4px 0;
  margin: 0;
}
.tp-goodie-step__result strong {
  font-family: var(--bi-font-display);
  font-weight: 600;
  color: var(--bi-blue-bright);
  font-size: 7pt;
  letter-spacing: .12em;
  text-transform: uppercase;
  display: block;
  margin-bottom: 1mm;
}
.tp-goodie-step__time {
  margin-top: auto;
  padding-top: 2mm;
  font-family: var(--bi-font-display);
  font-size: 7pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
  border-top: 1px dashed var(--bi-border);
}

/* "What you get after one afternoon" checklist */
.tp-checklist {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2mm 5mm;
  padding: 4mm 5mm;
  background: var(--bi-bg-muted);
  border-radius: 8px;
  margin: 0 0 4mm;
}
.tp-checklist__title {
  grid-column: 1 / -1;
  font-family: var(--bi-font-display);
  font-size: 9pt;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
  margin-bottom: 1mm;
}
.tp-checklist__item {
  font-size: 8.5pt;
  line-height: 1.4em;
  color: var(--bi-fg);
  padding-left: 6mm;
  position: relative;
}
.tp-checklist__item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 1.2mm;
  width: 4mm;
  height: 4mm;
  border-radius: 50%;
  background: var(--bi-blue-bright);
}
.tp-checklist__item::after {
  content: "";
  position: absolute;
  left: 1.1mm;
  top: 2.2mm;
  width: 1.8mm;
  height: 0.9mm;
  border-left: 1.2px solid var(--bi-white);
  border-bottom: 1.2px solid var(--bi-white);
  transform: rotate(-45deg);
}

/* "When PA stops being enough" limits matrix */
.tp-limits {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5mm 4mm;
  margin: 2mm 0 4mm;
}
.tp-limit {
  display: grid;
  grid-template-columns: 6mm 1fr;
  gap: 3mm;
  padding: 2.5mm 3mm;
  border: 1px solid var(--bi-border);
  border-radius: 6px;
  background: var(--bi-white);
}
.tp-limit__icon {
  width: 6mm;
  height: 6mm;
  border-radius: 50%;
  background: rgba(217,70,70,.10);
  color: #b34c4c;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--bi-font-display);
  font-size: 9pt;
  font-weight: 700;
  flex-shrink: 0;
}
.tp-limit__title {
  font-family: var(--bi-font-display);
  font-size: 8.5pt;
  font-weight: 600;
  color: var(--bi-navy);
  line-height: 1.2em;
  margin: 0;
}
.tp-limit__body {
  font-size: 7.8pt;
  line-height: 1.35em;
  color: var(--bi-fg-subtle);
  margin: 1mm 0 0;
}

/* ---------- Closing block on page 3 (handoff + contact) ----------------- */
/* Contact ribbon here has no art column */
.tp-page--p3 .tp-contact {
  grid-template-columns: 1.4fr 1fr;
}
/* Let page 3 ground its closing block at the bottom of the sheet */
.tp-page--p3 .tp-page__bleed {
  display: flex;
  flex-direction: column;
}
.tp-page--p3 .tp-handoff {
  margin-top: auto;
}

/* "That is where DocProc takes over" handoff strip */
.tp-handoff {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6mm;
  align-items: center;
  padding: 5mm 6mm;
  background: linear-gradient(135deg, rgba(0,149,242,.10), rgba(0,149,242,.02));
  border: 1px solid rgba(0,149,242,.25);
  border-radius: 10px;
  margin-bottom: 4mm;
}
.tp-handoff__copy {
  display: flex;
  flex-direction: column;
  gap: 2mm;
}
.tp-handoff__eyebrow {
  font-family: var(--bi-font-display);
  font-size: 7.5pt;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--bi-blue-bright);
}
.tp-handoff__title {
  font-family: var(--bi-font-display);
  font-size: 13pt;
  font-weight: 600;
  line-height: 1.15em;
  color: var(--bi-navy);
  margin: 0;
}
.tp-handoff__lead {
  font-size: 9pt;
  line-height: 1.4em;
  color: var(--bi-fg-subtle);
  margin: 0;
}
.tp-handoff__arrow {
  font-family: var(--bi-font-display);
  font-size: 30pt;
  font-weight: 700;
  color: var(--bi-blue-bright);
  line-height: 1em;
  letter-spacing: -.04em;
}

/* ---------- Print rules --------------------------------------------------- */
@media print {
  html, body { background: white; }
  .tp-toolbar { display: none !important; }
  .tp-page {
    margin: 0;
    box-shadow: none;
    page-break-after: always;
  }
  .tp-page:last-child { page-break-after: auto; }
}
