:root {
  --bg: #050505;
  --panel: #0b0b0d;
  --soft: #111114;
  --line: rgba(205, 162, 83, 0.22);
  --line-soft: rgba(255,255,255,0.08);
  --gold: #d7b06c;
  --gold-soft: #f2dfb2;
  --text: #f3efe8;
  --muted: #b7b1a6;
  --danger: #d89191;
  --success: #a7d7a3;
}
* { box-sizing: border-box; }
html { color-scheme: dark; }
body {
  margin: 0;
  font-family: Inter, system-ui, sans-serif;
  background: radial-gradient(circle at top, rgba(132, 89, 17, 0.12), transparent 26%), var(--bg);
  color: var(--text);
}
.hidden { display: none !important; }
.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 260px 1fr;
}
.sidebar {
  border-right: 1px solid var(--line);
  padding: 32px 24px;
  background: rgba(7,7,8,0.94);
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.brand-mark {
  width: 64px;
  height: 64px;
  border: 1px solid var(--line);
  border-radius: 20px;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.02);
  overflow: hidden;
}
.brand-logo {
  width: 40px;
  height: 40px;
  object-fit: contain;
  display: block;
}
.auth-brand {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
}
.auth-logo {
  width: 82px;
  height: 82px;
  object-fit: contain;
  display: block;
  filter: drop-shadow(0 12px 24px rgba(215,176,108,0.22));
}
.sidebar h1,
.header-stack h2,
.panel-header h3,
.subsection-header h4 {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  letter-spacing: 0.01em;
}
.eyebrow {
  color: var(--gold);
  font-size: 12px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.user-meta {
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255,255,255,0.02);
  color: var(--muted);
  line-height: 1.6;
}
.ghost-btn, .primary-btn {
  border-radius: 14px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  cursor: pointer;
  font-weight: 600;
  transition: transform .12s ease, opacity .12s ease;
}
.ghost-btn:hover, .primary-btn:hover { transform: translateY(-1px); }
.ghost-btn {
  background: transparent;
  color: var(--text);
}
.primary-btn {
  background: linear-gradient(180deg, rgba(219,181,112,0.16), rgba(219,181,112,0.08));
  color: var(--gold-soft);
}
.main-content { padding: 32px; }
.panel {
  background: linear-gradient(180deg, rgba(255,255,255,0.015), rgba(255,255,255,0.008));
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 24px;
  backdrop-filter: blur(8px);
}
.auth-panel {
  max-width: 600px;
  margin: 3vh auto 4vh;
  padding: 34px 38px 30px;
  position: relative;
  box-shadow: 0 22px 60px rgba(0,0,0,0.35);
}
.auth-panel::before {
  content: '';
  display: block;
  width: 84px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(215,176,108,0.75), transparent);
  margin: 0 auto 22px;
}

.header-stack {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.header-stack .eyebrow { text-align: center; margin-bottom: 0; }
.header-stack h2 { text-align: center; font-size: clamp(34px, 5vw, 52px); line-height: 0.96; }
.header-stack p { max-width: 420px; text-align: center; margin: 0 auto 0; }
.header-stack p, .muted { color: var(--muted); }
.form-grid {
  display: grid;
  gap: 16px;
  margin-top: 24px;
}

.auth-switch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  width: min(100%, 360px);
  margin: 18px auto 0;
  padding: 8px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 999px;
}
.auth-tab {
  appearance: none;
  border: 0;
  border-radius: 999px;
  background: transparent;
  color: var(--muted);
  padding: 12px 16px;
  font: inherit;
  font-weight: 600;
  cursor: pointer;
}
.auth-tab.is-active {
  background: linear-gradient(180deg, rgba(219,181,112,0.18), rgba(219,181,112,0.08));
  color: var(--gold-soft);
  box-shadow: inset 0 0 0 1px rgba(219,181,112,0.14);
}
.auth-form { margin-top: 18px; }
.auth-helper-text {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
  text-align: center;
  padding: 2px 8px 0;
}
.compact { gap: 14px; }
label {
  display: grid;
  gap: 8px;
  color: var(--muted);
  font-size: 14px;
}
input, select, textarea {
  width: 100%;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--text);
  border-radius: 18px;
  padding: 16px 18px;
  font: inherit;
}
input::placeholder, textarea::placeholder { color: rgba(183,177,166,0.78); }
textarea { resize: vertical; }
.message {
  margin-top: 16px;
  min-height: 20px;
  color: var(--muted);
  text-align: center;
}
.top-grid {
  display: grid;
  grid-template-columns: 1.7fr 1fr 1fr 1fr;
  gap: 18px;
}
.hero-card {
  min-height: 180px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.balance-value {
  font-size: clamp(38px, 4vw, 58px);
  font-family: 'Cormorant Garamond', serif;
  margin: 4px 0 8px;
  color: var(--gold-soft);
}
.stat-card {
  display: grid;
  align-content: center;
  min-height: 180px;
}
.stat-value {
  font-size: 34px;
  color: var(--gold-soft);
  font-family: 'Cormorant Garamond', serif;
}
.content-grid {
  display: grid;
  grid-template-columns: 1.15fr 1fr;
  gap: 18px;
  margin-top: 18px;
}
.feature-grid { grid-template-columns: 1fr 1fr; }
.bottom-grid { grid-template-columns: 1fr 1fr; }
.admin-core-grid,
.admin-flow-grid { grid-template-columns: 1fr 1fr; }
.admin-stack { display: grid; gap: 18px; margin-top: 18px; }
.panel-header {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
}
.subsection-header {
  margin: 22px 0 14px;
}
.list-stack {
  display: grid;
  gap: 12px;
}
.list-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
}
.list-card strong {
  display: block;
  margin-bottom: 4px;
  color: var(--gold-soft);
}
.list-card small {
  color: var(--muted);
  display: block;
  line-height: 1.5;
}
.inline-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.inline-pill,
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line-soft);
  border-radius: 999px;
  padding: 6px 10px;
  font-size: 12px;
  color: var(--muted);
}
.status-pill { margin-top: 8px; }
.admin-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}
.mini-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 18px;
  background: rgba(255,255,255,0.02);
  display: grid;
  gap: 8px;
}
.mini-card span { color: var(--muted); font-size: 13px; }
.mini-card strong {
  color: var(--gold-soft);
  font-size: 26px;
  font-family: 'Cormorant Garamond', serif;
}
.create-grid {
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.span-2 { grid-column: span 2; }
.card-actions {
  display: flex;
  gap: 10px;
  margin-top: 12px;
  flex-wrap: wrap;
}
.card-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.text-btn {
  background: transparent;
  color: var(--gold-soft);
  border: 1px solid var(--line-soft);
  border-radius: 12px;
  padding: 10px 14px;
  cursor: pointer;
}
.text-btn:hover { transform: translateY(-1px); }
.danger-btn { color: var(--danger); }
.helper-note {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.6;
  margin: 14px 0 8px;
}
.package-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.package-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
  text-align: left;
  cursor: pointer;
  color: var(--text);
}
.package-card strong,
.package-card small,
.package-name {
  display: block;
}
.package-card strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 28px;
  color: var(--gold-soft);
  margin: 8px 0 4px;
}
.package-card small,
.package-name { color: var(--muted); }
.package-card.is-selected {
  border-color: var(--gold);
  box-shadow: 0 0 0 1px rgba(215,176,108,0.18) inset;
}
.filter-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.filter-tab {
  background: transparent;
  color: var(--muted);
  border: 1px solid var(--line-soft);
  border-radius: 999px;
  padding: 8px 12px;
  cursor: pointer;
}
.filter-tab.is-active {
  color: var(--gold-soft);
  border-color: var(--line);
}

.expiry-lot-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px;
  background: rgba(255,255,255,0.02);
  display: grid;
  gap: 12px;
}
.expiry-lot-top {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 12px;
}
.expiry-lot-amount {
  display: block;
  margin-top: 6px;
  color: var(--gold-soft);
  font-family: 'Cormorant Garamond', serif;
  font-size: 34px;
  line-height: 1;
}
.expiry-lot-meta {
  display: grid;
  gap: 6px;
}
.expiry-lot-date,
.expiry-lot-balance {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.5;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 92px;
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 11px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  border: 1px solid var(--line-soft);
  color: var(--muted);
}
.status-pending { color: var(--gold-soft); }
.status-in_progress,
.status-approved { color: #b9d9a0; }
.status-completed { color: #b8d4ff; }
.status-rejected,
.status-reversed { color: var(--danger); }
.status-proof_submitted { color: #d1c3ff; }
@media (max-width: 1220px) {
  .top-grid,
  .content-grid,
  .admin-grid,
  .feature-grid,
  .bottom-grid,
  .admin-core-grid,
  .admin-flow-grid,
  .package-grid,
  .create-grid {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 980px) {
  .app-shell { grid-template-columns: 1fr; }
  .sidebar { border-right: none; border-bottom: 1px solid var(--line); padding: 24px 20px 16px; gap: 10px; }
  .top-grid,
  .content-grid,
  .admin-grid,
  .feature-grid,
  .bottom-grid,
  .admin-core-grid,
  .admin-flow-grid,
  .package-grid,
  .create-grid { grid-template-columns: 1fr; }
  .span-2 { grid-column: span 1; }
  .main-content { padding: 16px; }
  .auth-panel {
    margin: 6px auto 18px;
    padding: 28px 20px 22px;
    border-radius: 22px;
  }
  .auth-logo { width: 74px; height: 74px; }
  .header-stack h2 { font-size: 26px; }
  .auth-switch { width: 100%; }
}



.cc-package-grid { margin-top: 1.4rem; }


.expiry-grid { grid-template-columns: 1.05fr 1fr; }
.expiry-summary-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.mini-stat {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px 18px;
  background: rgba(255,255,255,0.02);
}
.mini-stat strong {
  display: block;
  font-size: 28px;
  line-height: 1.05;
  color: var(--gold-soft);
  font-family: "Cormorant Garamond", serif;
  margin-bottom: 6px;
}
.mini-stat small { color: var(--muted); display: block; line-height: 1.45; }
@media (max-width: 900px) {
  .expiry-grid { grid-template-columns: 1fr; }
  .expiry-summary-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .expiry-summary-grid { grid-template-columns: 1fr; }
}


input[type="file"] {
  padding: 14px 16px;
  line-height: 1.4;
}
.proof-helper {
  margin: -2px 0 0;
}

.proof-upload-tips {
  display: grid;
  gap: 6px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(196, 161, 90, 0.12);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
}
.proof-upload-tips strong {
  color: var(--gold-soft);
  font-size: 12px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}
.proof-upload-tips span {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.55;
}
.proof-preview {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(196, 161, 90, 0.14);
  border-radius: 22px;
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.06), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
}
.proof-preview img {
  width: 100%;
  max-height: 320px;
  object-fit: contain;
  border-radius: 16px;
  border: 1px solid rgba(196, 161, 90, 0.12);
  background: linear-gradient(180deg, rgba(8, 7, 6, 0.96), rgba(13, 12, 11, 0.92));
}
.proof-preview a {
  color: var(--gold-soft);
  text-decoration: none;
  font-size: 13px;
  white-space: nowrap;
}
.proof-preview-head strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 17px;
}
.proof-preview-note {
  margin: 0;
}
.proof-label {
  color: var(--muted);
  font-size: 14px;
}
.proof-inline {
  display: grid;
  gap: 10px;
  margin-top: 10px;
}
.proof-inline img {
  width: 100%;
  max-height: 220px;
  object-fit: cover;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,0.08);
}
.proof-inline a {
  color: var(--gold-soft);
  text-decoration: none;
  font-size: 13px;
}


.proof-preview-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}

.admin-proof-preview {
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(196, 161, 90, 0.16);
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.08), transparent 34%),
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.015));
}

.admin-proof-preview img {
  width: 100%;
  height: auto;
  max-height: 460px;
  object-fit: contain;
  background: linear-gradient(180deg, rgba(8, 7, 6, 0.96), rgba(13, 12, 11, 0.92));
  border-color: rgba(196, 161, 90, 0.14);
}

.proof-thumb-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 10px;
}

.proof-thumb {
  width: 72px;
  height: 72px;
  border-radius: 18px;
  object-fit: cover;
  border: 1px solid rgba(196, 161, 90, 0.24);
  background: rgba(255,255,255,0.02);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}

.proof-thumb-fallback {
  width: 72px;
  height: 72px;
  border-radius: 18px;
  display: grid;
  place-items: center;
  border: 1px solid rgba(196, 161, 90, 0.18);
  color: rgba(233, 224, 205, 0.78);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01));
  font-size: 12px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.proof-thumb-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.proof-view-btn {
  min-width: 120px;
}

.proof-modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 1000;
}

.proof-modal.active {
  display: block;
}

.proof-modal-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(5, 5, 6, 0.78);
  backdrop-filter: blur(8px);
}

.proof-modal-dialog {
  position: relative;
  width: min(1040px, calc(100vw - 32px));
  max-height: calc(100vh - 28px);
  overflow: auto;
  margin: 14px auto;
  padding: 24px;
  border-radius: 30px;
  border: 1px solid rgba(196, 161, 90, 0.18);
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.08), transparent 38%),
    linear-gradient(180deg, rgba(20, 18, 17, 0.985), rgba(12, 11, 10, 0.985));
}

.proof-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 18px;
}

.proof-modal-head-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.proof-open-original-btn {
  min-width: 148px;
}

.proof-modal-head h3 {
  margin: 6px 0 4px;
}

.proof-modal-head span {
  display: block;
  color: rgba(233, 224, 205, 0.70);
  max-width: 32rem;
  line-height: 1.32;
}

.proof-modal-body {
  display: grid;
  grid-template-columns: 1.4fr 0.9fr;
  gap: 20px;
  align-items: start;
}

.proof-preview-shell {
  min-height: 0;
  padding: 12px;
  border-radius: 28px;
  overflow: hidden;
  border: 1px solid rgba(196, 161, 90, 0.16);
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.05), transparent 42%),
    linear-gradient(180deg, rgba(255,255,255,0.02), rgba(255,255,255,0.01));
  display: grid;
  place-items: center;
}

.proof-modal-image-link {
  display: block;
  width: 100%;
  text-decoration: none;
  cursor: zoom-in;
}

.proof-modal-image-hint {
  margin-top: 12px;
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(196, 161, 90, 0.78);
  text-align: center;
}

.proof-modal-image {
  display: block;
  width: 100%;
  height: auto;
  max-height: min(78vh, 980px);
  object-fit: contain;
  object-position: center;
  border-radius: 22px;
  border: 1px solid rgba(196, 161, 90, 0.14);
  background: linear-gradient(180deg, rgba(8, 7, 6, 0.96), rgba(13, 12, 11, 0.92));
  transition: transform 160ms ease, box-shadow 160ms ease, border-color 160ms ease;
}

.proof-modal-image-link:hover .proof-modal-image,
.proof-modal-image-link:focus-visible .proof-modal-image {
  transform: translateY(-1px);
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.34);
  border-color: rgba(196, 161, 90, 0.3);
}

.proof-modal-empty {
  padding: 28px;
  text-align: left;
  width: 100%;
}

.proof-empty-title {
  font-family: "Cormorant Garamond", serif;
  font-size: 28px;
  color: #f1e7d0;
  margin-bottom: 10px;
}

.proof-modal-empty p {
  color: rgba(233, 224, 205, 0.72);
  line-height: 1.6;
}

.proof-meta-grid {
  display: grid;
  gap: 14px;
  align-content: start;
}

.proof-meta-card {
  padding: 18px 18px;
  border-radius: 22px;
}

.proof-meta-card span {
  display: block;
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: rgba(196, 161, 90, 0.78);
  margin-bottom: 8px;
}

.proof-meta-card strong {
  display: block;
  color: #f1e7d0;
  font-size: 18px;
  line-height: 1.35;
}

.hidden {
  display: none !important;
}

@media (max-width: 900px) {
  .proof-modal-dialog {
    width: calc(100vw - 20px);
    max-height: calc(100vh - 12px);
    margin: 6px auto;
    padding: 18px;
    border-radius: 24px;
  }

  .proof-modal-head {
    align-items: flex-start;
  }

  .proof-modal-head-actions {
    width: 100%;
    justify-content: flex-start;
  }

  .proof-modal-body {
    grid-template-columns: 1fr;
  }

  .proof-preview-shell {
    min-height: 0;
    padding: 10px;
  }

  .proof-modal-image {
    max-height: 52vh;
    border-radius: 18px;
  }

  .admin-proof-preview img {
    max-height: 320px;
  }
}


