body.vault-persona-page { background: var(--l-bg); color: var(--l-text); }
.crumbs { display: flex; align-items: center; gap: 10px; font-family: var(--mono); font-size: 11.5px;
  letter-spacing: 0.14em; text-transform: uppercase; color: var(--l-faint); }
.crumbs a { color: var(--azure-700); }
.crumbs .sep { color: var(--l-line-2); }
.vh { position: relative; border-bottom: 1px solid var(--l-line); }
.vh__in { display: grid; grid-template-columns: 1.06fr 0.94fr; gap: 60px; align-items: center; padding-block: 40px 76px; }
@media (max-width: 940px) { .vh__in { grid-template-columns: 1fr; gap: 40px; padding-block: 32px 56px; } }
.vh__kick { display: inline-flex; align-items: center; gap: 11px; margin-top: 22px;
  font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--azure-700); }
.vh__kick .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--azure); flex: none; }
.vh h1 { font-weight: 700; letter-spacing: -0.04em; line-height: 0.98; margin: 18px 0 0;
  font-size: clamp(38px, 5.4vw, 62px); text-wrap: balance; color: var(--l-text); }
.vh__sub { font-family: 'Newsreader', Georgia, serif; color: var(--l-muted); font-size: clamp(18px, 2vw, 21px);
  line-height: 1.55; margin: 22px 0 0; max-width: 520px; text-wrap: pretty; }
.vh__meta { display: flex; gap: 28px; margin: 30px 0 0; flex-wrap: wrap; }
.vh__stat { display: flex; flex-direction: column; gap: 4px; }
.vh__stat b { font-family: var(--font); font-weight: 700; font-size: 22px; letter-spacing: -0.02em; color: var(--l-text); }
.vh__stat span { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--l-faint); }
.cover { position: relative; background: var(--l-paper); border: 1px solid var(--l-line-2); border-radius: var(--radius-lg);
  box-shadow: 0 40px 80px -54px rgba(21,22,15,.34); overflow: hidden; }
.cover::before, .cover::after { content: ""; position: absolute; width: 16px; height: 16px; border-color: var(--l-line-2); border-style: solid; z-index: 2; }
.cover::before { top: 14px; left: 14px; border-width: 1.5px 0 0 1.5px; }
.cover::after { bottom: 14px; right: 14px; border-width: 0 1.5px 1.5px 0; }
.cover__top { padding: 28px 30px 22px; border-bottom: 1px solid var(--l-line); }
.cover__code { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--l-faint); display: flex; justify-content: space-between; }
.cover__t { font-family: var(--font); font-weight: 700; font-size: clamp(23px, 2.8vw, 28px); letter-spacing: -0.03em; line-height: 1.05; margin: 14px 0 0; }
.cover__for { font-family: 'Newsreader', Georgia, serif; font-size: 14.5px; color: var(--l-muted); margin: 9px 0 0; }
.cover__list { padding: 10px 30px 6px; }
.cline { display: grid; grid-template-columns: auto 1fr auto; gap: 13px; align-items: center; padding: 11px 0; border-bottom: 1px solid var(--l-line); }
.cline:last-child { border-bottom: 0; }
.cline .mk { width: 8px; height: 8px; background: var(--l-line-2); transform: rotate(45deg); flex: none; }
.cline .q { font-family: var(--font); font-size: 13.5px; font-weight: 500; letter-spacing: -0.01em; color: var(--l-text); line-height: 1.25; }
.cline .t { font-family: var(--mono); font-size: 10px; letter-spacing: 0.04em; color: var(--l-faint); white-space: nowrap; }
.cover__more { padding: 13px 30px 22px; font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--l-faint); }
.cover__cta { display: flex; flex-direction: column; gap: 5px; margin-top: 16px; padding: 17px 22px;
  background: var(--l-paper); border: 1px solid var(--l-line-2); border-radius: var(--radius);
  transition: border-color .3s, transform .4s var(--ease), box-shadow .3s; }
.cover__cta:hover { border-color: var(--azure-line); transform: translateY(-2px); box-shadow: 0 18px 36px -28px rgba(21,22,15,.28); }
.cover__cta-main { display: flex; align-items: center; gap: 9px; font-family: var(--font); font-weight: 600; font-size: 16px; letter-spacing: -0.015em; color: var(--azure-700); }
.cover__cta-main .arw { transition: transform .4s var(--ease); }
.cover__cta:hover .cover__cta-main .arw { transform: translateX(3px); }
.cover__cta-sub { font-family: 'Newsreader', Georgia, serif; font-size: 14px; line-height: 1.4; color: var(--l-muted); }
.jrn { padding-top: 64px; }
.jrn__head { max-width: 600px; }
.jrn__head .eyebrow { display: flex; align-items: center; gap: 12px; font-family: var(--mono); font-size: 12px;
  letter-spacing: 0.2em; text-transform: uppercase; color: var(--azure-700); }
