body.vault-hub-page { background: var(--l-bg); color: var(--l-text); }
.vx-head { border-bottom: 1px solid var(--l-line); }
.vx-head__in { padding-block: 64px 56px; max-width: 820px; }
@media (max-width: 720px) { .vx-head__in { padding-block: 46px 40px; } }
.vx-kick { display: inline-flex; align-items: center; gap: 11px; }
.vx-kick .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--azure); flex: none; }
.vx-head h1 { font-weight: 700; letter-spacing: -0.04em; line-height: 0.97; margin: 20px 0 0;
  font-size: clamp(40px, 6vw, 72px); text-wrap: balance; color: var(--l-text); }
.vx-head__sub { font-family: 'Newsreader', Georgia, serif; font-size: clamp(18px, 2.1vw, 22px); line-height: 1.5;
  color: var(--l-muted); margin: 22px 0 0; max-width: 600px; text-wrap: pretty; }
.vx-head__meta { display: flex; gap: 26px; margin: 30px 0 0; flex-wrap: wrap;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--l-faint); }
.vx-head__meta span { display: inline-flex; align-items: center; gap: 9px; }
.vx-head__meta .sq { width: 7px; height: 7px; background: var(--l-line-2); transform: rotate(45deg); flex: none; }
.vx-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; }
@media (max-width: 960px) { .vx-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .vx-grid { grid-template-columns: 1fr; } }
.vcardx { position: relative; display: flex; flex-direction: column; padding: 26px 26px 22px;
  background: var(--l-paper); border: 1px solid var(--l-line); border-radius: var(--radius);
  transition: border-color .3s, transform .45s var(--ease), box-shadow .35s; overflow: hidden; color: inherit; }
.vcardx::before { content: ""; position: absolute; top: 16px; right: 16px; width: 14px; height: 14px;
  border-top: 1.5px solid var(--l-line-2); border-right: 1.5px solid var(--l-line-2); transition: border-color .3s; }
.vcardx:hover { border-color: var(--azure-line); transform: translateY(-4px); box-shadow: 0 26px 50px -34px rgba(21,22,15,.32); }
.vcardx:hover::before { border-color: var(--azure); }
.vcardx__code { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.16em; text-transform: uppercase; color: var(--l-faint); }
.vcardx__name { font-family: var(--font); font-weight: 700; font-size: 23px; letter-spacing: -0.03em; line-height: 1.06;
  color: var(--l-text); margin: 14px 0 0; text-wrap: balance; }
.vcardx__who { font-family: 'Newsreader', Georgia, serif; font-size: 15px; line-height: 1.45; color: var(--l-muted);
  margin: 9px 0 0; text-wrap: pretty; }
.vcardx__count { display: inline-flex; align-items: center; gap: 8px; margin: 18px 0 0;
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--l-faint); }
.vcardx__count b { color: var(--l-text); font-weight: 700; }
.vcardx__count .tk { color: var(--l-line-2); }
.vcardx__ex { margin: 16px 0 0; padding-top: 16px; border-top: 1px solid var(--l-line); display: grid; gap: 10px; }
.vcardx__exrow { display: grid; grid-template-columns: auto 1fr; gap: 11px; align-items: start; }
.vcardx__exrow .mk { width: 7px; height: 7px; background: var(--l-line-2); transform: rotate(45deg); margin-top: 6px; flex: none; transition: background .3s; }
.vcardx:hover .vcardx__exrow .mk { background: var(--azure); }
.vcardx__exrow .q { font-family: var(--font); font-size: 13.5px; font-weight: 500; letter-spacing: -0.01em; line-height: 1.3; color: var(--l-text); }
.vcardx__open { display: flex; align-items: center; gap: 10px; margin-top: 20px; padding-top: 18px;
  border-top: 1px solid var(--l-line); font-weight: 600; font-size: 14px; color: var(--l-text); }
.vcardx__open .lbl { transition: color .3s; }
.vcardx:hover .vcardx__open .lbl { color: var(--azure-700); }
.vcardx__open .arw2 { margin-left: auto; width: 30px; height: 30px; border-radius: 999px; display: grid; place-items: center;
  border: 1px solid var(--l-line-2); color: var(--l-muted); transition: background .3s, color .3s, border-color .3s, transform .4s var(--ease); }
.vcardx:hover .vcardx__open .arw2 { background: var(--azure); color: #fff; border-color: var(--azure); transform: translateX(2px); }
.vx-alt { margin-top: 18px; display: grid; grid-template-columns: 1.2fr 1fr; gap: 18px; }
@media (max-width: 760px) { .vx-alt { grid-template-columns: 1fr; } }
.altcard { display: flex; align-items: center; gap: 20px; padding: 26px 28px; border-radius: var(--radius);
  background: var(--l-paper); border: 1px solid var(--l-line); transition: border-color .3s, transform .4s var(--ease), box-shadow .3s; }
.altcard:hover { border-color: var(--azure-line); transform: translateY(-3px); box-shadow: 0 18px 36px -28px rgba(21,22,15,.28); }
.altcard__ic { width: 46px; height: 46px; border-radius: 12px; border: 1px solid var(--l-line-2); display: grid; place-items: center; color: var(--l-muted); flex: none; transition: color .3s, border-color .3s; }
.altcard:hover .altcard__ic { color: var(--azure); border-color: var(--azure-line); }
.altcard__t { font-weight: 600; font-size: 16.5px; letter-spacing: -0.02em; color: var(--l-text); }
.altcard__d { font-family: 'Newsreader', Georgia, serif; font-size: 14px; color: var(--l-muted); margin-top: 4px; line-height: 1.4; }
.altcard__arw { margin-left: auto; color: var(--l-faint); transition: transform .4s var(--ease), color .3s; flex: none; }
.altcard:hover .altcard__arw { color: var(--azure-700); transform: translateX(3px); }
.vx-strip { position: relative; overflow: hidden; margin-top: 18px; border-radius: var(--radius);
  background: var(--ink); color: var(--paper); padding: 30px 36px; display: flex; align-items: center; gap: 28px; flex-wrap: wrap; }
.vx-strip__bg { position: absolute; inset: 0; background-image: radial-gradient(rgba(247,248,242,0.05) 1.3px, transparent 1.3px); background-size: 30px 30px; }
.vx-strip__txt { position: relative; max-width: 620px; }
.vx-strip__k { font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--azure-300); }
.vx-strip__h { font-size: 19px; font-weight: 600; letter-spacing: -0.02em; line-height: 1.35; margin: 8px 0 0; }
.vx-strip__h b { color: var(--azure-300); font-weight: 600; }
.vx-strip .btn { position: relative; margin-left: auto; }
@media (max-width: 620px) { .vx-strip { padding: 26px 22px; } .vx-strip .btn { margin-left: 0; } }
.vault-hub-page .sec-head__t { color: var(--l-text); }

@media (max-width: 720px) {
  .vault-hub-page .masthead { display: none; }
}

/* Side gutters — beats layout shells that set padding shorthand on .wrap */
.vault-hub-page .wrap {
  padding-inline: var(--gutter);
}