.buy-credit-history-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(196, 161, 90, 0.14);
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.06), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
}
.buy-credit-history-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.buy-credit-history-code {
  display: block;
  color: var(--gold-soft);
  margin-bottom: 4px;
}
.buy-credit-history-title {
  display: block;
  color: var(--text);
  font-size: 22px;
  line-height: 1.12;
  font-family: "Cormorant Garamond", serif;
}
.buy-credit-history-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.buy-credit-history-meta-card {
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 18px;
  padding: 14px 15px;
  background: rgba(255,255,255,0.02);
}
.buy-credit-history-meta-card span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(196, 161, 90, 0.75);
  margin-bottom: 8px;
}
.buy-credit-history-meta-card strong {
  display: block;
  color: var(--text);
  font-size: 17px;
  line-height: 1.35;
  margin: 0;
}
.buy-credit-history-proof {
  display: grid;
  gap: 12px;
}
.buy-credit-history-proof-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.buy-credit-history-proof-head span {
  color: rgba(196, 161, 90, 0.8);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.buy-credit-history-proof-head a {
  color: var(--gold-soft);
  text-decoration: none;
  font-size: 13px;
  border-bottom: 1px solid rgba(215,176,108,0.20);
  padding-bottom: 2px;
}
.buy-credit-history-proof img {
  width: 100%;
  max-height: 220px;
  object-fit: contain;
  border-radius: 18px;
  border: 1px solid rgba(196, 161, 90, 0.12);
  background: linear-gradient(180deg, rgba(8,7,6,0.96), rgba(13,12,11,0.92));
}
.buy-credit-history-inline-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.buy-credit-note {
  margin-top: 0;
}
.buy-credit-status-chip {
  min-width: 118px;
  padding: 9px 16px;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.025);
}
.buy-credit-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  display: inline-block;
  background: currentColor;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.03);
}
.buy-credit-history-note-card {
  display: grid;
  gap: 8px;
  padding: 14px 15px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.018);
}
.buy-credit-history-note-card span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(196, 161, 90, 0.75);
}
.buy-credit-history-note-card strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  line-height: 1.6;
  font-weight: 500;
}
.status-badge.status-pending.buy-credit-status-chip {
  color: #e9d7ad;
  border-color: rgba(215,176,108,0.26);
  background: linear-gradient(180deg, rgba(215,176,108,0.10), rgba(255,255,255,0.02));
}
.status-badge.status-approved.buy-credit-status-chip,
.status-badge.status-completed.buy-credit-status-chip {
  color: #d8f0c4;
  border-color: rgba(185,217,160,0.26);
  background: linear-gradient(180deg, rgba(185,217,160,0.10), rgba(255,255,255,0.02));
}
.status-badge.status-rejected.buy-credit-status-chip,
.status-badge.status-reversed.buy-credit-status-chip {
  color: #ffc8c0;
  border-color: rgba(214,108,92,0.26);
  background: linear-gradient(180deg, rgba(214,108,92,0.10), rgba(255,255,255,0.02));
}
.status-badge.status-proof_submitted.buy-credit-status-chip,
.status-badge.status-in_progress.buy-credit-status-chip {
  color: #ddd2ff;
  border-color: rgba(176,153,255,0.24);
  background: linear-gradient(180deg, rgba(176,153,255,0.10), rgba(255,255,255,0.02));
}
.status-badge.is-soft {
  min-width: 104px;
  background: rgba(255,255,255,0.02);
}
.message-success-card {
  margin-top: 16px;
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid rgba(185, 217, 160, 0.2);
  background: linear-gradient(180deg, rgba(185, 217, 160, 0.06), rgba(255,255,255,0.02));
  color: var(--text);
  text-align: left;
}
.message-success-card strong {
  display: block;
  color: #dbe8cf;
  margin-bottom: 6px;
}
.message-success-card span {
  display: block;
  color: var(--muted);
  line-height: 1.55;
  font-size: 13px;
}
@media (max-width: 720px) {
  .buy-credit-history-meta {
    grid-template-columns: 1fr;
  }
  .buy-credit-history-top {
    flex-direction: column;
    align-items: flex-start;
  }
}


.order-history-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(196, 161, 90, 0.14);
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.06), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
}
.order-history-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.order-history-code {
  display: block;
  color: var(--gold-soft);
  margin-bottom: 4px;
}
.order-history-title {
  display: block;
  color: var(--text);
  font-size: 22px;
  line-height: 1.12;
  font-family: "Cormorant Garamond", serif;
}
.order-history-inline-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.order-history-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.order-history-meta-card,
.order-history-target-card,
.order-history-note-card {
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 18px;
  padding: 14px 15px;
  background: rgba(255,255,255,0.02);
}
.order-history-meta-card span,
.order-history-target-head span,
.order-history-note-card span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(196, 161, 90, 0.75);
  margin-bottom: 8px;
}
.order-history-meta-card strong,
.order-history-target-card strong,
.order-history-note-card strong {
  display: block;
  color: var(--text);
  font-size: 17px;
  line-height: 1.45;
  margin: 0;
  word-break: break-word;
}
.order-history-target-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.order-history-target-head a {
  color: var(--gold-soft);
  text-decoration: none;
  font-size: 13px;
  border-bottom: 1px solid rgba(215,176,108,0.20);
  padding-bottom: 2px;
}
.order-status-chip {
  min-width: 126px;
  padding: 9px 16px;
  gap: 8px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.14em;
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.025);
}
.order-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  display: inline-block;
  background: currentColor;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.03);
}
.status-badge.status-pending.order-status-chip {
  color: #e9d7ad;
  border-color: rgba(215,176,108,0.26);
  background: linear-gradient(180deg, rgba(215,176,108,0.10), rgba(255,255,255,0.02));
}
.status-badge.status-approved.order-status-chip,
.status-badge.status-proof_submitted.order-status-chip,
.status-badge.status-in_progress.order-status-chip {
  color: #ddd2ff;
  border-color: rgba(176,153,255,0.24);
  background: linear-gradient(180deg, rgba(176,153,255,0.10), rgba(255,255,255,0.02));
}
.status-badge.status-completed.order-status-chip {
  color: #d8f0c4;
  border-color: rgba(185,217,160,0.26);
  background: linear-gradient(180deg, rgba(185,217,160,0.10), rgba(255,255,255,0.02));
}
.status-badge.status-rejected.order-status-chip,
.status-badge.status-reversed.order-status-chip {
  color: #ffc8c0;
  border-color: rgba(214,108,92,0.26);
  background: linear-gradient(180deg, rgba(214,108,92,0.10), rgba(255,255,255,0.02));
}

@media (max-width: 720px) {
  .order-history-meta {
    grid-template-columns: 1fr;
  }
  .order-history-top {
    flex-direction: column;
    align-items: flex-start;
  }
  .order-history-target-head {
    flex-direction: column;
    align-items: flex-start;
  }
}


.ledger-transaction-card {
  display: grid;
  gap: 12px;
  padding: 16px;
  border-radius: 22px;
  border: 1px solid rgba(196, 161, 90, 0.14);
  background:
    radial-gradient(circle at top left, rgba(196, 161, 90, 0.06), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
}

.ledger-transaction-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}

.ledger-transaction-title {
  display: block;
  color: var(--text);
  font-size: 20px;
  line-height: 1.12;
  font-family: "Cormorant Garamond", serif;
}

.ledger-transaction-date {
  display: block;
  margin-top: 4px;
  color: rgba(233, 224, 205, 0.58);
  font-size: 12px;
  line-height: 1.45;
}

.ledger-transaction-delta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 104px;
  padding: 10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,0.08);
  color: var(--gold-soft);
  background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.015));
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.12em;
}

.ledger-transaction-delta.is-positive {
  color: #dfe7c9;
  border-color: rgba(181, 205, 140, 0.22);
}

.ledger-transaction-delta.is-negative {
  color: #f0dcc0;
  border-color: rgba(215, 176, 108, 0.20);
}

.ledger-transaction-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.ledger-transaction-meta-card {
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 18px;
  padding: 14px 15px;
  background: rgba(255,255,255,0.02);
}

.ledger-transaction-meta-card span {
  display: block;
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: rgba(196, 161, 90, 0.75);
  margin-bottom: 8px;
}

.ledger-transaction-meta-card strong {
  display: block;
  color: var(--text);
  font-size: 17px;
  line-height: 1.45;
}

.ledger-transaction-note {
  border: 1px solid rgba(255,255,255,0.07);
  border-radius: 18px;
  padding: 12px 15px;
  background: rgba(255,255,255,0.02);
  color: rgba(233, 224, 205, 0.74);
  line-height: 1.5;
  font-size: 14px;
}

@media (max-width: 900px) {
  .ledger-transaction-grid {
    grid-template-columns: 1fr;
  }
  .ledger-transaction-top {
    flex-direction: column;
    align-items: flex-start;
  }
}


.admin-buy-credit-status-chip {
  min-width: 118px;
  padding: 10px 14px;
  letter-spacing: 0.14em;
  font-size: 11px;
}
.status-badge.status-pending.admin-buy-credit-status-chip {
  color: #ead7af;
  border-color: rgba(215,176,108,0.26);
  background: linear-gradient(180deg, rgba(215,176,108,0.12), rgba(255,255,255,0.02));
}
.status-badge.status-approved.admin-buy-credit-status-chip {
  color: #d8f0c4;
  border-color: rgba(185,217,160,0.26);
  background: linear-gradient(180deg, rgba(185,217,160,0.12), rgba(255,255,255,0.02));
}
.status-badge.status-rejected.admin-buy-credit-status-chip,
.status-badge.status-reversed.admin-buy-credit-status-chip {
  color: #ffc8c0;
  border-color: rgba(214,108,92,0.26);
  background: linear-gradient(180deg, rgba(214,108,92,0.12), rgba(255,255,255,0.02));
}
.status-badge.status-proof_submitted.admin-buy-credit-status-chip,
.status-badge.status-in_progress.admin-buy-credit-status-chip {
  color: #ddd2ff;
  border-color: rgba(176,153,255,0.24);
  background: linear-gradient(180deg, rgba(176,153,255,0.12), rgba(255,255,255,0.02));
}
.admin-request-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.admin-request-head-copy {
  display: grid;
  gap: 6px;
}
.admin-request-code {
  display: block;
  margin: 0;
  color: var(--gold-soft);
}
.admin-request-title {
  margin: 0;
  font-family: 'Cormorant Garamond', serif;
  font-size: 38px;
  line-height: 0.98;
  font-weight: 600;
  color: var(--text);
}
.admin-request-member {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.55;
}
.admin-request-meta-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.admin-request-meta-card {
  border: 1px solid var(--line-soft);
  border-radius: 18px;
  padding: 16px 18px;
  background: rgba(255,255,255,0.018);
}
.admin-request-meta-card span {
  display: block;
  margin-bottom: 8px;
  color: var(--gold);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.admin-request-meta-card strong {
  display: block;
  margin: 0;
  color: var(--text);
  font-size: 16px;
  line-height: 1.45;
  font-weight: 600;
}
.admin-request-proof-block {
  display: grid;
  gap: 12px;
  padding: 16px 18px 18px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.015);
  margin-bottom: 14px;
}
.admin-request-proof-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.admin-request-proof-head .eyebrow {
  margin-bottom: 6px;
}
.admin-request-proof-head small {
  display: block;
  color: var(--muted);
  line-height: 1.55;
}
.admin-request-review-btn {
  white-space: nowrap;
}
.admin-request-note-card {
  display: grid;
  gap: 8px;
  padding: 14px 16px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,0.07);
  background: rgba(255,255,255,0.018);
  margin-top: 12px;
}
.admin-request-note-card.is-soft {
  background: rgba(255,255,255,0.012);
}
.admin-request-note-card span {
  display: block;
  color: rgba(196, 161, 90, 0.75);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.admin-request-note-card strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  line-height: 1.6;
  font-weight: 500;
}
.admin-request-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 14px;
  flex-wrap: wrap;
}
.admin-request-actions.is-readonly {
  justify-content: space-between;
}
@media (max-width: 720px) {
  .admin-request-head,
  .admin-request-proof-head {
    grid-template-columns: 1fr;
    display: grid;
  }
  .admin-request-title {
    font-size: 28px;
    line-height: 1.04;
  }
  .admin-request-meta-grid {
    grid-template-columns: 1fr;
  }
  .admin-request-actions.is-readonly {
    justify-content: flex-start;
  }
}


#adminBuyCreditForm .admin-review-summary-field > span,
#adminBuyCreditForm .admin-review-status-field > span {
  display: block;
  color: rgba(196, 161, 90, 0.82);
  font-size: 12px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

#adminBuyCreditForm .admin-review-summary-field input,
#adminBuyCreditForm .admin-review-summary-field select {
  min-height: 70px;
  border-radius: 22px;
  font-size: 18px;
  line-height: 1.35;
  font-weight: 600;
  color: var(--text);
  background: rgba(255,255,255,0.028);
  border: 1px solid rgba(255,255,255,0.08);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}

#adminBuyCreditForm .admin-review-summary-field select {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.admin-review-status-field {
  align-content: start;
}

.admin-form-status-display {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-width: 128px;
  margin-top: 2px;
}

.admin-form-hidden-input {
  display: none !important;
}


.admin-buy-credit-readonly {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 2px;
  flex-wrap: wrap;
}

#adminBuyCreditForm.is-readonly .admin-review-summary-field input,
#adminBuyCreditForm.is-readonly .admin-review-summary-field:not(:first-child) input,
#adminBuyCreditForm.is-readonly .admin-review-summary-field:not(:first-child) select,
#adminBuyCreditForm.is-readonly #adminBuyCreditNote {
  opacity: 0.68;
}

@media (max-width: 720px) {
  #adminBuyCreditForm .admin-review-summary-field input,
  #adminBuyCreditForm .admin-review-summary-field select {
    min-height: 64px;
    font-size: 16px;
  }
}


.admin-empty-state-card {
  border: 1px solid var(--line-soft);
  border-radius: 22px;
  padding: 20px 22px;
  background: linear-gradient(180deg, rgba(255,255,255,0.025), rgba(255,255,255,0.01));
  display: grid;
  gap: 10px;
  margin-bottom: 16px;
}
.admin-empty-state-card h4 {
  margin: 0;
  font-size: 34px;
  line-height: 1;
  color: var(--gold-soft);
}
.admin-empty-state-card p {
  margin: 0;
  color: var(--muted);
  line-height: 1.65;
  max-width: 56ch;
}
.admin-order-target-card,
.admin-order-list-target {
  margin-top: 12px;
}
.admin-order-list-target strong,
.admin-order-target-card strong {
  font-size: 15px;
}


.payment-settings-card {
  border: 1px solid rgba(206, 165, 92, 0.18);
  border-radius: 24px;
  padding: 18px;
  background: rgba(17, 12, 8, 0.62);
  display: grid;
  gap: 14px;
}

.payment-settings-card--admin {
  background: rgba(17, 12, 8, 0.52);
}

.payment-settings-head strong {
  display: block;
  font-size: 1rem;
}

.payment-channels-copy {
  margin: 0;
  color: rgba(236, 226, 213, 0.8);
  line-height: 1.6;
}

.payment-channels-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px;
}

.payment-channel-card {
  border: 1px solid rgba(206, 165, 92, 0.14);
  border-radius: 20px;
  padding: 16px;
  background: rgba(8, 8, 10, 0.62);
  display: grid;
  gap: 12px;
}

.payment-channel-card.is-selected {
  border-color: rgba(231, 203, 150, 0.75);
  box-shadow: 0 0 0 1px rgba(231, 203, 150, 0.16) inset;
}

.payment-channel-top {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}

.payment-channel-name {
  display: block;
  font-size: 1.05rem;
  font-weight: 700;
}

.payment-channel-meta {
  margin-top: 6px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  color: rgba(236, 226, 213, 0.76);
  font-size: 0.9rem;
}

.payment-channel-number {
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  word-break: break-all;
}

.payment-copy-btn {
  justify-self: start;
}


.payment-channel-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.payment-channel-tab {
  border: 1px solid rgba(206, 165, 92, 0.18);
  background: rgba(10, 10, 12, 0.7);
  color: rgba(236, 226, 213, 0.86);
  border-radius: 999px;
  padding: 10px 16px;
  font: inherit;
  font-weight: 600;
}