.jrn__head .eyebrow .ln { height: 1px; width: 34px; background: var(--azure); }
.jrn__head h2 { font-weight: 700; font-size: clamp(28px, 3.8vw, 38px); letter-spacing: -0.03em; line-height: 1.05; margin: 14px 0 0; color: var(--l-text); }
.jrn__head p { font-family: 'Newsreader', Georgia, serif; font-size: 17.5px; line-height: 1.55; color: var(--l-muted); margin: 14px 0 0; max-width: 56ch; }
#stages { display: flex; flex-direction: column; gap: 26px; margin-top: 38px; }
.stage { position: relative; background: var(--l-paper); border: 1px solid var(--l-line); border-radius: var(--radius);
  overflow: hidden; box-shadow: 0 24px 48px -40px rgba(21,22,15,.32); }
.stage__head { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 18px;
  padding: 19px 24px; background: var(--l-card); border-bottom: 1px solid var(--l-line-2); }
.stage__badge { display: grid; place-items: center; width: 42px; height: 42px; border-radius: 11px; flex: none;
  background: var(--ink); color: var(--paper); font-family: var(--mono); font-weight: 700; font-size: 15px; }
.stage__tag { display: block; font-family: var(--mono); font-size: 10.5px; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: var(--azure-700); }
.stage__name { font-family: var(--font); font-weight: 700; font-size: 20px; letter-spacing: -0.025em; color: var(--l-text); margin-top: 3px; }
.stage__hint { display: block; font-family: 'Newsreader', Georgia, serif; font-style: italic; font-size: 13.5px; color: var(--l-faint); margin-top: 5px; }
.stage__count { align-self: center; font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--l-faint); white-space: nowrap; }
@media (max-width: 640px) { .stage__head { grid-template-columns: auto 1fr; padding: 16px 18px; } .stage__count { display: none; } }
.route { display: flex; flex-direction: column; }
.arow { display: grid; grid-template-columns: auto 1fr auto; gap: 20px; align-items: center;
  padding: 18px 24px; color: var(--l-text); transition: background .25s ease; }
.arow + .arow { border-top: 1px solid var(--l-line); }
.arow:hover { background: var(--azure-soft); }
.arow__seq { display: grid; place-items: center; width: 32px; height: 32px; border-radius: 50%; flex: none;
  border: 1.5px solid var(--l-line-2); background: var(--l-paper); font-family: var(--mono); font-size: 12px; font-weight: 700;
  color: var(--l-muted); transition: background .3s, color .3s, border-color .3s; }