.payment-channel-tab.is-active {
  border-color: rgba(231, 203, 150, 0.75);
  box-shadow: 0 0 0 1px rgba(231, 203, 150, 0.14) inset;
  color: rgba(255, 247, 231, 0.96);
}

.payment-channel-card--focus {
  grid-template-columns: 1fr;
}

.payment-channel-details-list {
  border-top: 1px solid rgba(206, 165, 92, 0.12);
  padding-top: 12px;
}

.payment-channel-details-list summary {
  cursor: pointer;
  color: rgba(236, 226, 213, 0.78);
  list-style: none;
}

.payment-channel-details-list summary::-webkit-details-marker {
  display: none;
}

.payment-channel-details-list summary::after {
  content: '▾';
  margin-left: 8px;
}

.payment-channel-details-list[open] summary::after {
  content: '▴';
}

.payment-channel-details-list[open] .payment-channels-grid--compact {
  margin-top: 12px;
}

.payment-channels-grid--compact {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}


.payment-settings-list .list-card {
  display: grid;
  gap: 8px;
}

.payment-settings-actions {
  justify-content: space-between;
  align-items: center;
}

.payment-settings-grid {
  margin-top: 18px;
}

#paymentSettingsForm .primary-btn {
  justify-self: end;
}

@media (max-width: 720px) {
  #paymentSettingsForm .primary-btn {
    width: 100%;
    justify-self: stretch;
  }
  .payment-settings-actions {
    flex-direction: column;
    align-items: stretch;
  }
}

.admin-alert-grid { grid-template-columns: 1.2fr 1fr; }
.admin-notification-grid { grid-template-columns: repeat(3, 1fr); }

.notification-mini-card {
  min-height: 172px;
  align-content: start;
}
.notification-mini-card strong {
  color: var(--gold-soft);
  font-family: 'Inter', sans-serif;
  font-weight: 700;
  font-size: 40px;
  line-height: 1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
  font-feature-settings: "tnum" 1, "lnum" 1;
}
.notification-mini-card small {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}
.activity-card {
  display: grid;
  gap: 10px;
}
.activity-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.activity-type-pill {
  display: inline-flex;
  align-items: center;
  border: 1px solid var(--line-soft);
  border-radius: 999px;
  padding: 5px 10px;
  font-size: 11px;
  color: var(--muted);
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.activity-time {
  color: var(--muted);
  font-size: 12px;
}
.activity-title {
  color: var(--gold-soft);
  font-size: 15px;
  line-height: 1.45;
}
.activity-meta {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.5;
}
@media (max-width: 980px) {
  .admin-alert-grid,
  .admin-notification-grid { grid-template-columns: 1fr; }
}


/* =========================================================
   VOSVEN V29 — WORLD-CLASS PREMIUM UI OVERRIDE
   Quiet luxury, cinematic depth, higher-end hierarchy
   ========================================================= */

body.theme-v29 {
  --bg: #040404;
  --panel: rgba(13, 13, 16, 0.88);
  --soft: rgba(17, 17, 20, 0.88);
  --line: rgba(214, 174, 102, 0.24);
  --line-soft: rgba(255, 255, 255, 0.06);
  --gold: #d4af6e;
  --gold-soft: #f2e5c4;
  --ivory: #f6efe3;
  --text: #f5f0e7;
  --muted: #b5ada0;
  --shadow-xl: 0 30px 90px rgba(0, 0, 0, 0.55);
  --shadow-lg: 0 18px 48px rgba(0, 0, 0, 0.34);
  --shadow-md: 0 12px 28px rgba(0, 0, 0, 0.22);
  background:
    radial-gradient(circle at 12% 12%, rgba(193, 144, 56, 0.16), transparent 24%),
    radial-gradient(circle at 88% 12%, rgba(255, 255, 255, 0.045), transparent 18%),
    radial-gradient(circle at 50% 120%, rgba(182, 133, 48, 0.12), transparent 30%),
    linear-gradient(180deg, #060607 0%, #040404 100%);
  min-height: 100vh;
  position: relative;
  overflow-x: hidden;
}

body.theme-v29::before,
body.theme-v29::after {
  content: "";
  position: fixed;
  inset: auto;
  width: 44vw;
  height: 44vw;
  pointer-events: none;
  z-index: 0;
  filter: blur(80px);
  opacity: 0.34;
}
body.theme-v29::before {
  top: -12vw;
  left: -10vw;
  background: radial-gradient(circle, rgba(191, 140, 51, 0.16), transparent 64%);
}
body.theme-v29::after {
  right: -10vw;
  bottom: -16vw;
  background: radial-gradient(circle, rgba(255, 255, 255, 0.05), transparent 64%);
}

body.theme-v29 .app-shell,
body.theme-v29 .proof-modal {
  position: relative;
  z-index: 1;
}

body.theme-v29 .app-shell {
  grid-template-columns: 292px 1fr;
}

body.theme-v29 .sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 30px 24px 28px;
  background:
    linear-gradient(180deg, rgba(12, 12, 14, 0.98) 0%, rgba(7, 7, 9, 0.92) 100%);
  border-right: 1px solid rgba(214, 174, 102, 0.16);
  box-shadow: inset -1px 0 0 rgba(255,255,255,0.03);
  gap: 22px;
}

body.theme-v29 .brand-mark {
  width: 76px;
  height: 76px;
  border-radius: 26px;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.055), rgba(255,255,255,0.018)),
    rgba(12,12,14,0.88);
  border: 1px solid rgba(214,174,102,0.24);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 18px 30px rgba(0,0,0,0.26);
}

body.theme-v29 .brand-logo {
  width: 46px;
  height: 46px;
  filter: drop-shadow(0 8px 20px rgba(212,175,110,0.22));
}

body.theme-v29 .sidebar h1 {
  font-size: clamp(30px, 2.3vw, 36px);
  line-height: 0.94;
  letter-spacing: 0.01em;
}

body.theme-v29 .eyebrow {
  color: #d7bb86;
  font-size: 11px;
  letter-spacing: 0.24em;
  margin-bottom: 10px;
}

body.theme-v29 .user-meta {
  padding: 18px 18px 16px;
  border-radius: 22px;
  border: 1px solid rgba(214,174,102,0.18);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.014));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.05),
    0 14px 28px rgba(0,0,0,0.18);
  line-height: 1.72;
}

body.theme-v29 .main-content {
  padding: 32px 34px 42px;
  max-width: 1720px;
}

body.theme-v29 #dashboardView {
  display: grid;
  gap: 22px;
}

body.theme-v29 .panel,
body.theme-v29 .list-card,
body.theme-v29 .expiry-lot-card,
body.theme-v29 .buy-credit-history-card,
body.theme-v29 .order-history-card,
body.theme-v29 .ledger-transaction-card,
body.theme-v29 .proof-meta-card,
body.theme-v29 .mini-card,
body.theme-v29 .mini-stat,
body.theme-v29 .admin-request-meta-card,
body.theme-v29 .admin-request-note-card,
body.theme-v29 .admin-empty-state-card,
body.theme-v29 .buy-credit-history-meta-card,
body.theme-v29 .buy-credit-history-note-card,
body.theme-v29 .order-history-meta-card,
body.theme-v29 .order-history-target-card,
body.theme-v29 .order-history-note-card,
body.theme-v29 .ledger-transaction-meta-card,
body.theme-v29 .payment-channel-card {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04) 0%, rgba(255,255,255,0.014) 100%),
    rgba(10,10,12,0.86);
  border: 1px solid rgba(214,174,102,0.16);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    var(--shadow-lg);
  backdrop-filter: blur(16px);
}

body.theme-v29 .panel {
  padding: 28px;
  border-radius: 30px;
  position: relative;
  overflow: hidden;
}
body.theme-v29 .panel::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.05), transparent 24%, transparent 76%, rgba(212,175,110,0.04));
  pointer-events: none;
}
body.theme-v29 .panel > * {
  position: relative;
  z-index: 1;
}

body.theme-v29 .top-grid {
  grid-template-columns: 1.9fr 1fr 1fr 1fr;
  gap: 20px;
}

body.theme-v29 .hero-card {
  min-height: 224px;
  padding: 34px;
  justify-content: flex-end;
  background:
    radial-gradient(circle at top right, rgba(212,175,110,0.16), transparent 28%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.014)),
    rgba(10,10,12,0.9);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 24px 60px rgba(0,0,0,0.42);
}
body.theme-v29 .hero-card::after {
  content: "";
  position: absolute;
  top: 24px;
  right: 24px;
  width: 130px;
  height: 130px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(212,175,110,0.18), transparent 68%);
  filter: blur(8px);
  opacity: 0.9;
}
body.theme-v29 .balance-value {
  font-size: clamp(42px, 4vw, 66px);
  line-height: 0.98;
  letter-spacing: -0.03em;
  color: var(--ivory);
  margin-bottom: 12px;
}
body.theme-v29 .muted {
  color: rgba(243, 235, 224, 0.72);
}

body.theme-v29 .stat-card {
  min-height: 224px;
  padding: 28px;
  justify-content: space-between;
  display: flex;
  flex-direction: column;
}
body.theme-v29 .stat-value,
body.theme-v29 .mini-card strong,
body.theme-v29 .mini-stat strong {
  font-size: clamp(28px, 2.1vw, 40px);
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--ivory);
}

body.theme-v29 .panel-header {
  align-items: end;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(214,174,102,0.11);
}
body.theme-v29 .panel-header h3 {
  font-size: clamp(28px, 2vw, 36px);
  line-height: 0.98;
}
body.theme-v29 .subsection-header {
  margin: 26px 0 14px;
  padding-top: 12px;
  border-top: 1px solid rgba(214,174,102,0.09);
}
body.theme-v29 .subsection-header h4 {
  font-size: clamp(24px, 1.7vw, 30px);
  line-height: 1;
}

body.theme-v29 .content-grid,
body.theme-v29 .admin-grid,
body.theme-v29 .feature-grid,
body.theme-v29 .bottom-grid,
body.theme-v29 .admin-core-grid,
body.theme-v29 .admin-flow-grid,
body.theme-v29 .admin-alert-grid,
body.theme-v29 .expiry-grid {
  gap: 20px;
}

body.theme-v29 .feature-grid { grid-template-columns: 1.16fr 0.84fr; }
body.theme-v29 .bottom-grid { grid-template-columns: 1.04fr 0.96fr; }
body.theme-v29 .admin-alert-grid { grid-template-columns: 1fr 1fr 1fr; }

body.theme-v29 .admin-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
body.theme-v29 .mini-card,
body.theme-v29 .mini-stat {
  padding: 20px;
  border-radius: 22px;
}
body.theme-v29 .mini-card span,
body.theme-v29 .mini-stat small {
  color: rgba(245,240,231,0.64);
}

body.theme-v29 .list-stack {
  gap: 16px;
}
body.theme-v29 .list-card,
body.theme-v29 .buy-credit-history-card,
body.theme-v29 .order-history-card,
body.theme-v29 .ledger-transaction-card,
body.theme-v29 .admin-empty-state-card {
  padding: 20px;
  border-radius: 24px;
}
body.theme-v29 .inline-pill,
body.theme-v29 .status-pill {
  border-radius: 999px;
  border: 1px solid rgba(214,174,102,0.14);
  background: rgba(255,255,255,0.03);
  color: rgba(245,240,231,0.76);
  padding: 8px 12px;
}

body.theme-v29 .ghost-btn,
body.theme-v29 .primary-btn,
body.theme-v29 .secondary-btn,
body.theme-v29 .text-btn,
body.theme-v29 .proof-view-btn,
body.theme-v29 .filter-tab,
body.theme-v29 .auth-tab {
  min-height: 48px;
  border-radius: 16px;
  border: 1px solid rgba(214,174,102,0.18);
  font-weight: 600;
  letter-spacing: 0.01em;
  transition:
    transform .18s ease,
    box-shadow .22s ease,
    border-color .22s ease,
    background .22s ease,
    color .22s ease;
}

body.theme-v29 .primary-btn {
  background:
    linear-gradient(180deg, rgba(220,183,115,0.24), rgba(220,183,115,0.10)),
    rgba(31,25,16,0.86);
  color: var(--ivory);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 12px 28px rgba(0,0,0,0.22);
}
body.theme-v29 .ghost-btn,
body.theme-v29 .secondary-btn,
body.theme-v29 .text-btn,
body.theme-v29 .filter-tab,
body.theme-v29 .auth-tab,
body.theme-v29 .proof-view-btn {
  background: rgba(255,255,255,0.02);
  color: var(--text);
}
body.theme-v29 .primary-btn:hover,
body.theme-v29 .ghost-btn:hover,
body.theme-v29 .secondary-btn:hover,
body.theme-v29 .text-btn:hover,
body.theme-v29 .filter-tab:hover,
body.theme-v29 .auth-tab:hover,
body.theme-v29 .proof-view-btn:hover,
body.theme-v29 .package-card:hover {
  transform: translateY(-2px);
  border-color: rgba(214,174,102,0.34);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    0 16px 36px rgba(0,0,0,0.28);
}

body.theme-v29 .auth-panel {
  max-width: 680px;
  margin: 5vh auto 4vh;
  padding: 42px 42px 36px;
  border-radius: 34px;
  background:
    radial-gradient(circle at top, rgba(212,175,110,0.11), transparent 38%),
    linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.016)),
    rgba(9,9,11,0.88);
  border: 1px solid rgba(214,174,102,0.18);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 32px 90px rgba(0,0,0,0.44);
}
body.theme-v29 .auth-logo {
  width: 92px;
  height: 92px;
}
body.theme-v29 .header-stack h2 {
  font-size: clamp(38px, 5vw, 62px);
  letter-spacing: -0.02em;
}
body.theme-v29 .auth-switch {
  padding: 6px;
  border-radius: 18px;
  border: 1px solid rgba(214,174,102,0.13);
  background: rgba(255,255,255,0.02);
}
body.theme-v29 .auth-tab.is-active,
body.theme-v29 .filter-tab.is-active {
  background:
    linear-gradient(180deg, rgba(214,174,102,0.22), rgba(214,174,102,0.10)),
    rgba(32,26,18,0.9);
  color: var(--ivory);
  border-color: rgba(214,174,102,0.26);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.06);
}

body.theme-v29 label {
  gap: 10px;
  color: rgba(245,240,231,0.72);
  font-size: 13px;
}
body.theme-v29 label > span {
  letter-spacing: 0.03em;
}
body.theme-v29 input,
body.theme-v29 select,
body.theme-v29 textarea {
  background:
    linear-gradient(180deg, rgba(255,255,255,0.035), rgba(255,255,255,0.012)),
    rgba(10,10,12,0.94);
  border: 1px solid rgba(214,174,102,0.13);
  border-radius: 18px;
  padding: 16px 18px;
  color: var(--ivory);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.03);
}
body.theme-v29 input:focus,
body.theme-v29 select:focus,
body.theme-v29 textarea:focus {
  outline: none;
  border-color: rgba(214,174,102,0.32);
  box-shadow:
    0 0 0 4px rgba(214,174,102,0.08),
    inset 0 1px 0 rgba(255,255,255,0.04);
}
body.theme-v29 input[type="file"] {
  padding: 14px;
}

body.theme-v29 .package-grid {
  gap: 14px;
}
body.theme-v29 .package-card {
  min-height: 136px;
  padding: 18px 18px 16px;
  border-radius: 24px;
  justify-content: space-between;
  background:
    linear-gradient(180deg, rgba(255,255,255,0.04), rgba(255,255,255,0.016)),
    rgba(10,10,12,0.82);
  border: 1px solid rgba(214,174,102,0.14);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.05),
    0 10px 26px rgba(0,0,0,0.18);
}
body.theme-v29 .package-card strong {
  font-size: 28px;
  color: var(--ivory);
}
body.theme-v29 .package-name,
body.theme-v29 .package-card small {
  color: rgba(245,240,231,0.70);
}
body.theme-v29 .package-card.is-selected {
  border-color: rgba(214,174,102,0.34);
  background:
    radial-gradient(circle at top right, rgba(214,174,102,0.14), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,0.05), rgba(255,255,255,0.018)),
    rgba(15,12,9,0.92);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 18px 42px rgba(0,0,0,0.26);
}

body.theme-v29 .status-badge {
  border-radius: 999px;
  padding: 9px 14px;
  font-weight: 600;
  letter-spacing: 0.01em;
  backdrop-filter: blur(8px);
}
body.theme-v29 .status-badge.is-soft {
  background: rgba(255,255,255,0.04);
}
body.theme-v29 .status-pending { color: #f0d89a; }
body.theme-v29 .status-approved,
body.theme-v29 .status-in_progress { color: #c8dfb2; }
body.theme-v29 .status-completed { color: #d9e7ff; }
body.theme-v29 .status-proof_submitted { color: #e1d4ff; }
body.theme-v29 .status-rejected,
body.theme-v29 .status-reversed { color: #efb1b1; }

body.theme-v29 .buy-credit-history-top,
body.theme-v29 .order-history-top,
body.theme-v29 .ledger-transaction-top,
body.theme-v29 .admin-request-head,
body.theme-v29 .card-row {
  align-items: start;
  gap: 12px;
}
body.theme-v29 .buy-credit-history-code,
body.theme-v29 .order-history-code,
body.theme-v29 .admin-request-code {
  font-size: 16px;
  color: var(--ivory);
}
body.theme-v29 .buy-credit-history-title,
body.theme-v29 .order-history-title,
body.theme-v29 .admin-request-title,
body.theme-v29 .ledger-transaction-title {
  color: rgba(245,240,231,0.72);
}
body.theme-v29 .buy-credit-history-meta,
body.theme-v29 .order-history-meta,
body.theme-v29 .ledger-transaction-grid,
body.theme-v29 .admin-request-meta-grid,
body.theme-v29 .proof-meta-grid,
body.theme-v29 .expiry-summary-grid {
  gap: 14px;
}
body.theme-v29 .buy-credit-history-meta-card,
body.theme-v29 .order-history-meta-card,
body.theme-v29 .ledger-transaction-meta-card,
body.theme-v29 .admin-request-meta-card,
body.theme-v29 .proof-meta-card {
  border-radius: 20px;
  padding: 16px;
}
body.theme-v29 .buy-credit-history-meta-card span,
body.theme-v29 .order-history-meta-card span,
body.theme-v29 .order-history-target-head span,
body.theme-v29 .order-history-note-card span,
body.theme-v29 .ledger-transaction-meta-card span,
body.theme-v29 .admin-request-meta-card span,
body.theme-v29 .proof-meta-card span {
  color: rgba(245,240,231,0.52);
  font-size: 12px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
body.theme-v29 .buy-credit-history-meta-card strong,
body.theme-v29 .order-history-meta-card strong,
body.theme-v29 .order-history-target-card strong,
body.theme-v29 .order-history-note-card strong,
body.theme-v29 .ledger-transaction-meta-card strong,
body.theme-v29 .admin-request-meta-card strong,
body.theme-v29 .proof-meta-card strong {
  color: var(--ivory);
  font-size: 15px;
}
body.theme-v29 .proof-preview,
body.theme-v29 .buy-credit-history-proof,
body.theme-v29 .admin-request-proof-block {
  border-radius: 22px;
  border: 1px solid rgba(214,174,102,0.14);
  background: rgba(255,255,255,0.02);
}
body.theme-v29 .proof-preview img,
body.theme-v29 .buy-credit-history-proof img,
body.theme-v29 .admin-proof-preview img {
  border-radius: 18px;
}
body.theme-v29 .proof-preview-head,
body.theme-v29 .buy-credit-history-proof-head,
body.theme-v29 .admin-request-proof-head {
  padding: 0 2px;
}
body.theme-v29 .helper-note,
body.theme-v29 .proof-upload-tips span,
body.theme-v29 .buy-credit-note,
body.theme-v29 .ledger-transaction-date {
  color: rgba(245,240,231,0.62);
}

body.theme-v29 .message {
  margin-top: 18px;
  min-height: 26px;
  color: rgba(245,240,231,0.72);
  text-align: left;
}
body.theme-v29 .message-success-card {
  border-radius: 22px;
  border-color: rgba(151, 214, 156, 0.18);
  background: linear-gradient(180deg, rgba(151,214,156,0.10), rgba(255,255,255,0.015));
}

body.theme-v29 .proof-modal-dialog {
  border-radius: 30px;
  border: 1px solid rgba(214,174,102,0.16);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.045), rgba(255,255,255,0.014)),
    rgba(9,9,11,0.96);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.06),
    0 30px 90px rgba(0,0,0,0.48);
}

body.theme-v29 .proof-modal-image {
  border-radius: 22px;
}
body.theme-v29 .proof-modal-backdrop {
  backdrop-filter: blur(10px);
  background: rgba(3, 3, 4, 0.72);
}

body.theme-v29 .notification-mini-card,
body.theme-v29 .mini-card.notification-mini-card {
  min-height: 160px;
  justify-content: flex-start;
  gap: 12px;
}

body.theme-v29 .danger-btn {
  color: #f0b6b6;
}

@media (max-width: 1320px) {
  body.theme-v29 .top-grid {
    grid-template-columns: 1.4fr 1fr 1fr;
  }
  body.theme-v29 .top-grid .hero-card {
    grid-column: span 3;
  }
  body.theme-v29 .feature-grid,
  body.theme-v29 .bottom-grid,
  body.theme-v29 .admin-alert-grid,
  body.theme-v29 .admin-core-grid,
  body.theme-v29 .admin-flow-grid,
  body.theme-v29 .expiry-grid {
    grid-template-columns: 1fr;
  }
  body.theme-v29 .admin-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 960px) {
  body.theme-v29 .app-shell {
    grid-template-columns: 1fr;
  }
  body.theme-v29 .sidebar {
    position: relative;
    height: auto;
    border-right: none;
    border-bottom: 1px solid rgba(214,174,102,0.12);
  }
  body.theme-v29 .main-content {
    padding: 22px 16px 34px;
  }
  body.theme-v29 .top-grid,
  body.theme-v29 .admin-grid {
    grid-template-columns: 1fr;
  }
  body.theme-v29 .top-grid .hero-card {
    grid-column: auto;
  }
  body.theme-v29 .panel,
  body.theme-v29 .auth-panel {
    padding: 22px;
    border-radius: 24px;
  }
  body.theme-v29 .balance-value {
    font-size: clamp(36px, 10vw, 48px);
  }
}


/* =========================================================
   VOSVEN B31 — BLACK VAULT REFINED PATCH
   Surgical visual refinement on top of stable production UI.
   ========================================================= */
body.theme-v31 {
  --bg: #040507;
  --panel: rgba(8, 10, 16, 0.86);
  --panel-strong: rgba(10, 12, 18, 0.94);
  --line: rgba(214, 173, 93, 0.22);
  --line-soft: rgba(214, 173, 93, 0.12);
  --gold: #c69336;
  --gold-soft: #f2dfbb;
  --text: #f6efe3;
  --muted: #b4aa99;
  background:
    radial-gradient(circle at 18% 0%, rgba(182, 136, 43, 0.12), transparent 28%),
    radial-gradient(circle at 82% 14%, rgba(49, 68, 116, 0.16), transparent 26%),
    radial-gradient(circle at 76% 76%, rgba(182, 136, 43, 0.09), transparent 24%),
    linear-gradient(180deg, #050608 0%, #030406 100%);
}

body.theme-v31::before,
body.theme-v31::after {
  content: '';
  position: fixed;
  inset: auto;
  pointer-events: none;
  z-index: 0;
  filter: blur(12px);
}
body.theme-v31::before {
  width: 38vw;
  height: 38vw;
  left: -8vw;
  top: 12vh;
  background: radial-gradient(circle, rgba(198,147,54,0.10), transparent 62%);
  opacity: 0.9;
}
body.theme-v31::after {
  width: 34vw;
  height: 34vw;
  right: -9vw;
  bottom: 6vh;
  background: radial-gradient(circle, rgba(72,95,146,0.11), transparent 60%);
  opacity: 0.75;
}

body.theme-v31 .app-shell {
  position: relative;
  z-index: 1;
  grid-template-columns: 296px minmax(0, 1fr);
  gap: 28px;
  padding: 24px;
}

body.theme-v31 .app-shell::before {
  content: '';
  position: fixed;
  inset: 0;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(255,255,255,0.015) 1px, transparent 1px),
    linear-gradient(180deg, rgba(255,255,255,0.015) 1px, transparent 1px);
  background-size: 120px 120px;
  mask-image: radial-gradient(circle at center, black 24%, transparent 78%);
  opacity: 0.12;
  z-index: -1;
}

body.theme-v31 .sidebar {
  position: sticky;
  top: 24px;
  align-self: start;
  min-height: calc(100vh - 48px);
  padding: 30px 24px 32px;
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(12,15,24,0.88), rgba(6,8,13,0.78)),
    radial-gradient(circle at top center, rgba(205,151,52,0.10), transparent 48%);
  border: 1px solid rgba(214,173,93,0.14);
  box-shadow:
    0 28px 80px rgba(0,0,0,0.45),
    inset 0 1px 0 rgba(255,255,255,0.03),
    inset 0 -24px 60px rgba(0,0,0,0.28);
  overflow: hidden;
}

body.theme-v31 .sidebar::before,
body.theme-v31 .sidebar::after,
body.theme-v31 .main-content::before,
body.theme-v31 .main-content::after,
body.theme-v31 .auth-panel::after,
body.theme-v31 .panel::before,
body.theme-v31 .panel::after,
body.theme-v31 .package-card::before,
body.theme-v31 .package-card::after,
body.theme-v31 .brand-logo::before,
body.theme-v31 .brand-logo::after {
  pointer-events: none;
}

body.theme-v31 .sidebar::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 50% 10%, rgba(212,165,76,0.18), transparent 24%),
    linear-gradient(180deg, rgba(255,255,255,0.02), transparent 22%);
  opacity: 0.7;
}
body.theme-v31 .sidebar::after {
  content: '';
  position: absolute;
  left: 22px;
  right: 22px;
  bottom: 22px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(214,173,93,0.42), transparent);
}

body.theme-v31 .brand-mark {
  gap: 18px;
}

body.theme-v31 .brand-logo {
  position: relative;
  width: 108px;
  height: 108px;
  border-radius: 30px;
  background:
    radial-gradient(circle at 50% 36%, rgba(243,218,169,0.10), transparent 30%),
    linear-gradient(180deg, rgba(13,16,24,0.96), rgba(7,9,14,0.92));
  border: 1px solid rgba(214,173,93,0.20);
  box-shadow:
    0 26px 60px rgba(0,0,0,0.38),
    inset 0 1px 0 rgba(255,255,255,0.05),
    inset 0 -18px 34px rgba(0,0,0,0.32);
}
body.theme-v31 .brand-logo::before {
  content: '';
  position: absolute;
  inset: 10px;
  border-radius: 22px;
  border: 1px solid rgba(214,173,93,0.10);
}
body.theme-v31 .brand-logo::after {
  content: '';
  position: absolute;
  inset: -18px;
  background: radial-gradient(circle, rgba(214,173,93,0.15), transparent 60%);
  opacity: 0.55;
  z-index: -1;
}
body.theme-v31 .brand-title {
  letter-spacing: 0.30em;
  font-size: 13px;
  color: rgba(242,223,187,0.92);
}
body.theme-v31 .brand-subtitle {
  color: rgba(180,170,153,0.82);
}

body.theme-v31 .main-content {
  position: relative;
  padding: 4px 0 48px;
  overflow: visible;
}
body.theme-v31 .main-content::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 220px;
  background:
    radial-gradient(circle at 22% 0%, rgba(198,147,54,0.12), transparent 36%),
    radial-gradient(circle at 78% 10%, rgba(68,87,129,0.12), transparent 34%);
  opacity: 0.9;
}
body.theme-v31 .main-content::after {
  content: '';
  position: absolute;
  top: 134px;
  left: 0;
  right: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(214,173,93,0.18), transparent);
}

body.theme-v31 .page-shell {
  gap: 22px;
}

body.theme-v31 .page-header {
  position: relative;
  padding: 10px 6px 26px;
  margin-bottom: 4px;
}
body.theme-v31 .page-title {
  font-size: clamp(48px, 5vw, 72px);
  letter-spacing: -0.035em;
  line-height: 0.92;
  text-shadow: 0 8px 32px rgba(0,0,0,0.28);
}
body.theme-v31 .eyebrow {
  color: rgba(228,196,136,0.88);
  letter-spacing: 0.34em;
  font-size: 11px;
}
body.theme-v31 .subtitle,
body.theme-v31 .section-copy,
body.theme-v31 .helper-note,
body.theme-v31 .auth-helper-text,
body.theme-v31 .muted,
body.theme-v31 .package-name,
body.theme-v31 .package-card small,
body.theme-v31 .mini-stat small,
body.theme-v31 label,
body.theme-v31 .list-card small,
body.theme-v31 .proof-upload-tips span,
body.theme-v31 .proof-label,
body.theme-v31 .expiry-lot-date,
body.theme-v31 .expiry-lot-balance {
  color: rgba(181,170,153,0.86);
}

body.theme-v31 .panel,
body.theme-v31 .auth-panel,
body.theme-v31 .list-card,
body.theme-v31 .mini-card,
body.theme-v31 .mini-stat,
body.theme-v31 .expiry-lot-card,
body.theme-v31 .package-card,
body.theme-v31 .proof-upload-tips,
body.theme-v31 .proof-preview,
body.theme-v31 .admin-proof-preview {
  position: relative;
  overflow: hidden;
  border-radius: 30px;
  border: 1px solid rgba(214,173,93,0.14);
  background:
    linear-gradient(180deg, rgba(13,16,25,0.92), rgba(8,10,16,0.88)),
    radial-gradient(circle at 88% 18%, rgba(217,164,63,0.08), transparent 28%);
  box-shadow:
    0 26px 78px rgba(0,0,0,0.38),
    inset 0 1px 0 rgba(255,255,255,0.035),
    inset 0 -22px 38px rgba(0,0,0,0.26);
}
body.theme-v31 .panel::before,
body.theme-v31 .auth-panel::before,
body.theme-v31 .list-card::before,
body.theme-v31 .mini-card::before,
body.theme-v31 .mini-stat::before,
body.theme-v31 .expiry-lot-card::before,
body.theme-v31 .package-card::before,
body.theme-v31 .proof-upload-tips::before,
body.theme-v31 .proof-preview::before,
body.theme-v31 .admin-proof-preview::before {
  content: '';
  position: absolute;
  top: 0;
  left: 28px;
  right: 28px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.16), transparent);
}
body.theme-v31 .panel::after,
body.theme-v31 .auth-panel::after,
body.theme-v31 .list-card::after,
body.theme-v31 .mini-card::after,
body.theme-v31 .mini-stat::after,
body.theme-v31 .expiry-lot-card::after,
body.theme-v31 .package-card::after,
body.theme-v31 .proof-upload-tips::after,
body.theme-v31 .proof-preview::after,
body.theme-v31 .admin-proof-preview::after {
  content: '';
  position: absolute;
  width: 220px;
  height: 220px;
  right: -108px;
  top: -108px;
  background: radial-gradient(circle, rgba(214,173,93,0.10), transparent 66%);
  opacity: 0.55;
}

body.theme-v31 .top-grid,
body.theme-v31 .content-grid,
body.theme-v31 .feature-grid,
body.theme-v31 .bottom-grid,
body.theme-v31 .admin-core-grid,
body.theme-v31 .admin-flow-grid {
  gap: 20px;
}

body.theme-v31 .hero-card {
  min-height: 250px;
  padding: 34px 34px 36px;
  background:
    linear-gradient(180deg, rgba(15,18,29,0.95), rgba(8,10,15,0.92)),
    radial-gradient(circle at 82% 22%, rgba(215,166,72,0.16), transparent 24%),
    radial-gradient(circle at 12% 86%, rgba(79,101,146,0.12), transparent 28%);
}
body.theme-v31 .hero-card::after {
  width: 300px;
  height: 300px;
  right: -120px;
  top: -80px;
  background: radial-gradient(circle, rgba(214,173,93,0.18), transparent 58%);
}
body.theme-v31 .balance-value {
  font-size: clamp(58px, 5.8vw, 88px);
  line-height: 0.90;
  letter-spacing: -0.04em;
  margin: 10px 0 10px;
  text-shadow: 0 10px 32px rgba(0,0,0,0.28);
}
body.theme-v31 .stat-card {
  min-height: 250px;
  align-content: end;
  padding: 28px 26px 30px;
}
body.theme-v31 .stat-value {
  font-size: clamp(34px, 3.2vw, 50px);
  line-height: 0.95;
  letter-spacing: -0.03em;
}
body.theme-v31 .panel-header {
  align-items: end;
  margin-bottom: 18px;
}
body.theme-v31 .panel-header h3,
body.theme-v31 .subsection-header h3 {
  font-size: clamp(30px, 3vw, 44px);
  line-height: 0.95;
  letter-spacing: -0.03em;
}
body.theme-v31 .panel-header p,
body.theme-v31 .subsection-header p {
  max-width: 56ch;
}