.arow:hover .arow__seq { border-color: var(--azure); color: var(--azure-700); background: #fff; }
.arow__col { font-family: var(--mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--l-faint); }
.arow__q { font-family: var(--font); font-weight: 600; font-size: 18px; letter-spacing: -0.02em; line-height: 1.25; margin: 5px 0 0; color: var(--l-text); text-wrap: balance; }
.arow:hover .arow__q { color: var(--azure-700); }
.arow__a { font-family: 'Newsreader', Georgia, serif; font-size: 15px; line-height: 1.5; color: var(--l-muted); margin: 5px 0 0; max-width: 62ch; text-wrap: pretty; }
.arow__go { display: flex; align-items: center; gap: 14px; flex: none; }
.arow__rt { display: inline-flex; align-items: center; gap: 6px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.04em; color: var(--l-faint); white-space: nowrap; }
.arow__rt svg { width: 13px; height: 13px; }
.arow__arw { width: 34px; height: 34px; border-radius: 50%; border: 1px solid var(--l-line-2); display: grid; place-items: center;
  color: var(--l-muted); flex: none; transition: background .3s, color .3s, border-color .3s, transform .35s var(--ease); }
.arow:hover .arow__arw { background: var(--azure); border-color: var(--azure); color: #fff; transform: translateX(2px); }
.arow--pending { cursor: default; }
.arow--pending:hover { background: transparent; }
.arow--pending:hover .arow__seq,
.arow--pending:hover .arow__q { color: inherit; border-color: var(--l-line-2); background: var(--l-paper); }
.arow__soon { font-family: var(--mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--l-faint); white-space: nowrap; }
@media (max-width: 640px) {
  .arow { gap: 14px; padding: 16px 18px; }
  .arow__a { display: none; }
  .arow__go { flex-direction: column-reverse; gap: 8px; align-items: flex-end; }
}
.jrn__note { margin-top: 38px; font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.04em; color: var(--l-faint);
  display: flex; align-items: center; gap: 10px; }
.jrn__note .sq { width: 7px; height: 7px; background: var(--l-line-2); transform: rotate(45deg); flex: none; }
.conv { margin-top: 80px; }
.conv__band { position: relative; overflow: hidden; border-radius: var(--radius-lg); background: var(--ink); color: var(--paper); padding: 60px 56px; }
.conv__bg { position: absolute; inset: 0; background-image: radial-gradient(rgba(247,248,242,0.05) 1.3px, transparent 1.3px); background-size: 34px 34px; }
.conv__in { position: relative; max-width: 920px; margin: 0 auto; text-align: center; }
.conv__k { font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--azure-300); display: inline-flex; align-items: center; gap: 10px; }
.conv__k .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--azure); }
.conv h2 { font-weight: 700; font-size: clamp(28px, 4vw, 42px); letter-spacing: -0.03em; line-height: 1.04; margin: 16px auto 0; text-wrap: balance; max-width: 20ch; }
.conv h2 b { color: var(--azure-300); font-weight: 700; }
.conv__p { font-family: 'Newsreader', Georgia, serif; font-size: 18px; color: var(--d-muted); margin: 16px auto 0; max-width: 600px; line-height: 1.55; }
.conv__reasons { display: grid; grid-template-columns: repeat(3, 1fr); gap: 30px; margin: 40px 0 0; padding-top: 30px; border-top: 1px solid var(--d-line); text-align: left; }
@media (max-width: 680px) { .conv__reasons { grid-template-columns: 1fr; } }
.reason__n { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--d-faint); }
.reason__t { font-size: 17px; font-weight: 700; letter-spacing: -0.02em; margin: 9px 0 0; color: var(--paper); }
.reason__d { font-size: 13.5px; color: var(--d-muted); line-height: 1.5; margin: 6px 0 0; }
.conv__cta { display: flex; align-items: center; justify-content: center; gap: 18px; margin: 38px 0 0; flex-wrap: wrap; }
.conv__cta .micro { font-family: var(--mono); font-size: 11px; letter-spacing: 0.05em; color: var(--d-faint); }
@media (max-width: 620px) { .conv__band { padding: 44px 24px; } }
.xlinks { padding-top: 72px; display: grid; grid-template-columns: 1fr 1fr; gap: 56px; }
@media (max-width: 800px) { .xlinks { grid-template-columns: 1fr; gap: 40px; } }
.xcol__h { display: flex; align-items: center; gap: 12px; font-family: var(--mono); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--azure-700); }
.xcol__h .ln { height: 1px; width: 28px; background: var(--azure); }
.xrel { margin-top: 18px; display: grid; gap: 10px; }
.relcard { display: flex; align-items: center; gap: 16px; padding: 18px 20px; border-radius: var(--radius-sm);
  background: var(--l-paper); border: 1px solid var(--l-line); transition: border-color .3s, transform .35s var(--ease), box-shadow .3s; }
.relcard:hover { border-color: var(--azure-line); transform: translateY(-2px); box-shadow: 0 16px 32px -28px rgba(21,22,15,.3); }
.relcard__mk { width: 9px; height: 9px; background: var(--l-line-2); transform: rotate(45deg); flex: none; transition: background .3s; }
.relcard:hover .relcard__mk { background: var(--azure); }
.relcard__n { font-family: var(--font); font-weight: 600; font-size: 16px; letter-spacing: -0.02em; color: var(--l-text); }
.relcard__w { font-family: 'Newsreader', Georgia, serif; font-size: 13.5px; color: var(--l-muted); margin-top: 2px; line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
.relcard__arw { margin-left: auto; color: var(--l-faint); flex: none; transition: transform .4s var(--ease), color .3s; }
.relcard:hover .relcard__arw { color: var(--azure-700); transform: translateX(3px); }
.xtopics { margin-top: 18px; display: flex; flex-wrap: wrap; gap: 10px; }
.tchip { display: inline-flex; align-items: center; gap: 9px; padding: 10px 16px; border-radius: 999px;
  border: 1px solid var(--l-line-2); background: var(--l-paper); color: var(--l-text); font-size: 14px; font-weight: 500;
  transition: border-color .25s, transform .3s var(--ease); }
.tchip:hover { border-color: var(--azure-line); transform: translateY(-2px); }
.tchip .mono { font-family: var(--mono); font-size: 11px; color: var(--azure-700); }
.xtopics__note { width: 100%; margin-top: 14px; font-family: 'Newsreader', Georgia, serif; font-size: 14px; color: var(--l-muted); }
.trustline { margin: 64px 0 0; border-top: 1px solid var(--l-line); padding-top: 26px;
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--l-faint); }
.trustline .sep { color: var(--l-line-2); }

/* Side gutters — beats layout shells that set padding shorthand on .wrap */
.vault-persona-page .wrap {
  padding-inline: var(--gutter);
}