body.theme-v31 input,
body.theme-v31 select,
body.theme-v31 textarea {
  background:
    linear-gradient(180deg, rgba(4,6,12,0.90), rgba(8,10,18,0.88)),
    radial-gradient(circle at 18% 0%, rgba(214,173,93,0.05), transparent 32%);
  border: 1px solid rgba(214,173,93,0.14);
  color: var(--text);
  border-radius: 22px;
  padding: 18px 20px;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.03),
    inset 0 -16px 28px rgba(0,0,0,0.24),
    0 10px 24px rgba(0,0,0,0.14);
  transition: border-color 160ms ease, box-shadow 160ms ease, transform 160ms ease;
}
body.theme-v31 input:hover,
body.theme-v31 select:hover,
body.theme-v31 textarea:hover {
  border-color: rgba(214,173,93,0.22);
}
body.theme-v31 input:focus,
body.theme-v31 select:focus,
body.theme-v31 textarea:focus {
  outline: none;
  border-color: rgba(230,191,118,0.34);
  box-shadow:
    0 0 0 1px rgba(230,191,118,0.18),
    0 16px 34px rgba(0,0,0,0.18),
    inset 0 1px 0 rgba(255,255,255,0.04);
  transform: translateY(-1px);
}
body.theme-v31 input::placeholder,
body.theme-v31 textarea::placeholder {
  color: rgba(174,164,151,0.74);
}

body.theme-v31 .primary-btn,
body.theme-v31 .auth-tab.is-active {
  position: relative;
  overflow: hidden;
  color: #fff8ec;
  border: 1px solid rgba(214,173,93,0.20);
  background:
    linear-gradient(180deg, rgba(112,82,27,0.88), rgba(74,55,18,0.94)),
    radial-gradient(circle at 50% 0%, rgba(255,255,255,0.20), transparent 42%);
  box-shadow:
    0 18px 42px rgba(91,62,11,0.22),
    inset 0 1px 0 rgba(255,255,255,0.12),
    inset 0 -12px 22px rgba(0,0,0,0.18);
}
body.theme-v31 .primary-btn::before,
body.theme-v31 .auth-tab.is-active::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, transparent 20%, rgba(255,255,255,0.12) 50%, transparent 80%);
  transform: translateX(-120%);
  transition: transform 360ms ease;
}
body.theme-v31 .primary-btn:hover::before,
body.theme-v31 .auth-tab.is-active:hover::before {
  transform: translateX(120%);
}
body.theme-v31 .primary-btn:hover,
body.theme-v31 .auth-tab.is-active:hover {
  transform: translateY(-1px);
}
body.theme-v31 .ghost-btn,
body.theme-v31 .text-btn,
body.theme-v31 .filter-tab,
body.theme-v31 .inline-pill,
body.theme-v31 .status-pill {
  background: rgba(255,255,255,0.03);
  border-color: rgba(214,173,93,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}
body.theme-v31 .ghost-btn:hover,
body.theme-v31 .text-btn:hover,
body.theme-v31 .filter-tab:hover {
  border-color: rgba(214,173,93,0.22);
}

body.theme-v31 .list-stack {
  gap: 14px;
}
body.theme-v31 .list-card {
  padding: 18px 18px 18px;
}
body.theme-v31 .list-card strong {
  font-size: 18px;
  color: var(--text);
}
body.theme-v31 .inline-meta {
  gap: 10px;
}
body.theme-v31 .inline-pill,
body.theme-v31 .status-pill,
body.theme-v31 .status-badge {
  border-radius: 999px;
  padding: 7px 12px;
  background: rgba(255,255,255,0.035);
}
body.theme-v31 .status-badge {
  border-color: rgba(214,173,93,0.14);
}

body.theme-v31 .mini-card,
body.theme-v31 .mini-stat {
  padding: 18px 18px 20px;
}
body.theme-v31 .mini-card strong,
body.theme-v31 .mini-stat strong {
  font-size: clamp(28px, 2.2vw, 38px);
}

body.theme-v31 .package-grid {
  gap: 16px;
}
body.theme-v31 .package-card {
  padding: 20px 20px 22px;
  transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}
body.theme-v31 .package-card strong {
  font-size: clamp(34px, 3vw, 46px);
  letter-spacing: -0.04em;
  margin-top: 12px;
}
body.theme-v31 .package-card:hover {
  transform: translateY(-2px);
  border-color: rgba(214,173,93,0.22);
}
body.theme-v31 .package-card.is-selected {
  border-color: rgba(230,191,118,0.42);
  box-shadow:
    0 26px 70px rgba(72,47,8,0.18),
    inset 0 1px 0 rgba(255,255,255,0.06),
    inset 0 0 0 1px rgba(230,191,118,0.16);
  background:
    linear-gradient(180deg, rgba(20,16,10,0.92), rgba(12,11,13,0.92)),
    radial-gradient(circle at 88% 18%, rgba(217,164,63,0.15), transparent 28%);
}
body.theme-v31 .package-card.is-selected::after {
  width: 260px;
  height: 260px;
  right: -70px;
  top: -60px;
  background: radial-gradient(circle, rgba(214,173,93,0.18), transparent 56%);
}

body.theme-v31 .proof-preview img,
body.theme-v31 .admin-proof-preview img,
body.theme-v31 .proof-inline img,
body.theme-v31 .proof-thumb {
  border-color: rgba(214,173,93,0.16);
  box-shadow: 0 18px 40px rgba(0,0,0,0.22);
}

body.theme-v31 .auth-panel {
  max-width: 840px;
  padding: 44px 40px 34px;
  background:
    linear-gradient(180deg, rgba(10,13,20,0.92), rgba(6,8,13,0.90)),
    radial-gradient(circle at 50% 12%, rgba(214,173,93,0.16), transparent 30%);
}
body.theme-v31 .auth-panel::after {
  width: 280px;
  height: 280px;
  right: -60px;
  top: -80px;
  background: radial-gradient(circle, rgba(214,173,93,0.16), transparent 56%);
}
body.theme-v31 .auth-logo {
  width: 114px;
  height: 114px;
  border-radius: 32px;
  box-shadow:
    0 22px 60px rgba(0,0,0,0.30),
    inset 0 1px 0 rgba(255,255,255,0.06),
    0 0 0 1px rgba(214,173,93,0.16);
}
body.theme-v31 .header-stack {
  gap: 10px;
}
body.theme-v31 .header-stack h2 {
  font-size: clamp(42px, 5vw, 68px);
}
body.theme-v31 .auth-switch {
  padding: 10px;
  border: 1px solid rgba(214,173,93,0.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.02);
}
body.theme-v31 .auth-tab {
  padding: 14px 18px;
}

body.theme-v31 .proof-upload-tips strong,
body.theme-v31 .status-badge,
body.theme-v31 .filter-tab.is-active,
body.theme-v31 .status-pending,
body.theme-v31 .status-in_progress,
body.theme-v31 .status-approved,
body.theme-v31 .status-completed,
body.theme-v31 .status-proof_submitted {
  color: var(--gold-soft);
}

body.theme-v31 .admin-grid {
  gap: 18px;
}
body.theme-v31 .card-actions {
  gap: 12px;
}
body.theme-v31 .panel-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(214,173,93,0.20), transparent);
  margin: 10px 0 2px;
}

@media (max-width: 1220px) {
  body.theme-v31 .app-shell {
    grid-template-columns: 1fr;
    padding: 16px;
    gap: 16px;
  }
  body.theme-v31 .sidebar {
    position: relative;
    top: 0;
    min-height: auto;
    padding: 24px 20px;
  }
}

@media (max-width: 980px) {
  body.theme-v31 .main-content {
    padding-bottom: 28px;
  }
  body.theme-v31 .page-header {
    padding: 8px 2px 20px;
  }
  body.theme-v31 .page-title,
  body.theme-v31 .header-stack h2 {
    font-size: clamp(34px, 11vw, 50px);
  }
  body.theme-v31 .panel,
  body.theme-v31 .auth-panel,
  body.theme-v31 .list-card,
  body.theme-v31 .mini-card,
  body.theme-v31 .mini-stat,
  body.theme-v31 .expiry-lot-card,
  body.theme-v31 .package-card,
  body.theme-v31 .proof-upload-tips,
  body.theme-v31 .proof-preview,
  body.theme-v31 .admin-proof-preview {
    border-radius: 26px;
  }
  body.theme-v31 .hero-card,
  body.theme-v31 .stat-card {
    min-height: auto;
  }
}

@media (max-width: 640px) {
  body.theme-v31 .app-shell {
    padding: 12px;
  }
  body.theme-v31 .sidebar {
    padding: 18px 16px 20px;
    border-radius: 26px;
  }
  body.theme-v31 .brand-logo {
    width: 92px;
    height: 92px;
    border-radius: 24px;
  }
  body.theme-v31 .page-title {
    font-size: clamp(32px, 11vw, 46px);
  }
  body.theme-v31 .auth-panel {
    padding: 34px 18px 24px;
  }
  body.theme-v31 .panel,
  body.theme-v31 .hero-card,
  body.theme-v31 .stat-card,
  body.theme-v31 .list-card,
  body.theme-v31 .mini-card,
  body.theme-v31 .mini-stat,
  body.theme-v31 .expiry-lot-card,
  body.theme-v31 .package-card,
  body.theme-v31 .proof-upload-tips,
  body.theme-v31 .proof-preview,
  body.theme-v31 .admin-proof-preview {
    padding-left: 18px;
    padding-right: 18px;
  }
  body.theme-v31 .hero-card {
    min-height: 220px;
    padding-top: 28px;
    padding-bottom: 30px;
  }
  body.theme-v31 .stat-card {
    padding-top: 24px;
    padding-bottom: 24px;
  }
  body.theme-v31 .balance-value {
    font-size: clamp(50px, 16vw, 70px);
  }
  body.theme-v31 .panel-header h3,
  body.theme-v31 .subsection-header h3 {
    font-size: 24px;
  }
  body.theme-v31 .package-card strong {
    font-size: 38px;
  }
}

/* ===== B32 BLACK VAULT SIGNATURE REFINEMENT ===== */
body.theme-v31 .user-meta {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

body.theme-v31 .vault-identity-card {
  position: relative;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  gap: 1.15rem;
  padding: 1.6rem;
  border-radius: 2rem;
  border: 1px solid rgba(201, 162, 93, 0.22);
  background:
    radial-gradient(circle at 86% 18%, rgba(195, 138, 32, 0.18), transparent 30%),
    radial-gradient(circle at 16% 100%, rgba(25, 49, 110, 0.18), transparent 35%),
    linear-gradient(145deg, rgba(15, 16, 24, 0.96), rgba(7, 7, 10, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.05),
    0 32px 70px rgba(0,0,0,0.44);
}

body.theme-v31 .vault-identity-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(120deg, rgba(255,255,255,0.02), transparent 38%, transparent 62%, rgba(201,162,93,0.06));
  pointer-events: none;
}

body.theme-v31 .vault-identity-top {
  position: relative;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
}

body.theme-v31 .vault-identity-copy {
  flex: 1;
  min-width: 0;
}

body.theme-v31 .vault-kicker {
  margin-bottom: 0.8rem;
  font-size: 0.72rem;
  letter-spacing: 0.38em;
  text-transform: uppercase;
  color: rgba(212, 179, 112, 0.86);
}

body.theme-v31 .vault-name {
  margin: 0;
  font-size: clamp(2rem, 5.5vw, 3.25rem);
  line-height: 0.94;
  letter-spacing: -0.05em;
  font-family: 'Cormorant Garamond', serif;
  color: var(--ivory);
  text-wrap: balance;
}

body.theme-v31 .vault-email {
  margin: 0.5rem 0 0;
  font-size: 0.98rem;
  color: rgba(245, 238, 227, 0.82);
  word-break: break-word;
}

body.theme-v31 .vault-descriptor {
  margin: 0.55rem 0 0;
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(245, 238, 227, 0.52);
}

body.theme-v31 .vault-inline-logo-wrap {
  position: relative;
  flex: 0 0 auto;
  width: 4.9rem;
  height: 4.9rem;
  border-radius: 1.5rem;
  display: grid;
  place-items: center;
  border: 1px solid rgba(201, 162, 93, 0.2);
  background:
    radial-gradient(circle at 50% 30%, rgba(201, 162, 93, 0.16), transparent 52%),
    linear-gradient(145deg, rgba(22, 24, 35, 0.95), rgba(8, 8, 11, 0.98));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 18px 34px rgba(0,0,0,0.36);
}

body.theme-v31 .vault-inline-logo {
  width: 58%;
  height: auto;
  filter: drop-shadow(0 8px 18px rgba(195, 138, 32, 0.22));
}

body.theme-v31 .vault-meta-grid {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.85rem;
}

body.theme-v31 .vault-meta-card {
  min-height: 5.25rem;
  padding: 0.95rem 1rem;
  border-radius: 1.25rem;
  border: 1px solid rgba(201, 162, 93, 0.14);
  background: linear-gradient(180deg, rgba(16, 18, 29, 0.9), rgba(8, 8, 11, 0.92));
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.4rem;
}

body.theme-v31 .vault-meta-card span {
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.32em;
  color: rgba(212, 179, 112, 0.68);
}

body.theme-v31 .vault-meta-card strong {
  font-size: 1.02rem;
  font-weight: 600;
  color: rgba(245, 238, 227, 0.96);
  line-height: 1.15;
  word-break: break-word;
}

body.theme-v31 .vault-meta-card-badge {
  background:
    radial-gradient(circle at 80% 20%, rgba(195, 138, 32, 0.14), transparent 32%),
    linear-gradient(180deg, rgba(24, 17, 11, 0.86), rgba(10, 10, 12, 0.94));
}

body.theme-v31 #logoutBtn.secondary-btn {
  min-height: 4.25rem;
  border-radius: 1.65rem;
  border: 1px solid rgba(201, 162, 93, 0.2);
  background: linear-gradient(180deg, rgba(15, 16, 23, 0.94), rgba(8, 8, 11, 0.98));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.05), 0 18px 38px rgba(0,0,0,0.3);
}

body.theme-v31 .top-grid {
  gap: 1.15rem;
}

body.theme-v31 .stat-card {
  min-height: 17rem;
}

body.theme-v31 .stat-card:last-child {
  background:
    radial-gradient(circle at 76% 18%, rgba(195, 138, 32, 0.16), transparent 28%),
    radial-gradient(circle at 16% 88%, rgba(25, 49, 110, 0.18), transparent 36%),
    linear-gradient(145deg, rgba(15, 16, 24, 0.96), rgba(7, 7, 10, 0.98));
}

body.theme-v31 #roleValue {
  font-size: clamp(3rem, 10vw, 5.4rem);
  line-height: 0.9;
  letter-spacing: -0.06em;
}

body.theme-v31 .panel-header h2,
body.theme-v31 .panel-header h3,
body.theme-v31 .subsection-header h3 {
  letter-spacing: -0.03em;
}

body.theme-v31 .form-grid label {
  gap: 0.85rem;
}

body.theme-v31 .form-grid > label,
body.theme-v31 .form-stack > label,
body.theme-v31 .buy-credit-form > label {
  font-size: 0.9rem;
  color: rgba(245, 238, 227, 0.84);
}

body.theme-v31 input,
body.theme-v31 select,
body.theme-v31 textarea {
  border-radius: 1.45rem;
  border: 1px solid rgba(201, 162, 93, 0.18);
  background:
    linear-gradient(180deg, rgba(13, 14, 22, 0.98), rgba(8, 8, 11, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.04),
    inset 0 -10px 30px rgba(11, 19, 45, 0.18),
    0 12px 24px rgba(0,0,0,0.2);
}

body.theme-v31 input:focus,
body.theme-v31 select:focus,
body.theme-v31 textarea:focus {
  border-color: rgba(215, 182, 115, 0.4);
  box-shadow:
    0 0 0 3px rgba(195, 138, 32, 0.1),
    inset 0 1px 0 rgba(255,255,255,0.05),
    inset 0 -10px 30px rgba(11, 19, 45, 0.18),
    0 12px 24px rgba(0,0,0,0.26);
}

body.theme-v31 .primary-btn {
  border-radius: 1.6rem;
  background:
    linear-gradient(135deg, rgba(113, 82, 28, 0.98), rgba(187, 144, 63, 1) 50%, rgba(106, 76, 24, 0.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.18),
    inset 0 -8px 18px rgba(87, 56, 9, 0.22),
    0 20px 38px rgba(0,0,0,0.32),
    0 10px 24px rgba(191, 143, 53, 0.16);
}

body.theme-v31 .primary-btn:hover {
  transform: translateY(-1px);
}

body.theme-v31 .package-card {
  position: relative;
  overflow: hidden;
  min-height: 15rem;
  justify-content: flex-end;
  gap: 0.7rem;
  padding: 1.4rem;
  border-radius: 2rem;
}

body.theme-v31 .package-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 82% 18%, rgba(195, 138, 32, 0.16), transparent 26%),
    radial-gradient(circle at 12% 86%, rgba(25, 49, 110, 0.16), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.02), transparent 40%, transparent 65%, rgba(201,162,93,0.05));
  pointer-events: none;
}

body.theme-v31 .package-card-topline {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: auto;
}

body.theme-v31 .package-brow {
  font-size: 0.72rem;
  letter-spacing: 0.34em;
  text-transform: uppercase;
  color: rgba(212, 179, 112, 0.82);
}

body.theme-v31 .package-mark {
  font-size: 0.82rem;
  letter-spacing: 0.3em;
  color: rgba(245, 238, 227, 0.44);
}

body.theme-v31 .package-card .package-name {
  position: relative;
  font-size: 1rem;
  font-weight: 600;
  color: rgba(245, 238, 227, 0.92);
  max-width: 82%;
}

body.theme-v31 .package-card strong {
  position: relative;
  font-size: clamp(2.45rem, 9vw, 4.4rem);
  line-height: 0.92;
}

body.theme-v31 .package-card small {
  position: relative;
  font-size: 1rem;
  color: rgba(245, 238, 227, 0.76);
}

body.theme-v31 .package-card.is-selected,
body.theme-v31 .package-card.selected {
  border-color: rgba(214, 178, 109, 0.38);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.07),
    0 28px 54px rgba(0,0,0,0.38),
    0 0 0 1px rgba(214, 178, 109, 0.08);
}

@media (max-width: 720px) {
  body.theme-v31 .vault-identity-card {
    padding: 1.35rem;
    border-radius: 1.7rem;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    width: 4.2rem;
    height: 4.2rem;
    border-radius: 1.25rem;
  }

  body.theme-v31 .vault-meta-grid {
    grid-template-columns: 1fr;
  }

  body.theme-v31 .package-card {
    min-height: 13rem;
    border-radius: 1.7rem;
  }
}


/* B33 BLACK VAULT POLISH SAFE */

body.theme-v31 .main-content::after {
  display: none;
}

body.theme-v31 .auth-panel,
body.theme-v31 .vault-panel,
body.theme-v31 .hero-account-card,
body.theme-v31 .vault-stat-card,
body.theme-v31 .dashboard-card,
body.theme-v31 .vault-shell-card {
  overflow: hidden;
}

body.theme-v31 .brand-mark,
body.theme-v31 .auth-logo,
body.theme-v31 .brand-logo {
  box-sizing: border-box;
  padding: 12px;
}

body.theme-v31 .brand-mark img,
body.theme-v31 .auth-logo img,
body.theme-v31 .brand-logo img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center;
  display: block;
}

body.theme-v31 .auth-logo {
  width: 116px;
  height: 116px;
  padding: 14px;
}

body.theme-v31 .vault-inline-logo {
  width: 50%;
  max-width: 76px;
  max-height: 76px;
}

body.theme-v31 .vault-inline-logo--small {
  width: 42%;
  max-width: 56px;
  max-height: 56px;
}

body.theme-v31 .hero-account-card .brand-logo {
  width: 118px;
  height: 118px;
  padding: 14px;
}

body.theme-v31 .hero-account-card .brand-logo img {
  transform: scale(0.94);
  transform-origin: center;
}

body.theme-v31 .auth-panel .auth-logo img,
body.theme-v31 .auth-panel .brand-mark img {
  transform: scale(0.92);
  transform-origin: center;
}


/* ===== V34 SAFE LOGO + PACKAGE PASS ===== */
body.theme-v31 .brand-shell-card {
  gap: 1.7rem;
}

body.theme-v31 .brand-mark {
  width: 5.9rem;
  height: 5.9rem;
  padding: 0.7rem;
  border-radius: 2rem;
  background:
    radial-gradient(circle at 50% 28%, rgba(214, 178, 109, 0.18), transparent 48%),
    linear-gradient(180deg, rgba(15,19,36,0.96), rgba(6,8,18,0.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 18px 36px rgba(0,0,0,0.34),
    0 0 0 1px rgba(214,178,109,0.10);
}

body.theme-v31 .brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 14px rgba(212, 171, 92, 0.14))
    drop-shadow(0 8px 20px rgba(0, 0, 0, 0.24));
}

body.theme-v31 .vault-inline-logo-wrap {
  width: 5.25rem;
  height: 5.25rem;
  border-radius: 1.7rem;
  padding: 0.7rem;
  background:
    radial-gradient(circle at 50% 24%, rgba(217, 183, 113, 0.18), transparent 50%),
    linear-gradient(180deg, rgba(16,20,40,0.95), rgba(8,10,20,0.98));
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.07),
    0 18px 34px rgba(0,0,0,0.34),
    0 0 0 1px rgba(214,178,109,0.12);
}

body.theme-v31 .vault-inline-logo {
  width: 100%;
  height: 100%;
  object-fit: contain;
  filter:
    drop-shadow(0 0 12px rgba(212,171,92,0.12))
    drop-shadow(0 8px 18px rgba(0,0,0,0.24));
}

body.theme-v31 .vault-identity-card {
  padding: 1.95rem;
}

body.theme-v31 .package-card {
  min-height: 14.2rem;
  padding: 1.45rem;
}

body.theme-v31 .package-card::after {
  content: '';
  position: absolute;
  left: 1.45rem;
  right: 1.45rem;
  bottom: 1.15rem;
  height: 1px;
  background: linear-gradient(90deg, rgba(214,178,109,0.16), rgba(214,178,109,0.04), transparent 80%);
  pointer-events: none;
  opacity: 0.78;
}

body.theme-v31 .package-card:nth-child(1)::before,
body.theme-v31 .package-card.is-selected::before,
body.theme-v31 .package-card.selected::before {
  background:
    radial-gradient(circle at 82% 18%, rgba(198, 146, 44, 0.22), transparent 28%),
    radial-gradient(circle at 12% 86%, rgba(25, 49, 110, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.02), transparent 40%, transparent 65%, rgba(201,162,93,0.06));
}

body.theme-v31 .package-card:nth-child(2)::before {
  background:
    radial-gradient(circle at 78% 22%, rgba(173, 116, 24, 0.18), transparent 28%),
    radial-gradient(circle at 16% 86%, rgba(20, 42, 92, 0.16), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.02), transparent 40%, transparent 65%, rgba(201,162,93,0.05));
}

body.theme-v31 .package-card:nth-child(3)::before,
body.theme-v31 .package-card:nth-child(4)::before,
body.theme-v31 .package-card:nth-child(5)::before {
  background:
    radial-gradient(circle at 82% 18%, rgba(28, 56, 124, 0.20), transparent 30%),
    radial-gradient(circle at 18% 84%, rgba(178, 124, 34, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.02), transparent 40%, transparent 65%, rgba(201,162,93,0.04));
}

body.theme-v31 .package-card .package-name {
  max-width: 84%;
}

body.theme-v31 .package-mark {
  color: rgba(245, 238, 227, 0.48);
}

body.theme-v31 .package-card.is-selected,
body.theme-v31 .package-card.selected {
  transform: translateY(-1px);
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.08),
    0 30px 56px rgba(0,0,0,0.42),
    0 0 0 1px rgba(214, 178, 109, 0.10);
}

@media (max-width: 720px) {
  body.theme-v31 .brand-mark {
    width: 5.55rem;
    height: 5.55rem;
    border-radius: 1.75rem;
    padding: 0.65rem;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    width: 4.9rem;
    height: 4.9rem;
    border-radius: 1.45rem;
    padding: 0.62rem;
  }

  body.theme-v31 .vault-identity-card {
    padding: 1.55rem;
  }

  body.theme-v31 .package-card {
    min-height: 13.4rem;
    border-radius: 1.8rem;
  }
}


/* B35 surgical fix: package header cleanup + safer mobile wrapping */
.vault-email{overflow-wrap:anywhere;word-break:break-word;}
@media (max-width: 640px){.vault-identity-top{grid-template-columns:minmax(0,1fr) 112px;gap:18px;align-items:start;}.vault-inline-logo-wrap{justify-self:end;}}


/* ===== B36 MOBILE IDENTITY FIT FIX ===== */
body.theme-v31 .vault-email {
  overflow-wrap: anywhere;
  word-break: break-word;
}

@media (max-width: 780px) {
  body.theme-v31 .vault-identity-top {
    grid-template-columns: minmax(0, 1fr) 5.25rem;
    gap: 0.95rem;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    width: 5.25rem;
    height: 5.25rem;
    padding: 0.7rem;
  }

  body.theme-v31 .vault-name {
    font-size: clamp(2.45rem, 8.2vw, 3.25rem);
  }

  body.theme-v31 .vault-email {
    font-size: clamp(1rem, 3.8vw, 1.2rem);
    line-height: 1.28;
  }
}

@media (max-width: 640px) {
  body.theme-v31 .vault-identity-card {
    padding: 1.35rem 1.1rem 1.15rem;
    gap: 0.95rem;
  }

  body.theme-v31 .vault-identity-top {
    position: relative;
    display: block;
    padding-right: 5.5rem;
    min-height: 5rem;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    position: absolute;
    top: 0;
    right: 0;
    width: 4.8rem;
    height: 4.8rem;
    padding: 0.52rem;
    border-radius: 1.35rem;
  }

  body.theme-v31 .vault-eyebrow {
    margin-bottom: 0.72rem;
    font-size: 0.76rem;
    letter-spacing: 0.34em;
  }

  body.theme-v31 .vault-name {
    margin-bottom: 0.42rem;
    font-size: clamp(2.15rem, 9vw, 2.85rem);
    line-height: 0.95;
  }

  body.theme-v31 .vault-email {
    font-size: clamp(0.98rem, 4.6vw, 1.14rem);
    line-height: 1.26;
    max-width: 100%;
  }

  body.theme-v31 .vault-tagline {
    max-width: 100%;
    font-size: 0.82rem;
    line-height: 1.38;
    letter-spacing: 0.22em;
  }

  body.theme-v31 .vault-micro-panels {
    gap: 0.9rem;
  }

  body.theme-v31 .vault-micro-panel {
    min-height: auto;
    padding: 1.08rem 0.98rem 1.02rem;
  }

  body.theme-v31 .vault-micro-label {
    font-size: 0.76rem;
    letter-spacing: 0.34em;
  }

  body.theme-v31 .vault-micro-value {
    font-size: clamp(1.42rem, 6vw, 1.82rem);
  }
}

/* B37 mobile identity polish */
@media (max-width: 640px) {
  body.theme-v31 .vault-identity-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 4.05rem;
    align-items: flex-start;
    gap: 0.72rem;
  }

  body.theme-v31 .vault-identity-copy {
    min-width: 0;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    width: 4.05rem;
    height: 4.05rem;
    flex: 0 0 4.05rem;
    margin-top: 0.06rem;
  }

  body.theme-v31 .vault-name {
    font-size: clamp(1.56rem, 6.8vw, 1.66rem);
    line-height: 0.96;
    letter-spacing: -0.022em;
  }

  body.theme-v31 .vault-email {
    max-width: 100%;
    font-size: 0.9rem;
    line-height: 1.14;
    letter-spacing: 0.004em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  body.theme-v31 .vault-descriptor {
    font-size: 0.84rem;
    line-height: 1.24;
    letter-spacing: 0.2em;
  }
}


/* B38 MOBILE ADMIN EMAIL STACK FIX */
@media (max-width: 640px) {
  body.theme-v31 .vault-identity-top {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.88rem;
    padding-right: 0;
    min-height: 0;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    position: static;
    align-self: flex-end;
    width: 4.2rem;
    height: 4.2rem;
    flex: 0 0 4.2rem;
    margin-top: 0.02rem;
    margin-bottom: 0.04rem;
  }

  body.theme-v31 .vault-identity-copy {
    width: 100%;
    min-width: 0;
  }

  body.theme-v31 .vault-name {
    font-size: clamp(1.58rem, 6.6vw, 1.8rem);
    line-height: 0.98;
  }

  body.theme-v31 .vault-email {
    display: block;
    width: 100%;
    max-width: 100%;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    overflow-wrap: anywhere;
    word-break: break-word;
    font-size: clamp(0.96rem, 4vw, 1.06rem);
    line-height: 1.18;
  }

  body.theme-v31 .vault-descriptor {
    max-width: 100%;
    font-size: 0.82rem;
    line-height: 1.28;
    letter-spacing: 0.18em;
  }
}


/* B39 MOBILE IDENTITY REBALANCE FIX */
@media (max-width: 480px) {
  .vault-identity-top {
    position: relative;
    display: block;
    min-height: 5.25rem;
  }

  .vault-identity-copy {
    width: 100%;
    min-width: 0;
    padding-right: 6.15rem;
  }

  .vault-kicker {
    max-width: 100%;
    letter-spacing: 0.30em;
  }

  .vault-name {
    font-size: clamp(1.70rem, 8vw, 2.02rem);
    line-height: 0.94;
    max-width: 100%;
  }

  .vault-email {
    max-width: 100%;
    font-size: clamp(0.94rem, 3.4vw, 1.02rem);
    line-height: 1.14;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    word-break: normal;
    overflow-wrap: break-word;
  }

  .vault-descriptor {
    max-width: 100%;
    margin-top: 0.4rem;
    font-size: 0.77rem;
    line-height: 1.32;
    letter-spacing: 0.26em;
  }

  .vault-inline-logo-wrap {
    position: absolute;
    right: 0;
    top: 1.08rem;
    width: 5.15rem;
    height: 5.15rem;
    flex: 0 0 5.15rem;
    margin-top: 0;
  }

  .vault-inline-logo-wrap img {
    width: 3.45rem;
    height: 3.45rem;
  }

  .vault-identity-panel {
    margin-top: 1.1rem;
  }
}

@media (max-width: 390px) {
  .vault-identity-copy {
    padding-right: 5.8rem;
  }

  .vault-inline-logo-wrap {
    width: 4.85rem;
    height: 4.85rem;
    flex-basis: 4.85rem;
    top: 1.18rem;
  }

  .vault-inline-logo-wrap img {
    width: 3.15rem;
    height: 3.15rem;
  }

  .vault-descriptor {
    font-size: 0.74rem;
    letter-spacing: 0.24em;
  }
}


/* B40 DEPLOY-READY MOBILE IDENTITY LOCK FIX
   Purpose: keep admin/member identity card readable on iPhone widths
   by locking the proven stacked mobile layout and overriding B39 rebalance. */
@media (max-width: 640px) {
  body.theme-v31 .vault-identity-top {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.88rem;
    padding-right: 0;
    min-height: 0;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    position: static;
    align-self: flex-end;
    width: 4.2rem;
    height: 4.2rem;
    flex: 0 0 4.2rem;
    margin-top: 0.02rem;
    margin-bottom: 0.04rem;
  }

  body.theme-v31 .vault-identity-copy {
    width: 100%;
    min-width: 0;
  }

  body.theme-v31 .vault-name {
    font-size: clamp(1.58rem, 6.6vw, 1.8rem);
    line-height: 0.98;
  }

  body.theme-v31 .vault-email {
    display: block;
    width: 100%;
    max-width: 100%;
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    overflow-wrap: anywhere;
    word-break: break-word;
    font-size: clamp(0.96rem, 4vw, 1.06rem);
    line-height: 1.18;
  }

  body.theme-v31 .vault-descriptor {
    max-width: 100%;
    font-size: 0.82rem;
    line-height: 1.28;
    letter-spacing: 0.18em;
  }
}


/* B41 MOBILE IDENTITY EMAIL LOCK */
@media (max-width: 640px) {
  body.theme-v31 .vault-identity-top,
  .vault-identity-top {
    display: block !important;
  }

  body.theme-v31 .vault-identity-copy,
  .vault-identity-copy {
    width: 100% !important;
    max-width: none !important;
    margin-right: 0 !important;
    padding-right: 0 !important;
  }

  body.theme-v31 .vault-name,
  .vault-name {
    max-width: none !important;
    font-size: clamp(2.15rem, 8.8vw, 3rem) !important;
    line-height: 1.02 !important;
    margin-bottom: 0.55rem !important;
  }

  body.theme-v31 .vault-email,
  .vault-email {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    font-size: clamp(0.98rem, 4.15vw, 1.16rem) !important;
    line-height: 1.18 !important;
    white-space: nowrap !important;
    overflow-wrap: normal !important;
    word-break: normal !important;
    letter-spacing: 0 !important;
  }

  body.theme-v31 .vault-descriptor,
  .vault-descriptor {
    max-width: 15ch !important;
    font-size: 0.86rem !important;
    line-height: 1.26 !important;
    letter-spacing: 0.28em !important;
    margin-top: 0.7rem !important;
  }

  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap {
    position: static !important;
    display: flex !important;
    justify-content: flex-end !important;
    width: 100% !important;
    margin-top: 0.9rem !important;
    padding-right: 0 !important;
  }

  body.theme-v31 .vault-inline-logo,
  .vault-inline-logo {
    width: 98px !important;
    height: 98px !important;
    flex: 0 0 98px !important;
  }
}


/* B42 FINAL MOBILE IDENTITY LOCK */
@media (max-width: 560px) {
  body.theme-black-vault .vault-identity-card {
    position: relative !important;
    overflow: hidden !important;
  }

  body.theme-black-vault .vault-identity-top {
    position: relative !important;
    display: block !important;
    min-height: 188px !important;
    padding-right: 0 !important;
    gap: 0 !important;
    align-items: stretch !important;
  }

  body.theme-black-vault .vault-identity-copy {
    display: block !important;
    width: calc(100% - 112px) !important;
    max-width: calc(100% - 112px) !important;
    min-width: 0 !important;
    padding-right: 0 !important;
  }

  body.theme-black-vault .vault-member-name {
    font-size: clamp(2.05rem, 8.2vw, 2.7rem) !important;
    line-height: 0.98 !important;
    max-width: 100% !important;
    margin-bottom: 0.5rem !important;
  }

  body.theme-black-vault .vault-email {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.74rem !important;
    line-height: 1.16 !important;
    letter-spacing: -0.015em !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    margin-bottom: 0.7rem !important;
  }

  body.theme-black-vault .vault-descriptor {
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.70rem !important;
    line-height: 1.35 !important;
    letter-spacing: 0.28em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap {
    position: absolute !important;
    right: 0 !important;
    top: 112px !important;
    width: 92px !important;
    height: 92px !important;
    min-width: 92px !important;
    min-height: 92px !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    border-radius: 26px !important;
    flex: 0 0 92px !important;
    align-self: auto !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.03), rgba(255,255,255,0.01)), linear-gradient(135deg, rgba(12,19,42,0.94), rgba(3,6,18,0.96)) !important;
    border: 1px solid rgba(196, 153, 77, 0.28) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.08), 0 16px 36px rgba(2,4,12,0.32) !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap::before,
  body.theme-black-vault .vault-inline-logo-wrap::after {
    display: none !important;
    content: none !important;
  }

  body.theme-black-vault .vault-inline-logo {
    width: 62px !important;
    height: 62px !important;
    margin: 0 !important;
    object-fit: contain !important;
  }

  body.theme-black-vault .vault-meta-grid {
    margin-top: 1.1rem !important;
    gap: 1rem !important;
  }
}


/* B43 MOBILE IDENTITY LOGO FIX */
@media (max-width: 560px) {
  .vault-identity-top {
    position: relative !important;
    display: block !important;
    min-height: 0 !important;
    padding-right: 0 !important;
    padding-bottom: 118px !important;
    gap: 0 !important;
  }

  .vault-identity-copy {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
  }

  .vault-member-name {
    max-width: 100% !important;
    margin-right: 0 !important;
  }

  .vault-email {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    line-height: 1.16 !important;
    margin-top: 6px !important;
  }

  .vault-descriptor {
    display: block !important;
    width: auto !important;
    max-width: 100% !important;
    margin-top: 12px !important;
    letter-spacing: 0.22em !important;
  }

  .vault-inline-logo-wrap {
    position: absolute !important;
    right: 0 !important;
    bottom: 4px !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
    width: 98px !important;
    min-width: 98px !important;
    max-width: 98px !important;
    height: 98px !important;
    min-height: 98px !important;
    max-height: 98px !important;
    padding: 16px !important;
    border-radius: 28px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background:
      radial-gradient(circle at 35% 28%, rgba(255,255,255,0.08), transparent 42%),
      radial-gradient(circle at 70% 72%, rgba(255,177,68,0.14), transparent 52%),
      linear-gradient(180deg, rgba(9,11,20,0.96), rgba(3,4,10,0.985)) !important;
    border: 1px solid rgba(198,154,83,0.22) !important;
    box-shadow:
      inset 0 1px 0 rgba(255,255,255,0.1),
      inset 0 -22px 42px rgba(0,0,0,0.4),
      0 24px 44px rgba(0,0,0,0.32) !important;
  }

  .vault-inline-logo {
    width: 66px !important;
    height: 66px !important;
  }

  .vault-meta-grid {
    margin-top: 8px !important;
  }
}


/* B44 MOBILE TOP GRID IDENTITY FIX */
@media (max-width: 640px) {
  .vault-identity-card {
    padding: 2rem 1.35rem 1.45rem;
  }

  .vault-identity-top {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 5.75rem;
    align-items: start;
    column-gap: 1rem;
    row-gap: 0;
    margin-bottom: 1.4rem;
  }

  .vault-identity-copy {
    min-width: 0;
    max-width: none;
    gap: 0.7rem;
  }

  .vault-kicker {
    font-size: 0.72rem;
    letter-spacing: 0.36em;
  }

  .vault-name {
    font-size: clamp(2.35rem, 10vw, 3.3rem);
    line-height: 0.94;
    max-width: 100%;
  }

  .vault-email {
    font-size: 0.98rem;
    line-height: 1.2;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 100%;
  }

  .vault-descriptor {
    font-size: 0.72rem;
    letter-spacing: 0.28em;
    line-height: 1.38;
    max-width: 100%;
    text-wrap: balance;
  }

  .vault-inline-logo-wrap {
    position: static !important;
    width: 5.75rem;
    height: 5.75rem;
    min-width: 5.75rem;
    margin: 0.4rem 0 0;
    padding: 0.32rem;
    justify-self: end;
    align-self: start;
    display: flex;
  }

  .vault-inline-logo {
    width: 100%;
    height: 100%;
    border-radius: 1.7rem;
  }

  .vault-meta-grid {
    margin-top: 0;
    gap: 1rem;
  }
}


/* B45 MOBILE IDENTITY TOP GRID HARD LOCK
   Goal: stop the floating/logo-drop bug and remove the dead vertical gap on iPhone widths. */
@media (max-width: 640px) {
  body.theme-black-vault .vault-identity-card,
  body.theme-v31 .vault-identity-card,
  .vault-identity-card {
    padding: 2rem 1.35rem 1.45rem !important;
    overflow: hidden !important;
  }

  body.theme-black-vault .vault-identity-top,
  body.theme-v31 .vault-identity-top,
  .vault-identity-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 5.4rem !important;
    column-gap: 0.9rem !important;
    row-gap: 0 !important;
    align-items: start !important;
    position: static !important;
    min-height: 0 !important;
    margin-bottom: 1.15rem !important;
    padding-right: 0 !important;
  }

  body.theme-black-vault .vault-identity-copy,
  body.theme-v31 .vault-identity-copy,
  .vault-identity-copy {
    display: block !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-kicker,
  body.theme-v31 .vault-kicker,
  .vault-kicker {
    font-size: 0.72rem !important;
    letter-spacing: 0.34em !important;
    margin-bottom: 0.78rem !important;
  }

  body.theme-black-vault .vault-member-name,
  body.theme-black-vault .vault-name,
  body.theme-v31 .vault-member-name,
  body.theme-v31 .vault-name,
  .vault-member-name,
  .vault-name {
    font-size: clamp(2.05rem, 8.8vw, 2.7rem) !important;
    line-height: 0.94 !important;
    max-width: 100% !important;
    margin: 0 0 0.45rem 0 !important;
  }

  body.theme-black-vault .vault-email,
  body.theme-v31 .vault-email,
  .vault-email {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.94rem !important;
    line-height: 1.18 !important;
    letter-spacing: 0 !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-descriptor,
  body.theme-v31 .vault-descriptor,
  .vault-descriptor {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: 0.76rem !important;
    line-height: 1.34 !important;
    letter-spacing: 0.18em !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: anywhere !important;
    text-wrap: balance !important;
    margin: 0.58rem 0 0 0 !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap,
  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap {
    position: static !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;
    grid-column: 2 !important;
    grid-row: 1 / span 3 !important;
    justify-self: end !important;
    align-self: start !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 5.4rem !important;
    min-width: 5.4rem !important;
    max-width: 5.4rem !important;
    height: 5.4rem !important;
    min-height: 5.4rem !important;
    max-height: 5.4rem !important;
    padding: 0.58rem !important;
    margin: 0.2rem 0 0 0 !important;
    border-radius: 1.6rem !important;
  }

  body.theme-black-vault .vault-inline-logo,
  body.theme-black-vault .vault-inline-logo-wrap img,
  body.theme-v31 .vault-inline-logo,
  body.theme-v31 .vault-inline-logo-wrap img,
  .vault-inline-logo,
  .vault-inline-logo-wrap img {
    width: 100% !important;
    height: 100% !important;
    border-radius: 1.25rem !important;
    display: block !important;
  }

  body.theme-black-vault .vault-identity-panel,
  body.theme-v31 .vault-identity-panel,
  .vault-identity-panel,
  body.theme-black-vault .vault-meta-grid,
  body.theme-v31 .vault-meta-grid,
  .vault-meta-grid {
    margin-top: 0 !important;
    gap: 1rem !important;
  }
}

@media (max-width: 390px) {
  body.theme-black-vault .vault-identity-top,
  body.theme-v31 .vault-identity-top,
  .vault-identity-top {
    grid-template-columns: minmax(0, 1fr) 5.05rem !important;
    column-gap: 0.8rem !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap,
  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap {
    width: 5.05rem !important;
    min-width: 5.05rem !important;
    max-width: 5.05rem !important;
    height: 5.05rem !important;
    min-height: 5.05rem !important;
    max-height: 5.05rem !important;
  }

  body.theme-black-vault .vault-member-name,
  body.theme-black-vault .vault-name,
  body.theme-v31 .vault-member-name,
  body.theme-v31 .vault-name,
  .vault-member-name,
  .vault-name {
    font-size: clamp(1.9rem, 8.4vw, 2.45rem) !important;
  }

  body.theme-black-vault .vault-email,
  body.theme-v31 .vault-email,
  .vault-email {
    font-size: 0.9rem !important;
  }

  body.theme-black-vault .vault-descriptor,
  body.theme-v31 .vault-descriptor,
  .vault-descriptor {
    font-size: 0.72rem !important;
    letter-spacing: 0.16em !important;
  }
}

/* B46 MOBILE DEAD SPACE FIX */
@media (max-width: 768px) {
  body.theme-black-vault .vault-identity-panel {
    position: relative !important;
  }

  body.theme-black-vault .vault-identity-top {
    display: block !important;
    padding-bottom: 0 !important;
    margin-bottom: 1.4rem !important;
  }

  body.theme-black-vault .vault-identity-copy {
    width: auto !important;
    max-width: calc(100% - 10.75rem) !important;
    padding-right: 0 !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap {
    position: absolute !important;
    top: 1.55rem !important;
    right: 1.1rem !important;
    width: 9.1rem !important;
    min-width: 9.1rem !important;
    max-width: 9.1rem !important;
    min-height: 9.1rem !important;
    height: 9.1rem !important;
    margin: 0 !important;
    padding: 0 !important;
    display: flex !important;
    align-items: flex-start !important;
    justify-content: flex-end !important;
    z-index: 2 !important;
  }

  body.theme-black-vault .vault-inline-logo {
    width: 100% !important;
    height: 100% !important;
  }

  body.theme-black-vault .vault-meta-grid {
    margin-top: 0 !important;
  }
}


/* B47 MOBILE COMPACT IDENTITY FIX */
@media (max-width: 640px) {
  .vault-identity-top {
    min-height: 0 !important;
    padding-bottom: 112px !important;
  }

  .vault-identity-copy {
    max-width: 100% !important;
    padding-right: 0 !important;
  }

  .vault-name {
    font-size: clamp(2.55rem, 7.8vw, 3.7rem) !important;
    line-height: 0.96 !important;
  }

  .vault-email {
    white-space: nowrap !important;
    font-size: clamp(0.98rem, 3.6vw, 1.14rem) !important;
    line-height: 1.15 !important;
  }

  .vault-descriptor {
    max-width: 14ch !important;
    margin-top: 10px !important;
  }

  .vault-inline-logo-wrap {
    width: 96px !important;
    height: 96px !important;
    right: 12px !important;
    bottom: 10px !important;
    top: auto !important;
    left: auto !important;
    transform: none !important;
  }

  .vault-inline-logo {
    width: 96px !important;
    height: 96px !important;
    border-radius: 24px !important;
  }

  .vault-meta-grid {
    margin-top: 16px !important;
    gap: 18px !important;
  }
}


/* B48 MOBILE IDENTITY GRID-AREA HARD FIX */
@media (max-width: 480px) {
  .vault-identity-panel {
    padding: 22px 16px 18px !important;
  }

  .vault-identity-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 96px !important;
    grid-template-areas:
      "copy logo"
      "meta meta" !important;
    column-gap: 16px !important;
    row-gap: 12px !important;
    align-items: start !important;
    justify-items: stretch !important;
  }

  .vault-copy-stack {
    grid-area: copy !important;
    min-width: 0 !important;
    gap: 8px !important;
    margin: 0 !important;
    padding: 0 !important;
    align-self: start !important;
  }

  .vault-inline-logo-wrap {
    grid-area: logo !important;
    grid-column: auto !important;
    grid-row: auto !important;
    width: 96px !important;
    height: 96px !important;
    margin: 2px 0 0 !important;
    padding: 0 !important;
    align-self: start !important;
    justify-self: end !important;
    position: relative !important;
    top: 0 !important;
    right: 0 !important;
    transform: none !important;
  }

  .vault-inline-logo-wrap img {
    width: 96px !important;
    height: 96px !important;
    border-radius: 24px !important;
    object-fit: contain !important;
  }

  .vault-copy-stack .vault-identity-eyebrow,
  .vault-copy-stack h1,
  .vault-copy-stack .vault-identity-email,
  .vault-copy-stack .vault-identity-descriptor {
    margin: 0 !important;
  }

  .vault-copy-stack h1 {
    font-size: clamp(1.9rem, 7.8vw, 2.45rem) !important;
    line-height: 0.98 !important;
    max-width: none !important;
  }

  .vault-copy-stack .vault-identity-email {
    font-size: 0.96rem !important;
    line-height: 1.15 !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
  }

  .vault-copy-stack .vault-identity-descriptor {
    font-size: 0.84rem !important;
    line-height: 1.22 !important;
    letter-spacing: 0.24em !important;
    max-width: 11ch !important;
  }

  .vault-meta-grid {
    grid-area: meta !important;
    grid-column: auto !important;
    margin: 0 !important;
    padding: 0 !important;
    gap: 14px !important;
    align-self: start !important;
  }
}

@media (max-width: 390px) {
  .vault-identity-panel {
    padding: 20px 14px 16px !important;
  }

  .vault-identity-top {
    grid-template-columns: minmax(0, 1fr) 90px !important;
    column-gap: 14px !important;
    row-gap: 10px !important;
  }

  .vault-inline-logo-wrap,
  .vault-inline-logo-wrap img {
    width: 90px !important;
    height: 90px !important;
    border-radius: 22px !important;
  }

  .vault-copy-stack h1 {
    font-size: clamp(1.82rem, 7.4vw, 2.28rem) !important;
  }

  .vault-copy-stack .vault-identity-email {
    font-size: 0.93rem !important;
  }

  .vault-copy-stack .vault-identity-descriptor {
    font-size: 0.81rem !important;
    max-width: 10ch !important;
  }

  .vault-meta-grid {
    gap: 12px !important;
  }
}


/* B49 MOBILE IDENTITY SINGLE-COLUMN HARD FIX */
@media (max-width: 1024px) {
  body.theme-v31 .vault-identity-card {
    padding: 32px 22px 24px !important;
  }

  body.theme-v31 .vault-identity-panel {
    padding: 26px 22px 22px !important;
  }

  body.theme-v31 .vault-identity-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 132px !important;
    align-items: start !important;
    gap: 18px !important;
    min-height: auto !important;
    padding-bottom: 0 !important;
  }

  body.theme-v31 .vault-copy-stack {
    min-width: 0 !important;
    max-width: none !important;
    width: 100% !important;
    gap: 10px !important;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    position: static !important;
    inset: auto !important;
    width: 132px !important;
    min-width: 132px !important;
    max-width: 132px !important;
    height: 132px !important;
    justify-self: end !important;
    align-self: start !important;
    margin: 6px 0 0 !important;
  }

  body.theme-v31 .vault-inline-logo {
    width: 100% !important;
    height: 100% !important;
    object-fit: contain !important;
  }

  body.theme-v31 .vault-label {
    font-size: 0.86rem !important;
    letter-spacing: 0.42em !important;
  }

  body.theme-v31 .vault-name {
    font-size: clamp(2.45rem, 8.2vw, 3.35rem) !important;
    line-height: 0.96 !important;
    letter-spacing: -0.03em !important;
  }

  body.theme-v31 .vault-email {
    font-size: clamp(1rem, 4.8vw, 1.6rem) !important;
    line-height: 1.14 !important;
    overflow-wrap: anywhere !important;
    word-break: break-word !important;
  }

  body.theme-v31 .vault-descriptor {
    max-width: 14ch !important;
    font-size: 0.78rem !important;
    line-height: 1.34 !important;
    letter-spacing: 0.32em !important;
  }

  body.theme-v31 .vault-meta-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    grid-auto-flow: row !important;
    gap: 16px !important;
    width: 100% !important;
    max-width: none !important;
    margin-top: 22px !important;
    align-items: stretch !important;
    justify-items: stretch !important;
  }

  body.theme-v31 .vault-meta-card {
    display: flex !important;
    width: 100% !important;
    max-width: none !important;
    min-width: 0 !important;
    min-height: 136px !important;
    justify-self: stretch !important;
    align-self: stretch !important;
    box-sizing: border-box !important;
  }
}

@media (max-width: 640px) {
  body.theme-v31 .vault-identity-card {
    padding: 30px 20px 22px !important;
  }

  body.theme-v31 .vault-identity-panel {
    padding: 24px 20px 20px !important;
  }

  body.theme-v31 .vault-identity-top {
    grid-template-columns: minmax(0, 1fr) 116px !important;
    gap: 16px !important;
  }

  body.theme-v31 .vault-inline-logo-wrap {
    width: 116px !important;
    min-width: 116px !important;
    max-width: 116px !important;
    height: 116px !important;
    margin-top: 2px !important;
  }

  body.theme-v31 .vault-name {
    font-size: clamp(2.25rem, 10vw, 3rem) !important;
  }

  body.theme-v31 .vault-email {
    font-size: clamp(0.98rem, 5.6vw, 1.38rem) !important;
  }

  body.theme-v31 .vault-descriptor {
    max-width: 11ch !important;
    letter-spacing: 0.28em !important;
  }

  body.theme-v31 .vault-meta-grid {
    gap: 14px !important;
    margin-top: 20px !important;
  }

  body.theme-v31 .vault-meta-card {
    min-height: 128px !important;
  }
}

/* B51 MOBILE IDENTITY STACK LOCK */
@media (max-width: 560px) {
  .vault-identity-panel {
    padding: 22px 16px 18px !important;
  }

  .vault-identity-top {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 14px !important;
    position: relative !important;
    grid-template-columns: none !important;
    grid-template-areas: none !important;
  }

  .vault-copy-stack {
    order: 1 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    grid-area: auto !important;
    padding-right: 0 !important;
  }

  .vault-kicker {
    margin-bottom: 12px !important;
  }

  .vault-name {
    font-size: clamp(3rem, 11.8vw, 4rem) !important;
    line-height: 0.92 !important;
    letter-spacing: -0.045em !important;
    white-space: normal !important;
    max-width: 100% !important;
    margin-bottom: 10px !important;
  }

  .vault-email {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    font-size: 18px !important;
    line-height: 1.16 !important;
    letter-spacing: -0.015em !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    margin-bottom: 12px !important;
  }

  .vault-descriptor {
    display: block !important;
    max-width: 220px !important;
    font-size: 15px !important;
    line-height: 1.34 !important;
    letter-spacing: 0.34em !important;
    white-space: normal !important;
    overflow-wrap: anywhere !important;
  }

  .vault-inline-logo-wrap {
    order: 2 !important;
    position: relative !important;
    inset: auto !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;
    align-self: flex-end !important;
    justify-self: end !important;
    margin-top: -2px !important;
    grid-area: auto !important;
  }

  .vault-inline-logo {
    width: 108px !important;
    height: 108px !important;
    border-radius: 28px !important;
  }

  .vault-meta-grid {
    order: 3 !important;
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
    margin-top: 4px !important;
    grid-area: auto !important;
  }

  .vault-meta-card {
    min-height: 104px !important;
  }
}


/* B52 MOBILE COPYBLOCK LOCK
   Root fix: B51 stack intent was correct, but some live markup uses .vault-identity-copy
   instead of .vault-copy-stack, so the copy block was still inheriting narrow-width rules.
   This patch force-locks the actual live markup into a readable mobile stack. */
@media (max-width: 560px) {
  body.theme-black-vault .vault-identity-card,
  body.theme-v31 .vault-identity-card,
  .vault-identity-card {
    padding: 24px 16px 18px !important;
  }

  body.theme-black-vault .vault-identity-top,
  body.theme-v31 .vault-identity-top,
  .vault-identity-top {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 12px !important;
    grid-template-columns: none !important;
    grid-template-areas: none !important;
    min-height: 0 !important;
    padding-bottom: 0 !important;
    margin-bottom: 12px !important;
  }

  body.theme-black-vault .vault-identity-copy,
  body.theme-v31 .vault-identity-copy,
  .vault-identity-copy,
  body.theme-black-vault .vault-copy-stack,
  body.theme-v31 .vault-copy-stack,
  .vault-copy-stack {
    order: 1 !important;
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    flex: 0 0 auto !important;
    padding-right: 0 !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-kicker,
  body.theme-v31 .vault-kicker,
  .vault-kicker {
    margin: 0 0 10px 0 !important;
    font-size: 0.7rem !important;
    line-height: 1.2 !important;
    letter-spacing: 0.28em !important;
  }

  body.theme-black-vault .vault-name,
  body.theme-v31 .vault-name,
  .vault-name,
  body.theme-black-vault .vault-member-name,
  body.theme-v31 .vault-member-name,
  .vault-member-name {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
    font-size: clamp(2.15rem, 10.2vw, 2.95rem) !important;
    line-height: 0.94 !important;
    letter-spacing: -0.04em !important;
    margin: 0 0 8px 0 !important;
  }

  body.theme-black-vault .vault-email,
  body.theme-v31 .vault-email,
  .vault-email,
  body.theme-black-vault .vault-identity-email,
  body.theme-v31 .vault-identity-email,
  .vault-identity-email {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    word-break: break-word !important;
    overflow-wrap: anywhere !important;
    font-size: 0.96rem !important;
    line-height: 1.22 !important;
    letter-spacing: -0.01em !important;
    margin: 0 0 10px 0 !important;
  }

  body.theme-black-vault .vault-descriptor,
  body.theme-v31 .vault-descriptor,
  .vault-descriptor,
  body.theme-black-vault .vault-identity-descriptor,
  body.theme-v31 .vault-identity-descriptor,
  .vault-identity-descriptor {
    display: block !important;
    width: auto !important;
    max-width: 16rem !important;
    white-space: normal !important;
    word-break: normal !important;
    overflow-wrap: normal !important;
    text-wrap: balance !important;
    font-size: 0.7rem !important;
    line-height: 1.34 !important;
    letter-spacing: 0.18em !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap,
  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap {
    order: 2 !important;
    position: relative !important;
    inset: auto !important;
    top: auto !important;
    right: auto !important;
    bottom: auto !important;
    left: auto !important;
    transform: none !important;
    align-self: flex-end !important;
    justify-self: end !important;
    width: 92px !important;
    min-width: 92px !important;
    max-width: 92px !important;
    height: 92px !important;
    min-height: 92px !important;
    max-height: 92px !important;
    margin: 2px 0 0 0 !important;
    padding: 0 !important;
    border-radius: 22px !important;
  }

  body.theme-black-vault .vault-inline-logo,
  body.theme-v31 .vault-inline-logo,
  .vault-inline-logo,
  body.theme-black-vault .vault-inline-logo-wrap img,
  body.theme-v31 .vault-inline-logo-wrap img,
  .vault-inline-logo-wrap img {
    width: 92px !important;
    height: 92px !important;
    border-radius: 22px !important;
    object-fit: contain !important;
  }

  body.theme-black-vault .vault-meta-grid,
  body.theme-v31 .vault-meta-grid,
  .vault-meta-grid {
    order: 3 !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 12px !important;
    width: 100% !important;
    max-width: none !important;
    margin-top: 8px !important;
  }

  body.theme-black-vault .vault-meta-card,
  body.theme-v31 .vault-meta-card,
  .vault-meta-card {
    min-height: 96px !important;
    width: 100% !important;
    max-width: none !important;
  }
}

@media (max-width: 390px) {
  body.theme-black-vault .vault-identity-card,
  body.theme-v31 .vault-identity-card,
  .vault-identity-card {
    padding: 22px 14px 16px !important;
  }

  body.theme-black-vault .vault-name,
  body.theme-v31 .vault-name,
  .vault-name,
  body.theme-black-vault .vault-member-name,
  body.theme-v31 .vault-member-name,
  .vault-member-name {
    font-size: clamp(1.95rem, 9.6vw, 2.55rem) !important;
  }

  body.theme-black-vault .vault-email,
  body.theme-v31 .vault-email,
  .vault-email,
  body.theme-black-vault .vault-identity-email,
  body.theme-v31 .vault-identity-email,
  .vault-identity-email {
    font-size: 0.9rem !important;
  }

  body.theme-black-vault .vault-descriptor,
  body.theme-v31 .vault-descriptor,
  .vault-descriptor,
  body.theme-black-vault .vault-identity-descriptor,
  body.theme-v31 .vault-identity-descriptor,
  .vault-identity-descriptor {
    max-width: 14rem !important;
    font-size: 0.66rem !important;
    letter-spacing: 0.16em !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap,
  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap,
  body.theme-black-vault .vault-inline-logo,
  body.theme-v31 .vault-inline-logo,
  .vault-inline-logo,
  body.theme-black-vault .vault-inline-logo-wrap img,
  body.theme-v31 .vault-inline-logo-wrap img,
  .vault-inline-logo-wrap img {
    width: 84px !important;
    min-width: 84px !important;
    max-width: 84px !important;
    height: 84px !important;
    min-height: 84px !important;
    max-height: 84px !important;
    border-radius: 20px !important;
  }
}


/* B53 MOBILE HERO TIGHTEN
   Micro-polish only: reduce dead space, integrate the logo tighter,
   and keep the copy readable without falling back into clipping. */
@media (max-width: 560px) {
  body.theme-black-vault .vault-identity-card,
  body.theme-v31 .vault-identity-card,
  .vault-identity-card {
    padding: 24px 16px 18px !important;
  }

  body.theme-black-vault .vault-identity-top,
  body.theme-v31 .vault-identity-top,
  .vault-identity-top {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) 86px !important;
    column-gap: 14px !important;
    row-gap: 8px !important;
    align-items: start !important;
    margin-bottom: 8px !important;
  }

  body.theme-black-vault .vault-identity-copy,
  body.theme-v31 .vault-identity-copy,
  .vault-identity-copy,
  body.theme-black-vault .vault-copy-stack,
  body.theme-v31 .vault-copy-stack,
  .vault-copy-stack {
    grid-column: 1 !important;
    grid-row: 1 !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    padding-right: 0 !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-kicker,
  body.theme-v31 .vault-kicker,
  .vault-kicker {
    margin: 0 0 10px 0 !important;
  }

  body.theme-black-vault .vault-name,
  body.theme-v31 .vault-name,
  .vault-name,
  body.theme-black-vault .vault-member-name,
  body.theme-v31 .vault-member-name,
  .vault-member-name {
    font-size: clamp(2.05rem, 9.6vw, 2.7rem) !important;
    line-height: 0.94 !important;
    margin: 0 0 8px 0 !important;
  }

  body.theme-black-vault .vault-email,
  body.theme-v31 .vault-email,
  .vault-email,
  body.theme-black-vault .vault-identity-email,
  body.theme-v31 .vault-identity-email,
  .vault-identity-email {
    font-size: 0.94rem !important;
    line-height: 1.2 !important;
    margin: 0 0 8px 0 !important;
  }

  body.theme-black-vault .vault-descriptor,
  body.theme-v31 .vault-descriptor,
  .vault-descriptor,
  body.theme-black-vault .vault-identity-descriptor,
  body.theme-v31 .vault-identity-descriptor,
  .vault-identity-descriptor {
    max-width: 15rem !important;
    font-size: 0.69rem !important;
    line-height: 1.32 !important;
    letter-spacing: 0.17em !important;
    margin: 0 !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap,
  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap {
    grid-column: 2 !important;
    grid-row: 1 !important;
    align-self: start !important;
    justify-self: end !important;
    position: relative !important;
    inset: auto !important;
    width: 86px !important;
    min-width: 86px !important;
    max-width: 86px !important;
    height: 86px !important;
    min-height: 86px !important;
    max-height: 86px !important;
    margin: 6px 0 0 0 !important;
    padding: 0 !important;
    border-radius: 20px !important;
  }

  body.theme-black-vault .vault-inline-logo,
  body.theme-v31 .vault-inline-logo,
  .vault-inline-logo,
  body.theme-black-vault .vault-inline-logo-wrap img,
  body.theme-v31 .vault-inline-logo-wrap img,
  .vault-inline-logo-wrap img {
    width: 86px !important;
    height: 86px !important;
    border-radius: 20px !important;
  }

  body.theme-black-vault .vault-meta-grid,
  body.theme-v31 .vault-meta-grid,
  .vault-meta-grid {
    grid-column: 1 / -1 !important;
    order: initial !important;
    margin-top: 10px !important;
    gap: 12px !important;
  }

  body.theme-black-vault .vault-meta-card,
  body.theme-v31 .vault-meta-card,
  .vault-meta-card {
    min-height: 94px !important;
  }
}

@media (max-width: 390px) {
  body.theme-black-vault .vault-identity-top,
  body.theme-v31 .vault-identity-top,
  .vault-identity-top {
    grid-template-columns: minmax(0, 1fr) 80px !important;
    column-gap: 12px !important;
  }

  body.theme-black-vault .vault-name,
  body.theme-v31 .vault-name,
  .vault-name,
  body.theme-black-vault .vault-member-name,
  body.theme-v31 .vault-member-name,
  .vault-member-name {
    font-size: clamp(1.92rem, 9.1vw, 2.45rem) !important;
  }

  body.theme-black-vault .vault-email,
  body.theme-v31 .vault-email,
  .vault-email,
  body.theme-black-vault .vault-identity-email,
  body.theme-v31 .vault-identity-email,
  .vault-identity-email {
    font-size: 0.88rem !important;
  }

  body.theme-black-vault .vault-descriptor,
  body.theme-v31 .vault-descriptor,
  .vault-descriptor,
  body.theme-black-vault .vault-identity-descriptor,
  body.theme-v31 .vault-identity-descriptor,
  .vault-identity-descriptor {
    max-width: 13.5rem !important;
    font-size: 0.65rem !important;
  }

  body.theme-black-vault .vault-inline-logo-wrap,
  body.theme-v31 .vault-inline-logo-wrap,
  .vault-inline-logo-wrap,
  body.theme-black-vault .vault-inline-logo,
  body.theme-v31 .vault-inline-logo,
  .vault-inline-logo,
  body.theme-black-vault .vault-inline-logo-wrap img,
  body.theme-v31 .vault-inline-logo-wrap img,
  .vault-inline-logo-wrap img {
    width: 80px !important;
    min-width: 80px !important;
    max-width: 80px !important;
    height: 80px !important;
    min-height: 80px !important;
    max-height: 80px !important;
    border-radius: 19px !important;
  }
}
