/* responsive.css — Mobile-first responsive layout */
/* Virtfluencer v2: Feed bell badge glow */
.vf-feed-badge { background-image: linear-gradient(118deg,#1B4FD8,#2F8BFC,#44AFFF); box-shadow: 0 0 12px rgba(47,139,252,.6); }
html.dark .vf-feed-badge { box-shadow: 0 0 12px rgba(47,139,252,.75); }

/* Breakpoint: 768px (desktop/mobile divide) */

/* HAMBURGER NAV */

.nav-toggle {
  display: none;
  background: none;
  border: 0;
  cursor: pointer;
  padding: var(--space-2);
  font-size: var(--text-xl);
  color: var(--text-primary);
  line-height: 1;
}

/* Push opt-in overlay scoped to chat widget panel */
.vf-chat__panel { position: relative; }
.vf-push-overlay {
  position: absolute; left: 0; right: 0; bottom: 0; top: 56px; /* keep header clickable */
  display: flex; align-items: center; justify-content: center;
  padding: 16px;
  background: rgba(15,23,42,0.45); /* slate-900 ~ overlay */
  z-index: 60; /* above panel */
  border-bottom-left-radius: 12px; border-bottom-right-radius: 12px; /* match panel rounding */
}
html.dark .vf-push-overlay { background: rgba(0,0,0,0.55); }

.vf-push-card {
  width: calc(100% - 32px); max-width: 320px; min-width: 260px;
  background: #ffffff; color: #0B1426;
  border-radius: 14px; padding: 20px; box-shadow: 0 10px 30px rgba(0,0,0,0.25);
  border: 1px solid rgba(15,23,42,0.08);
}
html.dark .vf-push-card {
  background: #0B1426; color: #F4F7FC;
  border: 1px solid rgba(255,255,255,0.10);
}

.vf-push-card-title { display: flex; align-items: center; gap: 10px; font-weight: 700; font-size: 18px; color: #0B1426; }
html.dark .vf-push-card-title { color: #F4F7FC; }
.vf-push-card-title i, .vf-push-card-title svg { width: 20px; height: 20px; }

.vf-push-card-body { margin-top: 8px; font-size: 14px; line-height: 1.5; color: #475569; }
html.dark .vf-push-card-body { color: #cbd5e1; }

.vf-push-actions { margin-top: 14px; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.vf-push-btn-primary {
  appearance: none; border: none; cursor: pointer;
  background: #2F8BFC; color: #ffffff; font-weight: 600; font-size: 14px;
  padding: 10px 14px; border-radius: 10px;
}
.vf-push-btn-primary:hover { background: #1F4E79; }
.vf-push-btn-primary:focus { outline: 2px solid rgba(46,117,182,0.4); outline-offset: 2px; }

.vf-push-btn-secondary {
  appearance: none; cursor: pointer;
  background: transparent; color: #0B1426; font-weight: 600; font-size: 14px;
  padding: 10px 14px; border-radius: 10px; border: 1px solid rgba(15,23,42,0.20);
}
html.dark .vf-push-btn-secondary { color: #F4F7FC; border-color: rgba(255,255,255,0.20); }
.vf-push-btn-secondary:hover { background: rgba(15,23,42,0.05); }
html.dark .vf-push-btn-secondary:hover { background: rgba(255,255,255,0.06); }

.vf-push-btn-link {
  appearance: none; cursor: pointer; border: none; background: transparent;
  color: #64748b; font-weight: 600; font-size: 14px; padding: 8px 10px; border-radius: 8px;
}
.vf-push-btn-link:hover { color: #0B1426; }
html.dark .vf-push-btn-link { color: #94a3b8; }
html.dark .vf-push-btn-link:hover { color: #F4F7FC; }

/* Ensure the text column expands properly in rows (no narrow wrapping) */
.vf-feed-row > .vf-feed-mid,
.vf-feed-row .vf-feed-mid {
  flex: 1 1 auto;
  min-width: 0;
  width: 100%;
}

/* Dropdown list should be full width and use subtle separators */
#vf-feed-dropdown-list { width: 100%; }
#vf-feed-dropdown-list .vf-feed-row { width: 100%; }
#vf-feed-dropdown-list > * + * { border-top: 1px solid var(--border-default); }
html.dark #vf-feed-dropdown-list > * + * { border-top: 1px solid rgba(122,168,255,0.14); }

/* Bell badge: red, hidden by default; shown via .is-visible */
#vf-feed-bell { position: relative; }
.vf-feed-badge {
  display: none;
  position: absolute;
  top: -2px;
  right: -2px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 9999px;
  background: #ef4444; /* red */
  color: #ffffff;
  font-size: 10px;
  line-height: 16px;
  text-align: center;
  font-weight: 600;
  box-sizing: border-box;
  pointer-events: none;
}
.vf-feed-badge.is-visible { display: block; }

/* Chat launcher global badge (JS appends to .vf-chat__launcher) */
.vf-chat-badge {
  display: none;
  position: absolute;
  top: -4px;
  right: -4px;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 9999px;
  background: #ef4444; /* red */
  color: #ffffff;
  font-size: 10px;
  line-height: 16px;
  text-align: center;
  font-weight: 600;
  box-sizing: border-box;
  pointer-events: none;
}
.vf-chat-badge.is-visible { display: inline-block; }

/* Per-thread unread dot/count in thread list */
.vf-thread-unread {
  display: inline-block;
  min-width: 16px;
  height: 16px;
  padding: 0 4px;
  border-radius: 9999px;
  background: #ef4444;
  color: #ffffff;
  font-size: 10px;
  line-height: 16px;
  text-align: center;
  font-weight: 600;
}

/* Toast notifications (presence-aware in-app alerts) */
#vf-toast-stack {
  position: fixed;
  top: 16px;
  right: 16px;
  z-index: 1000;
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
}
.vf-toast {
  pointer-events: auto;
  min-width: 260px;
  max-width: 360px;
  background: #0b1220; /* dark glass base for consistency */
  color: var(--border-default);
  border: 1px solid rgba(148,163,184,0.25);
  border-radius: 10px;
  box-shadow: 0 6px 16px rgba(0,0,0,0.25);
  padding: 10px 12px;
  display: block;
  animation: vf-toast-in 180ms ease-out;
  cursor: pointer;
}
html.dark .vf-toast { background: rgba(12,19,34,0.92); border-color: rgba(255,255,255,0.18); color: #F4F7FC; }
body:not(.dark) .vf-toast { background: rgba(255,255,255,0.98); color: #0B1426; border-color: rgba(0,0,0,0.08); }
.vf-toast-title { font-weight: 600; font-size: 13px; margin-bottom: 2px; }
.vf-toast-body { font-size: 12px; opacity: 0.9; }
@keyframes vf-toast-in { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: translateY(0); } }

/* Chat settings view */
.vf-chat__settings { padding: 8px 0; height: 100%; overflow: auto; }
.vf-settings { padding: 8px 0; }
.vf-settings-header { display: flex; align-items: center; justify-content: space-between; padding: 8px 16px; border-bottom: 1px solid rgba(15,23,42,0.08); }
html.dark .vf-settings-header { border-bottom-color: rgba(255,255,255,0.10); }
.vf-settings-title { font-weight: 700; font-size: 16px; }
.vf-small-btn { appearance: none; border: 1px solid rgba(15,23,42,0.20); background: transparent; color: #0B1426; padding: 6px 10px; border-radius: 8px; font-size: 12px; cursor: pointer; }
.vf-small-btn:hover { background: rgba(15,23,42,0.05); }
html.dark .vf-small-btn { color: #F4F7FC; border-color: rgba(255,255,255,0.20); }
html.dark .vf-small-btn:hover { background: rgba(255,255,255,0.06); }
.vf-setting-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 12px 16px; border-bottom: 1px solid rgba(15,23,42,0.08); }
html.dark .vf-setting-row { border-bottom-color: rgba(255,255,255,0.10); }
.vf-setting-label { font-size: 14px; color: #0B1426; }
html.dark .vf-setting-label { color: #F4F7FC; }
.vf-setting-ctrls { display: inline-flex; align-items: center; gap: 10px; }
.vf-setting-note { font-size: 12px; color: #2F8BFC; }

/* Switch control */
.vf-switch { position: relative; display: inline-block; width: 38px; height: 22px; }
.vf-switch input { position: absolute; opacity: 0; width: 0; height: 0; }
.vf-switch .track { position: absolute; cursor: pointer; inset: 0; background: #cbd5e1; border: 1px solid rgba(15,23,42,0.20); border-radius: 999px; transition: background 0.2s ease, border-color 0.2s ease; }
html.dark .vf-switch .track { background: #334155; border-color: rgba(255,255,255,0.20); }
.vf-switch .thumb { position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; background: #ffffff; border-radius: 50%; transition: transform 0.2s ease; box-shadow: 0 1px 2px rgba(0,0,0,0.25); }
html.dark .vf-switch .thumb { background: #F4F7FC; }
.vf-switch input:checked + .track { background: #2F8BFC; border-color: rgba(46,117,182,0.80); }
html.dark .vf-switch input:checked + .track { background: #2F8BFC; border-color: rgba(46,117,182,0.80); }
.vf-switch input:checked + .track .thumb { transform: translateX(16px); }

/* Comment body wrapping fixes (handles long unbroken strings) */
.vf-comment-body {
  overflow-wrap: anywhere;
  word-break: break-word;
  min-width: 0;
}
/* Ensure bubble/container can shrink so the body wraps instead of overflowing */
.vf-comment-body, [data-comment-uuid] {
  max-width: 100%;
}

/* Bell dropdown panel subtle borders (avoid relying on Tailwind compile) */
.vf-feed-panel {
  position: fixed;
  top: 64px;
  left: 50%;
  transform: translateX(-50%);
  width: 1280px;
  max-width: calc(100vw - 3rem);
  border: 1px solid var(--border-default); /* slate-200 */
  z-index: 60;
}
html.dark .vf-feed-panel {
  border: 1px solid rgba(122,168,255,0.14); /* slate-800 */
}
.vf-feed-panel-header { border-bottom: 1px solid var(--border-default); }
html.dark .vf-feed-panel-header { border-bottom: 1px solid rgba(122,168,255,0.14); }
.vf-feed-panel-footer { border-top: 1px solid var(--border-default); }
html.dark .vf-feed-panel-footer { border-top: 1px solid rgba(122,168,255,0.14); }

/* ==========================================================
   ACTIVITY FEED ROWS (JS-rendered)
   Provide stable light/dark/hover styling without Tailwind build.
   ========================================================== */
.vf-feed-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  border-radius: 12px;
  border: 1px solid var(--border-default); /* slate-200 */
  background: #ffffff;       /* white */
  transition: background-color .15s ease, box-shadow .15s ease, border-color .15s ease;
}
html.dark .vf-feed-row {
  border-color: rgba(122,168,255,0.14); /* slate-800 */
  background: #0B1426;  /* slate-900 */
}
.vf-feed-row.is-unread {
  border-color: #a5f3fc;                 /* cyan-200 light */
  background: rgba(236, 254, 255, 0.60); /* cyan-50/60 light */
}
html.dark .vf-feed-row.is-unread {
  border-color: #155e75;                 /* cyan-800-ish for visibility in dark */
  background: rgba(8, 51, 68, 0.25);     /* faint cyan tint in dark */
}
.vf-feed-row.is-clickable { cursor: pointer; }
.vf-feed-row.is-clickable:hover {
  background: #F4F7FC; /* slate-50 light hover */
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
}
html.dark .vf-feed-row.is-clickable:hover {
  background: rgba(122,168,255,0.14); /* slate-800 dark hover */
  box-shadow: 0 2px 10px rgba(0,0,0,0.40);
}
.vf-feed-row:not(.is-clickable) { cursor: default; }

/* Compact variant for bell dropdown (borderless, tighter) */
.vf-feed-row.is-compact {
  padding: 10px 14px;
  border: none;
  border-radius: 0;
  gap: 10px;
}
.vf-feed-row.is-compact.is-unread { background: rgba(47,139,252,0.06); }
html.dark .vf-feed-row.is-compact.is-unread { background: rgba(47,139,252,0.08); }
.vf-feed-row.is-compact.is-clickable:hover { background: rgba(148,163,184,0.10); box-shadow: none; }
html.dark .vf-feed-row.is-compact.is-clickable:hover { background: rgba(148,163,184,0.12); box-shadow: none; }

/* Thumbnail and icon tile visuals */
.vf-feed-thumb {
  flex: 0 0 auto;
  width: 64px; height: 64px; /* default (page) */
  border-radius: 12px;
  overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  border: 1px solid var(--border-default); background: var(--bg-muted); /* slate-100 */
}
html.dark .vf-feed-thumb { border-color: #334155; background: #1f2937; }
.vf-feed-row.is-compact .vf-feed-thumb { width: 48px; height: 48px; border-radius: 10px; }
.vf-feed-thumb-img { width: 100%; height: 100%; object-fit: cover; display: block; }

/* When no media: gradient icon tile */
.vf-feed-icon-tile {
  background: linear-gradient(135deg, var(--bg-muted) 0%, var(--border-default) 100%);
  border: 1px solid var(--border-default);
}
html.dark .vf-feed-icon-tile {
  background: linear-gradient(135deg, #475569 0%, #334155 100%);
  border-color: #334155;
}
.vf-feed-icon { width: 24px; height: 24px; opacity: 0.9; }
.vf-icon-chevron { width: 16px; height: 16px; opacity: 0.6; }
.vf-icon-default { color: #64748b; } /* slate-500 */
.vf-icon-batch { color: #2F8BFC; }   /* cyan-500 light */
html.dark .vf-icon-batch { color: #44AFFF; } /* cyan-400 dark */
.vf-icon-comment { color: #64748b; }
.vf-icon-reaction { color: #fb923c; } /* orange-400 */


/* Comment actions (reactions + reply): hidden until the comment is clicked */
.vf-comment-actions {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-out, opacity 0.2s ease-out, margin-top 0.2s ease-out;
  margin-top: 0;
}
.vf-comment-actions.is-open {
  max-height: 80px;
  opacity: 1;
  margin-top: 8px;
}

/* Persistent reaction pills on comments (mirror chat) */
.vf-comment-reaction-pills {
  display: none;
  align-items: center;
  gap: 6px;
  position: absolute;
  bottom: -10px;
  right: 8px;
  z-index: 2;
}
.vf-comment-reaction-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  border: 1px solid rgba(0,0,0,0.10);
  border-radius: 999px;
  padding: 2px 8px;
  font-size: 12px;
  color: #475569;
  line-height: 1;
  background: #FFFFFF;
  box-shadow: 0 2px 6px rgba(0,0,0,0.08);
}
html.dark .vf-comment-reaction-pill {
  background: rgba(30, 41, 59, 0.95);
  border: 1px solid rgba(255,255,255,0.20);
  color: #ffffff;
  box-shadow: 0 2px 8px rgba(0,0,0,0.4);
  backdrop-filter: blur(8px);
}
.vf-comment-reaction-pill.is-mine { border-color: #2F8BFC; }

/* Comment reply banner (self-contained; used in inline + modal) */
.vf-comment-reply-ctx {
  flex: 0 0 auto;
  margin: 0;
  border-radius: 12px;
  background: rgba(47, 139, 252, 0.12);
  border: 1px solid rgba(47, 139, 252, 0.30);
  padding: 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.2s ease-out, opacity 0.2s ease-out, margin-top 0.2s ease-out, padding 0.2s ease-out;
}
.vf-comment-reply-ctx.is-open {
  max-height: 200px;
  opacity: 1;
  margin-top: 8px;
  padding: 8px 12px;
}
.vf-comment-reply-ctx .vf-chat__reply-ctx-row { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.vf-comment-reply-ctx .vf-chat__reply-ctx-left { display: inline-flex; align-items: center; gap: 6px; min-width: 0; font-size: 12px; color: #2F8BFC; }
.vf-comment-reply-ctx .vf-chat__reply-ctx-text {
  display: -webkit-box; -webkit-line-clamp: 2; line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden; color: #2F8BFC; line-height: 1.3; word-break: break-word;
}
html.dark .vf-comment-reply-ctx .vf-chat__reply-ctx-text { color: #38bdf8; }
.vf-comment-reply-ctx .vf-chat__reply-ctx-close { border: none; background: transparent; color: rgba(14,165,233,0.8); cursor: pointer; padding: 4px; border-radius: 8px; font-size: 14px; line-height: 1; }
.vf-comment-reply-ctx .vf-chat__reply-ctx-close:hover { color: rgba(14,165,233,1); }

/* Comment attachment preview (pending before send) */
.vf-comment-attach-preview {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.vf-comment-attach-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 10px;
  padding: 4px 8px;
  font-size: 12px;
  color: #0B1426;
  background: #ffffff;
}
html.dark .vf-comment-attach-chip {
  border-color: rgba(255,255,255,0.20);
  color: var(--border-default);
  background: rgba(30,41,59,0.85);
  backdrop-filter: blur(6px);
}
.vf-comment-attach-chip .thumb {
  width: 40px;
  height: 40px;
  object-fit: cover;
  border-radius: 6px;
  border: 1px solid rgba(0,0,0,0.08);
}
html.dark .vf-comment-attach-chip .thumb { border-color: rgba(255,255,255,0.16); }
.vf-comment-attach-chip .icon { opacity: 0.8; }
.vf-comment-attach-chip .name { max-width: 180px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vf-comment-attach-chip .size { color: #475569; }
html.dark .vf-comment-attach-chip .size { color: #94a3b8; }
.vf-comment-attach-chip .remove {
  border: 0;
  background: transparent;
  color: #64748b;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 2px 4px;
}
.vf-comment-attach-chip .remove:hover { color: #0B1426; }
html.dark .vf-comment-attach-chip .remove:hover { color: var(--border-default); }

/* Posted comment attachment gallery */
.vf-comment-attachment-gallery {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}
.vf-comment-attachment-img {
  position: relative;
  display: inline-block;
}
.vf-comment-attachment-thumb {
  display: block;
  max-width: 160px;
  max-height: 120px;
  object-fit: cover;
  border-radius: 8px;
  border: 1px solid rgba(0,0,0,0.10);
  background: #0b1220;
}
html.dark .vf-comment-attachment-thumb { border-color: rgba(255,255,255,0.18); }
.vf-comment-attachment-dl {
  position: absolute;
  top: 6px;
  right: 6px;
  background: rgba(15,23,42,0.65);
  color: var(--border-default);
  text-decoration: none;
  font-size: 12px;
  padding: 2px 6px;
  border-radius: 6px;
}
.vf-comment-attachment-dl:hover { background: rgba(15,23,42,0.85); }

.vf-comment-attachment-chip {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  border: 1px solid rgba(0,0,0,0.12);
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 12px;
  color: #0B1426;
  background: #ffffff;
  text-decoration: none;
}
html.dark .vf-comment-attachment-chip {
  border-color: rgba(255,255,255,0.20);
  color: var(--border-default);
  background: rgba(30,41,59,0.85);
  backdrop-filter: blur(6px);
}
.vf-comment-attachment-chip .icon { opacity: 0.9; }
.vf-comment-attachment-chip .name { max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.vf-comment-attachment-chip .size { color: #475569; }
html.dark .vf-comment-attachment-chip .size { color: #94a3b8; }

/* ==========================================================
   ACCOUNT MENU DROPDOWN
   Replaces the standalone Logout link in the top nav with a
   dropdown containing Account, Change Password, Logout.
   ========================================================== */

.account-menu {
  position: relative;
}

.account-menu-trigger {
  background: none;
  border: 0;
  cursor: pointer;
  color: var(--text-secondary);
  font-size: var(--text-base);
  padding: var(--space-2) var(--space-3);
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-family: inherit;
  line-height: 1.4;
  border-radius: var(--radius-sm);
}

body:not(.tailwind-active) .account-menu-trigger:hover {
  color: var(--accent);
  background: var(--bg-muted);
}

body:not(.tailwind-active) .account-menu-trigger[aria-expanded="true"] {
  color: var(--accent);
  background: var(--bg-muted);
}

.account-menu-chevron {
  width: 14px;
  height: 14px;
  transition: transform 0.15s ease;
}

.account-menu-trigger[aria-expanded="true"] .account-menu-chevron {
  transform: rotate(180deg);
}

.account-menu-name {
  font-weight: var(--font-medium);
}

.account-menu-dropdown {
  display: none;
  position: absolute;
  top: 100%;
  right: 0;
  min-width: 200px;
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-md);
  padding: var(--space-1) 0;
  margin: var(--space-1) 0 0 0;
  list-style: none;
  z-index: 100;
}

.account-menu-dropdown.is-open {
  display: block;
}

.account-menu-dropdown li {
  padding: 0;
  margin: 0;
  list-style: none;
}

.account-menu-dropdown li a {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  color: var(--text-primary);
  text-decoration: none;
  font-size: var(--text-sm);
  line-height: 1.4;
}

body:not(.tailwind-active) .account-menu-dropdown li a:hover {
  background: var(--bg-muted);
  color: var(--accent);
}

.account-menu-dropdown li a i,
.account-menu-dropdown li a [data-lucide] {
  width: 14px;
  height: 14px;
}

.account-menu-divider {
  height: 1px;
  background: var(--border-default);
  margin: var(--space-1) 0;
}

/* On mobile, the account menu lives inside the hamburger dropdown.
   Show the dropdown items inline rather than as a sub-dropdown. */
@media (max-width: 768px) {
  .account-menu {
    width: 100%;
  }
  
  .account-menu-trigger {
    display: none; /* Hide the trigger — items are shown inline below */
  }
  
  .account-menu-dropdown {
    display: block !important;
    position: static;
    border: 0;
    box-shadow: none;
    background: transparent;
    padding: 0;
    margin: 0;
    min-width: 0;
  }
  
  .account-menu-dropdown li a {
    padding: var(--space-3) var(--space-2);
    min-height: 44px;
    border-bottom: 1px solid var(--border-subtle);
  }
}

@media (max-width: 768px) {
  /* Safety net: any table without responsive-table class gets horizontal scroll
     instead of being squashed into vertical letter-stacked columns by PicoCSS. */
  main.layout table:not(.responsive-table) {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
    max-width: 100%;
  }

  main.layout table:not(.responsive-table) th,
  main.layout table:not(.responsive-table) td {
    white-space: nowrap;
  }
}

@media (max-width: 768px) {
  .nav-toggle {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 44px;
    min-height: 44px;
  }

  header.site-header nav { position: relative; }

  html body header.site-header nav ul.nav-right {
    display: none !important;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    background: var(--bg-elevated);
    border-bottom: 1px solid var(--border-default);
    box-shadow: var(--shadow-md);
    padding: var(--space-2) var(--space-4);
    margin: 0;
    gap: 0;
  }

  html body header.site-header nav ul.nav-right.is-open { display: flex !important; }

  html body header.site-header nav ul.nav-right li {
    padding: 0;
    width: 100%;
  }

  html body header.site-header nav ul.nav-right li a {
    display: block;
    padding: var(--space-3) var(--space-2);
    min-height: 44px;
    line-height: 1.4;
    border-bottom: 1px solid var(--border-subtle);
  }

  html body header.site-header nav ul.nav-right li:last-child a {
    border-bottom: 0;
  }
}

/* RESPONSIVE TABLES — CARD STACK */

@media (max-width: 768px) {
  table.responsive-table,
  table.responsive-table thead,
  table.responsive-table tbody,
  table.responsive-table tr,
  table.responsive-table th,
  table.responsive-table td {
    display: block;
    width: 100%;
    box-sizing: border-box;
  }

  table.responsive-table thead { display: none; }

  table.responsive-table tr {
    margin-bottom: var(--space-4);
    border: 1px solid var(--border-default);
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    padding: var(--space-3);
    box-shadow: var(--shadow-sm);
  }

  table.responsive-table td {
    border: 0;
    border-bottom: 1px solid var(--border-subtle);
    padding: var(--space-2) 0;
    text-align: left;
    position: relative;
    padding-left: 40%;
    min-height: 24px;
  }

  table.responsive-table td:last-child {
    border-bottom: 0;
    padding-bottom: 0;
  }

  table.responsive-table td:first-child { padding-top: 0; }

  table.responsive-table td::before {
    content: attr(data-label);
    position: absolute;
    left: 0;
    top: var(--space-2);
    width: 35%;
    font-weight: var(--font-medium);
    color: var(--text-secondary);
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
  }

  table.responsive-table td.actions {
    padding-left: 0;
    padding-top: var(--space-2);
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-2);
  }

  table.responsive-table td.actions::before { display: none; }

  /* Handle 2-column metadata-style tables where <th> is inside <tr> (not in <thead>) */
  table.responsive-table tr th {
    display: none;
  }

  table.responsive-table td.actions a[role="button"],
  table.responsive-table td.actions button {
    flex: 1 1 auto;
    min-height: 44px;
    padding: var(--space-3) var(--space-4);
    font-size: var(--text-sm);
    margin: 0;
  }

  table.responsive-table tr.empty-row td {
    padding-left: 0;
    text-align: center;
  }
  table.responsive-table tr.empty-row td::before { display: none; }
}

/* GENERAL MOBILE LAYOUT */

@media (max-width: 768px) {
  h1 { font-size: var(--text-2xl); }
  h2 { font-size: var(--text-xl); }
  h3 { font-size: var(--text-lg); }

  .container {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
  }

  .grid > form {
    flex-direction: column;
    align-items: stretch;
    width: 100%;
  }

  a[role="button"], button {
    min-height: 44px;
    padding: var(--space-3) var(--space-4);
  }

  form.status-filter {
    flex-direction: column !important;
    align-items: stretch !important;
    gap: var(--space-2) !important;
  }

  form.status-filter select { width: 100%; }
}

/* ==========================================================
   HYBRID OVERFLOW HANDLING (mobile only)
   - Long content never causes horizontal scroll on mobile
   - Different content types get different overflow treatments
   ========================================================== */

@media (max-width: 768px) {

  /* Global safety: nothing on mobile causes horizontal page scroll */
  html, body {
    overflow-x: hidden;
    max-width: 100%;
  }

  main.layout {
    max-width: 100%;
    overflow-x: hidden;
  }

  /* Card-stack table cells: long strings (URLs, emails, long IDs) wrap cleanly
     using overflow-wrap which respects word boundaries when possible
     but breaks long unbreakable strings instead of overflowing. */
  table.responsive-table td {
    overflow-wrap: anywhere;
    word-break: break-word;
    hyphens: auto;
  }

  /* Truncate-with-ellipsis utility class.
     Apply via class="truncate" to any element on mobile that should
     show "..." when content overflows rather than wrap.
     The full value remains in the DOM and is accessible via the
     title attribute or tap-to-expand. */
  .truncate {
    display: inline-block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: bottom;
  }

  /* Tap-to-expand pattern:
     An element with class="expandable" shows truncated by default.
     When the user taps (which toggles class "expanded" via JS),
     it wraps and shows the full content. */
  .expandable {
    display: inline-block;
    max-width: 100%;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    vertical-align: bottom;
    cursor: pointer;
    border-bottom: 1px dotted var(--text-tertiary);
  }

  .expandable.expanded {
    white-space: normal;
    overflow: visible;
    text-overflow: clip;
    overflow-wrap: anywhere;
    word-break: break-word;
    border-bottom-style: solid;
  }

  /* When mid-cell text contains "(email@example.com)" pattern
     wrapped in <span class="muted">, allow the muted email span
     to truncate cleanly. The email is supplementary because the
     full name is usually above it. */
  table.responsive-table td span.muted {
    display: inline-block;
    max-width: 100%;
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  /* For links inside cards: same wrapping rules so URLs don't overflow */
  table.responsive-table td a {
    overflow-wrap: anywhere;
    word-break: break-word;
  }

  /* Forms and form fields — never exceed viewport width on mobile */
  input, textarea, select, button {
    max-width: 100%;
    box-sizing: border-box;
  }

  /* Pre/code blocks — horizontal scroll inside the block, not the page */
  pre, code {
    max-width: 100%;
    overflow-x: auto;
    white-space: pre-wrap;
    word-break: break-word;
  }

  /* Images and videos — never exceed container */
  img, video {
    max-width: 100%;
    height: auto;
  }
}

/* ==========================================================
   DESKTOP TABLE DENSITY (>768px)
   Tighter buttons, denser rows, no wrapping in action cells.
   Applies to all admin/creator/reviewer tables.
   ========================================================== */

@media (min-width: 769px) {

  /* Action cells: inline-row layout, no wrapping */
  table td.actions,
  table th.actions {
    white-space: nowrap;
    text-align: right;
  }

  table td.actions {
    text-align: right;
    vertical-align: middle;
    white-space: nowrap;
  }

  table td.actions > a[role="button"],
  table td.actions > button {
    display: inline-block;
    vertical-align: middle;
    margin-left: var(--space-2);
  }

  table td.actions > a[role="button"]:first-child,
  table td.actions > button:first-child {
    margin-left: 0;
  }

  /* Compact buttons inside any table action cell */
  table td.actions a[role="button"],
  table td.actions button {
    min-height: 0;
    padding: 4px 10px;
    font-size: var(--text-xs);
    line-height: 1.4;
    margin: 0;
    white-space: nowrap;
    border-radius: var(--radius-sm);
  }

  /* Smaller icons inside compact buttons */
  table td.actions a[role="button"] svg,
  table td.actions button svg,
  table td.actions a[role="button"] [data-lucide],
  table td.actions button [data-lucide] {
    width: 14px;
    height: 14px;
    vertical-align: text-bottom;
    margin-right: 2px;
  }

  /* Denser table rows overall */
  main.layout table {
    font-size: var(--text-sm);
  }

  main.layout table th,
  main.layout table td {
    padding-top: var(--space-2);
    padding-bottom: var(--space-2);
    vertical-align: middle;
  }

  /* Compact headers */
  main.layout table thead th {
    font-size: var(--text-xs);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    font-weight: var(--font-semibold);
    color: var(--text-secondary);
    padding-top: var(--space-3);
    padding-bottom: var(--space-3);
  }

  /* Badges inside dense cells should be slightly smaller too */
  main.layout table .badge {
    font-size: 10px;
    padding: 1px 6px;
  }
}

.viewer-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-3);
  margin-bottom: var(--space-5);
}

.viewer-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: var(--space-4);
  box-shadow: var(--shadow-sm);
}

.caption-inline {
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  padding: var(--space-3);
}

.caption-inline .caption-actions {
  display: flex;
  gap: var(--space-2);
  margin-top: var(--space-2);
}

.caption-inline textarea {
  width: 100%;
  box-sizing: border-box;
}

/* Media gallery — Instagram-style uniform 1:1 grid */
.media-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: var(--space-3);
  margin: var(--space-3) 0;
}

.media-card {
  background: var(--bg-elevated);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  overflow: hidden;
  box-shadow: var(--shadow-sm);
  display: flex;
  flex-direction: column;
}

.media-card .thumb {
  display: block;
  background: var(--bg-muted);
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
}

.media-card .thumb img,
.media-card .thumb video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.media-card figcaption {
  padding: var(--space-2) var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  flex: 1;
  min-width: 0;
}

.media-card .filename {
  font-size: var(--text-xs);
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.media-card .media-actions {
  display: flex;
  gap: var(--space-1);
  margin-top: auto;
}

.media-card .media-actions a[role="button"] {
  flex: 1 1 0;
  min-width: 0;
  padding: 4px 6px;
  font-size: var(--text-xs);
  line-height: 1.4;
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-height: 0;
  border-radius: var(--radius-sm);
}

.media-card .media-actions a[role="button"] svg,
.media-card .media-actions a[role="button"] [data-lucide] {
  width: 12px;
  height: 12px;
  vertical-align: text-bottom;
  margin-right: 2px;
}

@media (max-width: 768px) {
  .media-grid {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 480px) {
  .media-grid {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================
   ACCOUNT MENU — Role Switcher additions
   ========================================================== */

.account-menu-section-label {
  padding: var(--space-1) var(--space-3);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--text-tertiary);
  font-weight: var(--font-medium);
  pointer-events: none;
}

.account-menu-role-btn {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  width: 100%;
  padding: var(--space-2) var(--space-3);
  background: none;
  border: 0;
  color: var(--text-primary);
  text-align: left;
  font-size: var(--text-sm);
  line-height: 1.4;
  cursor: pointer;
  font-family: inherit;
}

body:not(.tailwind-active) .account-menu-role-btn:hover {
  background: var(--bg-muted);
  color: var(--accent);
}

.account-menu-role-btn i,
.account-menu-role-btn [data-lucide] {
  width: 14px;
  height: 14px;
}

/* Admin user form — multi-role checkboxes */
.form-row ul#id_roles,
.form-row ul[id^="id_roles"] {
  list-style: none;
  padding: 0;
  margin: var(--space-1) 0;
}

.form-row ul#id_roles li,
.form-row ul[id^="id_roles"] li {
  padding: var(--space-1) 0;
}

.form-row ul#id_roles label,
.form-row ul[id^="id_roles"] label {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  cursor: pointer;
  font-weight: normal;
}
/* ==========================================================
   ACCOUNT MENU — Role Switcher spacing fixes
   ========================================================== */

/* Forms inside the dropdown menu must have zero margin */
.account-menu-dropdown form {
  margin: 0;
  padding: 0;
}

/* List items containing forms should also have zero padding/margin */
.account-menu-dropdown li {
  margin: 0;
}

/* The SWITCH ROLE section label should match the indent of other items */
.account-menu-section-label {
  padding: var(--space-2) var(--space-3) var(--space-1);
  margin: 0;
}

/* Role buttons inside forms — match the padding of regular menu links */
.account-menu-dropdown form .account-menu-role-btn {
  padding: var(--space-2) var(--space-3);
  margin: 0;
  width: 100%;
  box-sizing: border-box;
}

/* Mobile (≤768px): same fixes apply inside the hamburger menu */
@media (max-width: 768px) {
  .account-menu-dropdown form {
    margin: 0;
    padding: 0;
  }
  
}
/* ==========================================================
   ACCOUNT MENU — Focus styling
   Suppress browser default focus ring on mouse click while
   preserving keyboard accessibility via :focus-visible.
   ========================================================== */

/* The trigger button: hide outline on mouse focus, keep custom outline for keyboard focus */
.account-menu-trigger:focus {
  outline: none;
}

.account-menu-trigger:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
}

/* Dropdown menu links: same treatment */
.account-menu-dropdown li a:focus,
.account-menu-dropdown form .account-menu-role-btn:focus {
  outline: none;
}

.account-menu-dropdown li a:focus-visible,
.account-menu-dropdown form .account-menu-role-btn:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: -2px;
  background: var(--bg-muted);
}
/* ==========================================================
   ADMIN POST DETAIL — Inline Caption Editor
   Override PicoCSS button styling so caption looks like plain text by default.
   Frame only appears when actively editing.
   ========================================================== */

/* The display div has role="button" for keyboard accessibility, but should
   look like plain text in its idle state — NOT a button. */
.caption-editor .caption-display[role="button"] {
  display: inline-block;
  background: transparent;
  color: var(--text-primary);
  border: 0;
  padding: 0;
  margin: 0;
  font-size: inherit;
  font-weight: inherit;
  font-family: inherit;
  line-height: inherit;
  text-align: left;
  white-space: pre-wrap;
  word-break: break-word;
  cursor: text;
  min-height: 1.5em;
  width: 100%;
  box-shadow: none;
}

/* Subtle hover hint so users know it's clickable */
.caption-editor .caption-display[role="button"]:hover {
  background: transparent;
  color: var(--text-primary);
  box-shadow: none;
  border-bottom: 1px dotted var(--border-default);
  margin-bottom: -1px;
}

/* Keyboard focus: subtle outline for accessibility */
.caption-editor .caption-display[role="button"]:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  background: transparent;
}

/* When editing: the textarea is shown, the display is hidden */
.caption-editor .caption-input {
  display: none;
  width: 100%;
  padding: var(--space-3);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-md);
  background: var(--bg-elevated);
  font-family: inherit;
  font-size: inherit;
  line-height: 1.5;
  min-height: 80px;
  resize: vertical;
  box-sizing: border-box;
}

/* Edit mode: input shown via JS removing the hidden attribute */
.caption-editor .caption-input:not([hidden]) {
  display: block;
}

/* Hide display when editing */
.caption-editor .caption-display.is-editing {
  display: none;
}

/* Status label below the field */
.caption-editor .caption-status {
  font-size: var(--text-xs);
  margin-top: var(--space-1);
  display: block;
}

.caption-editor .caption-status.saving { color: var(--text-secondary); }
.caption-editor .caption-status.saved { color: var(--success); }
.caption-editor .caption-status.error { color: var(--danger); }

/* ==========================================================
   REVIEWER MEDIA DETAIL — Mobile header layout
   Stack title and action buttons vertically below 768px.
   Buttons arrange in a clean 2-column grid for thumb-friendly tap targets.
   ========================================================== */
@media (max-width: 768px) {
  .media-head {
    flex-wrap: wrap;
    align-items: flex-start;
  }

  .media-head .title {
    flex: 1 1 100%;
    min-width: 0;
    white-space: normal;
    word-break: normal;
    overflow-wrap: anywhere;
    margin-bottom: var(--space-3);
  }

  .media-head .actions {
    flex: 1 1 100%;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--space-2);
  }

  .media-head .actions a[role="button"],
  .media-head .actions button {
    padding: var(--space-2) var(--space-3);
    font-size: var(--text-sm);
    min-height: 40px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    text-align: center;
  }
}


/* === Virtfluencer v2: beam border + pixel dissolve === */
@property --vf-a { syntax: '<angle>'; initial-value: 0deg; inherits: false; }
.vf-beam { position: relative; }
.vf-beam::after {
  content: ""; position: absolute; inset: -1px; border-radius: inherit; padding: 1px;
  background: conic-gradient(from var(--vf-a), transparent 0%, #44AFFF 12%, #2F8BFC 22%, transparent 36%);
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude;
  opacity: 0; transition: opacity .3s; pointer-events: none;
}
.vf-beam:hover::after { opacity: 1; animation: vf-beam-spin 2.6s linear infinite; }
@keyframes vf-beam-spin { to { --vf-a: 360deg; } }
.vf-dissolve { display: inline-grid; grid-template-columns: repeat(6, 1fr); gap: 3px; line-height: 0; }
.vf-dissolve i { width: 5px; height: 5px; border-radius: 1px; background: #2F8BFC; opacity: 0; animation: vf-px 2.8s infinite; }
.vf-dissolve i:nth-child(1){animation-delay:0s;background:#1B4FD8}
.vf-dissolve i:nth-child(2){animation-delay:.25s}
.vf-dissolve i:nth-child(3){animation-delay:.1s;background:#44AFFF}
.vf-dissolve i:nth-child(4){animation-delay:.45s;background:#fff}
.vf-dissolve i:nth-child(5){animation-delay:.3s}
.vf-dissolve i:nth-child(6){animation-delay:.6s;background:#44AFFF}
.vf-dissolve i:nth-child(7){animation-delay:.4s;background:#fff}
.vf-dissolve i:nth-child(8){animation-delay:.15s;background:#1B4FD8}
.vf-dissolve i:nth-child(9){animation-delay:.55s}
.vf-dissolve i:nth-child(10){animation-delay:.7s;background:#44AFFF}
.vf-dissolve i:nth-child(11){animation-delay:.35s}
.vf-dissolve i:nth-child(12){animation-delay:.8s;background:#fff}
html:not(.dark) .vf-dissolve i:nth-child(4),
html:not(.dark) .vf-dissolve i:nth-child(7),
html:not(.dark) .vf-dissolve i:nth-child(12) { background: #1B4FD8; }
.vf-dissolve--corner { position: absolute; top: 14px; right: 14px; }
@keyframes vf-px { 0%,100% { opacity:.12; transform: translateY(0); } 40% { opacity:1; transform: translateY(-2px); } }
@media (prefers-reduced-motion: reduce) {
  .vf-dissolve i { animation: none; opacity: .8; }
  .vf-beam:hover::after { animation: none; opacity: .6; }
}

/* === Virtfluencer v2 chrome: nav, dropdowns, pills, account chip === */
.vf-nav-item{position:relative;display:inline-flex;align-items:center;gap:6px;padding:8px 13px;border-radius:9px;font-size:13.5px;font-weight:500;color:var(--text-secondary);cursor:pointer;border:none;background:none;font-family:var(--font-sans);transition:color .15s,background .15s;text-decoration:none;line-height:1.2}
.vf-nav-item:hover{color:var(--text-primary);background:var(--bg-muted)}
.vf-nav-item.on{color:var(--text-primary)}
.vf-nav-item.on::after{content:"";position:absolute;left:13px;right:13px;bottom:1px;height:2px;border-radius:2px;background:var(--vf-grad)}
.vf-chev{width:13px;height:13px;opacity:.7;transition:transform .18s}
.vf-nav-dd{position:relative;list-style:none}
.vf-nav-dd.open>.vf-nav-item{color:var(--text-primary);background:var(--bg-muted)}
.vf-nav-dd.open .vf-chev{transform:rotate(180deg)}
.vf-dd{position:absolute;top:calc(100% + 10px);left:0;min-width:240px;background:var(--bg-elevated);border:1px solid var(--border-default);border-radius:14px;box-shadow:var(--shadow-lg);padding:7px;opacity:0;transform:translateY(-6px);pointer-events:none;transition:opacity .18s,transform .18s;z-index:60;margin:0;list-style:none}
.vf-nav-dd.open .vf-dd,.vf-dd.is-open{opacity:1;transform:none;pointer-events:auto}
.vf-dd-label{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--text-tertiary);padding:8px 11px 5px;list-style:none}
.vf-dd-item{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;font-size:13.5px;color:var(--text-secondary);cursor:pointer;text-decoration:none;transition:background .12s,color .12s;border:none;background:none;width:100%;text-align:left;font-family:var(--font-sans);box-sizing:border-box}
.vf-dd-item:hover{background:var(--accent-bg);color:var(--text-primary)}
.vf-dd-item .lucide{width:15px;height:15px;color:var(--text-tertiary);flex-shrink:0;transition:color .12s}
.vf-dd-item:hover .lucide{color:var(--accent-hover)}
.vf-dd-item--danger{color:#F87171}
.vf-dd-item--danger:hover{background:rgba(248,113,113,.10);color:#F87171}
.vf-dd-item--danger .lucide,.vf-dd-item--danger:hover .lucide{color:#F87171}
.vf-dd-divider{height:1px;background:var(--border-subtle);margin:6px 8px}
.vf-dd li{list-style:none}
.vf-pills{display:inline-flex;align-items:center;gap:2px;background:var(--bg-muted);border:1px solid var(--border-default);border-radius:9px;padding:3px}
.vf-pill{border:none;background:none;font-family:var(--font-mono);font-size:10px;letter-spacing:.05em;color:var(--text-tertiary);padding:5px 9px;border-radius:7px;cursor:pointer;transition:color .15s}
.vf-pill:hover{color:var(--text-primary)}
.vf-pill.on{color:#fff;background-image:var(--vf-grad);box-shadow:0 2px 10px -2px rgba(47,139,252,.5)}
.vf-bell-btn{position:relative;width:36px;height:36px;border-radius:10px;border:1px solid var(--border-default);background:var(--bg-elevated);display:grid;place-items:center;cursor:pointer;transition:border-color .15s}
.vf-bell-btn:hover{border-color:var(--border-strong)}
.vf-acct-chip{display:inline-flex;align-items:center;gap:9px;padding:5px 11px 5px 5px;border:1px solid var(--border-default);border-radius:11px;background:var(--bg-elevated);cursor:pointer;transition:border-color .15s;font-family:var(--font-sans)}
.vf-acct-chip:hover{border-color:var(--border-strong)}
.vf-avp{width:26px;height:26px;border-radius:8px;background-image:var(--vf-grad);display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:11.5px}
.vf-acct-em{font-size:12.5px;color:var(--text-secondary);max-width:170px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.account-menu-dropdown.vf-dd{left:auto;right:0;min-width:230px;display:block;padding:7px}
/* === hover-gated dissolve === */
.vf-card .vf-dissolve--corner,.sys-card .vf-dissolve{opacity:0;transition:opacity .25s ease}
.vf-card:hover .vf-dissolve--corner,.sys-card:hover .vf-dissolve{opacity:1}
.vf-card .vf-dissolve--corner i,.sys-card .vf-dissolve i{animation-play-state:paused}
.vf-card:hover .vf-dissolve--corner i,.sys-card:hover .vf-dissolve i{animation-play-state:running}

/* native select: keep arrow visible, contain focus glow */
select.vf-input{ -webkit-appearance:auto; appearance:auto; background-image:none; padding-right:2rem; }
select.vf-input:focus{ box-shadow:0 0 0 3px rgba(68,175,255,.18); }

/* === P1 Publisher Cockpit (showcase) ============================== */
/* Layout shell: ready-rail | composer | preflight-rail */
.ck-shell{display:grid;grid-template-columns:290px minmax(0,1fr) 320px;gap:16px;align-items:start}
@media (max-width:1180px){.ck-shell{grid-template-columns:1fr}}
.ck-panel{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md)}
.ck-panel-h{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-subtle);font-family:var(--font-display);font-weight:600;font-size:14px;color:var(--text-primary)}
.ck-panel-b{padding:14px 16px;display:grid;gap:12px}
.ck-count{font-family:var(--font-mono);font-size:10.5px;color:var(--text-tertiary);letter-spacing:.05em}

/* Section scaffolding for the showcase page itself */
.ck-sec{margin-bottom:48px}
.ck-sec-t{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text-primary);letter-spacing:-.015em}
.ck-sec-d{font-size:13px;color:var(--text-secondary);margin:4px 0 16px;max-width:78ch;line-height:1.55}
.ck-sec-d b{color:var(--text-primary)}

/* Account-health strip */
.ck-accts{display:grid;grid-template-columns:repeat(auto-fit,minmax(225px,1fr));gap:12px}
.ck-acct{display:flex;align-items:center;gap:11px;padding:11px 13px;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);transition:border-color .15s;min-width:0}
.ck-acct:hover{border-color:var(--border-strong)}
.ck-acct-av{width:36px;height:36px;border-radius:10px;display:grid;place-items:center;color:#fff;font-family:var(--font-display);font-weight:700;font-size:13px;flex:none}
.ck-acct-name{font-size:13px;font-weight:600;color:var(--text-primary);line-height:1.25;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ck-acct-sub{font-size:11.5px;color:var(--text-tertiary);display:flex;align-items:flex-start;gap:5px;line-height:1.45;margin-top:1px}
.ck-acct-sub .ck-dot{margin-top:5px}
.ck-grow{flex:1;min-width:0}
.ck-dot{width:7px;height:7px;border-radius:99px;flex:none}
.ck-dot.is-healthy{background:var(--success);box-shadow:0 0 0 3px rgba(52,211,153,.16)}
.ck-dot.is-expiring{background:var(--warning);box-shadow:0 0 0 3px rgba(245,158,11,.16)}
.ck-dot.is-reauth{background:var(--danger);box-shadow:0 0 0 3px rgba(248,113,113,.20);animation:ck-pulse 1.6s infinite}
.ck-dot.is-revoked{background:var(--text-tertiary)}
@keyframes ck-pulse{50%{box-shadow:0 0 0 6px rgba(248,113,113,.05)}}
.ck-reconnect{margin-left:auto;flex:none;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.04em;color:#fff;background-image:var(--vf-grad);border:none;border-radius:8px;padding:6px 10px;cursor:pointer;box-shadow:0 3px 12px -3px rgba(47,139,252,.5)}
.ck-reconnect:hover{filter:brightness(1.08)}

/* Platform brand chips */
.ck-pf{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;font-weight:600;letter-spacing:.03em;padding:3px 8px;border-radius:7px;border:1px solid var(--border-default);color:var(--text-secondary);background:var(--bg-elevated)}
.ck-pf-dot{width:8px;height:8px;border-radius:3px;flex:none}
.ck-pf--ig .ck-pf-dot{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
.ck-pf--fb .ck-pf-dot{background:#1877F2}
.ck-pf--tt .ck-pf-dot{background:linear-gradient(135deg,#00F2EA,#FF0050)}
.ck-pf--fv .ck-pf-dot{background:#0CC0DF}

/* Ready-to-publish rail */
.ck-item{display:flex;gap:11px;padding:11px;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-elevated);cursor:pointer;transition:border-color .15s,box-shadow .15s}
.ck-item:hover{border-color:var(--border-strong)}
.ck-item.is-active{border-color:var(--accent-border);box-shadow:var(--vf-glow)}
.ck-thumbs{display:flex;flex:none}
.ck-thumb{width:44px;height:44px;border-radius:9px;border:2px solid var(--bg-surface);background-image:var(--vf-grad);display:grid;place-items:center;color:#fff;font-family:var(--font-mono);font-size:9.5px;position:relative;flex:none}
.ck-thumb+.ck-thumb{margin-left:-15px}
.ck-thumb--b{background:linear-gradient(135deg,#DD2A7B,#8134AF)}
.ck-thumb--c{background:linear-gradient(135deg,#0CC0DF,#1B4FD8)}
.ck-thumb--d{background:linear-gradient(135deg,#0F766E,#34D399)}
.ck-item-t{font-size:12.5px;font-weight:600;color:var(--text-primary);line-height:1.3}
.ck-item-m{font-size:11px;color:var(--text-tertiary);margin-top:2px;line-height:1.4}

/* Composer platform tabs */
.ck-tabs{display:flex;gap:5px;padding:5px;background:var(--bg-muted);border-radius:11px;border:1px solid var(--border-default)}
.ck-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:7px;padding:8px 10px;border-radius:8px;border:none;background:none;font-family:var(--font-display);font-weight:600;font-size:12.5px;color:var(--text-tertiary);cursor:pointer;transition:color .15s,background .15s;white-space:nowrap}
.ck-tab:hover{color:var(--text-primary)}
.ck-tab.is-active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-md)}
.ck-tab .ck-pf-dot{width:9px;height:9px}

/* Composer fields */
.ck-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:640px){.ck-row{grid-template-columns:1fr}}
.ck-lblrow{display:flex;align-items:baseline;justify-content:space-between;gap:8px}
.ck-counter{font-family:var(--font-mono);font-size:10.5px;color:var(--text-tertiary)}
.ck-counter.is-over{color:var(--danger);font-weight:600}
.ck-note{display:flex;gap:9px;padding:10px 12px;border-radius:var(--radius-sm);font-size:12px;line-height:1.5;border:1px solid var(--accent-border);background:var(--accent-bg);color:var(--text-secondary)}
.ck-note b{color:var(--text-primary)}
.ck-note--warn{border-color:var(--warning-border);background:rgba(245,158,11,.08)}
.ck-note--lock{border-color:var(--danger-border);background:rgba(248,113,113,.07)}
.ck-note-ic{flex:none;width:16px;text-align:center}

/* Composer media strip */
.ck-media{display:flex;gap:8px;flex-wrap:wrap}
.ck-media .ck-thumb{width:64px;height:64px;border-radius:10px;border:1px solid var(--border-default);margin-left:0}
.ck-media-badge{position:absolute;bottom:4px;right:4px;font-size:9px;font-family:var(--font-mono);background:rgba(7,11,20,.72);color:#fff;border-radius:5px;padding:1px 5px;line-height:1.5}

/* Segmented control (privacy / audience / placement) */
.ck-seg{display:inline-flex;background:var(--bg-muted);border:1px solid var(--border-default);border-radius:9px;padding:3px;gap:2px;flex-wrap:wrap}
.ck-seg-opt{border:none;background:none;font-family:var(--font-sans);font-size:12px;font-weight:500;color:var(--text-tertiary);padding:6px 12px;border-radius:7px;cursor:pointer;transition:color .15s,background .15s}
.ck-seg-opt:hover{color:var(--text-primary)}
.ck-seg-opt.is-active{background:var(--bg-surface);color:var(--text-primary);box-shadow:var(--shadow-sm)}
.ck-seg-opt.is-locked{opacity:.4;cursor:not-allowed;text-decoration:line-through}

/* TikTok creator strip (mandated by their UX audit) */
.ck-creator{display:flex;align-items:center;gap:10px;padding:9px 12px;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-elevated)}
.ck-creator-n{font-size:12.5px;font-weight:600;color:var(--text-primary)}
.ck-creator-s{font-size:11px;color:var(--text-tertiary)}

/* Pre-flight checklist */
.ck-check{display:flex;gap:9px;align-items:flex-start;padding:8px 10px;border-radius:9px;font-size:12.5px;line-height:1.45;color:var(--text-secondary)}
.ck-check b{color:var(--text-primary);font-weight:600}
.ck-check-ic{flex:none;width:18px;height:18px;border-radius:99px;display:grid;place-items:center;font-size:10px;font-weight:700;color:#fff;margin-top:1px}
.ck-check.is-pass .ck-check-ic{background:var(--success)}
.ck-check.is-warn .ck-check-ic{background:var(--warning)}
.ck-check.is-fail .ck-check-ic{background:var(--danger)}
.ck-check.is-fail{background:rgba(248,113,113,.06);border:1px solid var(--danger-border)}
.ck-check.is-warn{background:rgba(245,158,11,.06)}

/* Schedule options */
.ck-sched-opt{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-default);border-radius:var(--radius-sm);cursor:pointer;font-size:12.5px;color:var(--text-secondary);transition:border-color .15s,background .15s}
.ck-sched-opt:hover{border-color:var(--border-strong)}
.ck-sched-opt.is-active{border-color:var(--accent-border);background:var(--accent-bg);color:var(--text-primary)}
.ck-radio{width:14px;height:14px;border-radius:99px;border:2px solid var(--border-strong);flex:none}
.ck-sched-opt.is-active .ck-radio{border-color:var(--accent);background:radial-gradient(circle at center,var(--accent) 42%,transparent 50%)}
.ck-sched-sub{font-size:11px;color:var(--text-tertiary);margin-top:1px}

/* Publish CTA */
.ck-publish{width:100%;display:flex;align-items:center;justify-content:center;gap:9px;padding:12px;border:none;border-radius:11px;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px;letter-spacing:-.01em;cursor:pointer;box-shadow:0 6px 22px -6px rgba(47,139,252,.55);transition:filter .15s}
.ck-publish:hover{filter:brightness(1.07)}
.ck-publish:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

/* Queue timeline */
.ck-day{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);margin:16px 0 8px}
.ck-day:first-child{margin-top:0}
.ck-q{display:flex;align-items:center;gap:12px;padding:11px 14px;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-elevated);min-width:0}
.ck-q+.ck-q{margin-top:8px}
.ck-q-time{font-family:var(--font-mono);font-size:11.5px;color:var(--text-secondary);width:62px;flex:none}
.ck-q-t{font-size:12.5px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ck-q-m{font-size:11px;color:var(--text-tertiary);margin-top:1px}
.ck-st{display:inline-flex;align-items:center;gap:6px;font-size:11px;font-weight:600;padding:3px 9px;border-radius:99px;border:1px solid;white-space:nowrap;flex:none}
.ck-st--scheduled{color:var(--badge-pending-text);background:var(--badge-pending-bg);border-color:var(--badge-pending-border)}
.ck-st--publishing{color:var(--badge-needs-revision-text);background:var(--badge-needs-revision-bg);border-color:var(--badge-needs-revision-border)}
.ck-st--published{color:var(--badge-accepted-text);background:var(--badge-accepted-bg);border-color:var(--badge-accepted-border)}
.ck-st--failed{color:var(--badge-rejected-text);background:var(--badge-rejected-bg);border-color:var(--badge-rejected-border)}
html.dark .ck-st--publishing{background:rgba(245,158,11,.10)}
html.dark .ck-st--published{background:rgba(52,211,153,.10)}
html.dark .ck-st--failed{background:rgba(248,113,113,.10)}
html.dark .ck-st--scheduled{background:rgba(47,139,252,.12)}
.ck-retry{font-size:11px;font-weight:600;color:var(--accent);background:none;border:1px solid var(--accent-border);border-radius:7px;padding:4px 10px;cursor:pointer;flex:none}
.ck-retry:hover{background:var(--accent-bg)}
.ck-err{font-size:11px;color:var(--danger);margin-top:2px}
.ck-spin{width:11px;height:11px;border:2px solid currentColor;border-top-color:transparent;border-radius:99px;animation:ck-rot .7s linear infinite;display:inline-block;flex:none}
@keyframes ck-rot{to{transform:rotate(360deg)}}
.ck-ext{font-family:var(--font-mono);font-size:10.5px;color:var(--accent);text-decoration:none}
.ck-ext:hover{text-decoration:underline}

/* Data-shape code block */
.ck-code{font-family:var(--font-mono);font-size:11.5px;line-height:1.65;background:#0b1020;color:#c9d1d9;border-radius:var(--radius-md);padding:16px 18px;overflow-x:auto;border:1px solid rgba(122,168,255,.18)}
.ck-code .k{color:#44AFFF}
.ck-code .s{color:#7CC0FF}
.ck-code .c{color:#5B6B8C;font-style:italic}

/* Cockpit platform colors (slug-addressed; shared by dots + avatars) */
[data-pf-dot="instagram"],[data-pf-av="instagram"]{background:linear-gradient(45deg,#F58529,#DD2A7B,#8134AF)}
[data-pf-dot="facebook"],[data-pf-av="facebook"]{background:#1877F2}
[data-pf-dot="tiktok"],[data-pf-av="tiktok"]{background:linear-gradient(135deg,#00F2EA 0%,#111 55%,#FF0050 100%)}
[data-pf-dot="fanvue"],[data-pf-av="fanvue"]{background:#0CC0DF}

/* === Deals: cap-table allocation bar === */
.dl-bar{display:flex;height:14px;border-radius:99px;overflow:hidden;background:var(--bg-muted);border:1px solid var(--border-default)}
.dl-bar-seg{flex:none}
.dl-bar-a{background-image:var(--vf-grad)}
.dl-bar-b{background:var(--accent-hover);opacity:.75}

/* === Registration / join — the front door ============================== */
.rg-shell{max-width:680px}
.rg-eyebrow{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:600}
.rg-title{font-family:var(--font-display);font-weight:700;font-size:26px;letter-spacing:-.02em;color:var(--text-primary);margin-top:5px;line-height:1.1}
.rg-sub{font-size:13.5px;color:var(--text-secondary);line-height:1.5;margin-top:8px;max-width:50ch}
.rg-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:540px){.rg-row{grid-template-columns:1fr}}
.rg-section-label{font-size:12.5px;font-weight:600;color:var(--text-primary);margin:22px 0 11px}
.rg-section-label span{font-family:var(--font-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);font-weight:500;margin-left:7px}
.rg-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px}
@media (max-width:540px){.rg-grid{grid-template-columns:1fr}}
.rg-role{position:relative;display:flex;gap:12px;padding:14px;border:1.5px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-elevated);cursor:pointer;transition:border-color .18s,box-shadow .18s,background .18s,transform .12s}
.rg-role:hover{border-color:var(--border-strong);transform:translateY(-1px)}
.rg-role input{position:absolute;opacity:0;width:0;height:0;pointer-events:none}
.rg-role:has(input:checked){border-color:transparent;background:var(--accent-bg);box-shadow:var(--vf-glow)}
.rg-role:has(input:checked)::before{content:"";position:absolute;inset:0;border-radius:var(--radius-md);padding:1.5px;background:var(--vf-grad);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;pointer-events:none}
.rg-role:has(input:focus-visible){border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.rg-role-ic{width:42px;height:42px;border-radius:12px;flex:none;display:grid;place-items:center;background:var(--bg-muted);color:var(--text-tertiary);transition:background .18s,color .18s,box-shadow .18s}
.rg-role-ic svg{width:20px;height:20px}
.rg-role:has(input:checked) .rg-role-ic{background-image:var(--vf-grad);color:#fff;box-shadow:0 6px 16px -5px rgba(47,139,252,.6)}
.rg-role-body{min-width:0;display:flex;flex-direction:column;padding-right:14px}
.rg-role-title{font-family:var(--font-display);font-weight:700;font-size:14.5px;color:var(--text-primary);line-height:1.15}
.rg-role-tag{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.09em;text-transform:uppercase;color:var(--accent);margin-top:2px;font-weight:600}
.rg-role-desc{font-size:11.5px;color:var(--text-secondary);line-height:1.42;margin-top:6px}
.rg-role-check{position:absolute;top:11px;right:11px;width:18px;height:18px;border-radius:99px;border:1.5px solid var(--border-strong);display:grid;place-items:center;color:transparent;opacity:.4;transition:opacity .18s,background .18s,border-color .18s}
.rg-role-check svg{width:11px;height:11px}
.rg-role:has(input:checked) .rg-role-check{opacity:1;border-color:transparent;background-image:var(--vf-grad);color:#fff}
.rg-submit{width:100%;display:flex;align-items:center;justify-content:center;gap:9px;padding:13px;margin-top:24px;border:none;border-radius:12px;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:14.5px;letter-spacing:-.01em;cursor:pointer;box-shadow:0 8px 24px -8px rgba(47,139,252,.6);transition:filter .15s,transform .12s}
.rg-submit:hover{filter:brightness(1.07);transform:translateY(-1px)}
.rg-submit svg{width:17px;height:17px}
.rg-fineprint{font-size:11px;color:var(--text-tertiary);text-align:center;margin-top:13px}
.rg-fineprint a{color:var(--text-secondary);text-decoration:underline}
.rg-signin{font-size:13px;color:var(--text-secondary);text-align:center;margin-top:18px}
.rg-signin a{color:var(--accent);font-weight:600}
.rg-signin a:hover{text-decoration:underline}

/* === Email verification (OTP) ========================================= */
.otp-icon{width:54px;height:54px;border-radius:15px;margin:0 auto;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;box-shadow:0 8px 22px -6px rgba(47,139,252,.55)}
.otp-icon svg{width:26px;height:26px}
.otp-boxes{display:flex;gap:9px;justify-content:center}
.otp-box{width:46px;height:56px;text-align:center;font-family:var(--font-mono);font-size:24px;font-weight:600;color:var(--text-primary);background:var(--bg-elevated);border:1.5px solid var(--border-default);border-radius:12px;transition:border-color .15s,box-shadow .15s;caret-color:var(--accent)}
@media (max-width:400px){.otp-box{width:42px;height:52px;font-size:21px}}
.otp-box:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}
.otp-box:not(:placeholder-shown),.otp-box[value]:not([value=""]){border-color:var(--border-strong)}
.otp-resend{font-size:13px;color:var(--text-secondary);margin-top:18px}
.otp-link{background:none;border:none;color:var(--accent);font-weight:600;font-size:13px;cursor:pointer;padding:0;font-family:var(--font-sans)}
.otp-link:hover{text-decoration:underline}

/* === Password requirements meter ====================================== */
.pw-meter{display:grid;gap:6px;margin-top:12px;padding:12px 14px;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);background:var(--bg-muted)}
.pw-req{font-size:11.5px;color:var(--text-tertiary);display:flex;align-items:center;gap:8px;line-height:1.3;transition:color .15s}
.pw-req::before{content:"○";font-size:11px;width:13px;text-align:center;flex:none}
.pw-req.is-ok{color:var(--text-secondary)}
.pw-req.is-ok::before{content:"✓";color:var(--success);font-weight:700}
.pw-meter.show-errors .pw-req:not(.is-ok){color:var(--danger)}
.pw-meter.show-errors .pw-req:not(.is-ok)::before{color:var(--danger)}

/* === Account menu: "logged in as" current-role indicator ============== */
.vf-role-now{display:flex;flex-direction:column;align-items:center;gap:6px;padding:9px 8px 5px;text-align:center}
.vf-role-now-label{font-family:var(--font-mono);font-size:9px;letter-spacing:.16em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600}
.vf-role-now-pill{font-family:var(--font-display);font-weight:700;font-size:13px;color:#fff;background-image:var(--vf-grad);padding:5px 18px;border-radius:999px;box-shadow:0 4px 14px -4px rgba(47,139,252,.55);text-transform:capitalize;letter-spacing:.01em}

/* === Public profile (pp-*) — how a member presents to the world ======= */
.pp-hero{padding:26px 28px}
.pp-hero-row{display:flex;gap:20px;align-items:flex-start}
@media (max-width:560px){.pp-hero-row{flex-direction:column;align-items:center;text-align:center}}
.pp-avatar{width:88px;height:88px;border-radius:24px;flex:none;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:38px;box-shadow:0 12px 32px -10px rgba(47,139,252,.6)}
.pp-hero-main{min-width:0;flex:1}
.pp-name-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
@media (max-width:560px){.pp-name-row{justify-content:center}}
.pp-name{font-family:var(--font-display);font-weight:700;font-size:27px;letter-spacing:-.02em;color:var(--text-primary);line-height:1.1;margin:0}
.pp-open{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:var(--success);background:var(--success-bg);border:1px solid var(--success-border);padding:4px 11px;border-radius:999px}
html.dark .pp-open{background:rgba(52,211,153,.10);border-color:rgba(52,211,153,.35)}
.pp-open-dot{width:6px;height:6px;border-radius:99px;background:var(--success);box-shadow:0 0 0 3px rgba(52,211,153,.18)}
.pp-headline{font-size:14.5px;color:var(--text-secondary);margin:7px 0 0;line-height:1.45}
.pp-chips{display:flex;flex-wrap:wrap;gap:6px;margin-top:11px}
@media (max-width:560px){.pp-chips{justify-content:center}}
.pp-chip{font-family:var(--font-mono);font-size:10.5px;letter-spacing:.04em;color:var(--text-secondary);background:var(--bg-muted);border:1px solid var(--border-default);padding:4px 11px;border-radius:999px;text-transform:capitalize}
.pp-chip-accent{color:var(--accent);background:var(--accent-bg);border-color:var(--accent-border)}
.pp-since{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--text-tertiary);margin-top:12px}
@media (max-width:560px){.pp-since{justify-content:center}}
.pp-since svg{width:13px;height:13px;color:var(--accent)}
.pp-edit{flex:none}

/* stat band */
.pp-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:680px){.pp-stats{grid-template-columns:repeat(2,1fr)}}
.pp-stat{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-md);padding:18px 14px;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;min-height:108px}
.pp-stat-big{font-family:var(--font-mono);font-size:27px;font-weight:700;color:var(--text-primary);line-height:1}
.pp-stat-mid{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text-primary);line-height:1.2}
.pp-stat-sub{font-size:10.5px;color:var(--text-tertiary);line-height:1.35}
.pp-stat-ic{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;background:var(--accent-bg);color:var(--accent);margin-bottom:3px}
.pp-stat-ic svg{width:16px;height:16px}
.pp-gold{color:#F59E0B}
.pp-stars{color:#F59E0B;font-size:13px;letter-spacing:2px;line-height:1.2}
.pp-verified-note{display:flex;align-items:center;justify-content:center;gap:6px;font-size:11px;color:var(--text-tertiary);margin:2px 0 0}
.pp-verified-note svg{width:12px;height:12px}

/* sections */
.pp-sec-title{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--text-primary);margin-bottom:12px}
.pp-bio{font-size:13.5px;color:var(--text-secondary);line-height:1.65;white-space:pre-wrap;margin:0}

/* services */
.pp-services{display:grid;gap:12px}
.pp-service{border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-elevated);padding:15px 16px;transition:border-color .15s}
.pp-service:hover{border-color:var(--border-strong)}
.pp-service-top{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}
.pp-service-rate{font-family:var(--font-mono);font-size:11.5px;color:var(--text-secondary)}
.pp-service-title{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text-primary);margin-top:8px}
.pp-service-desc{font-size:12.5px;color:var(--text-secondary);line-height:1.5;margin:5px 0 0}
.pp-invite{display:flex;gap:8px;margin-top:12px;align-items:center}
.pp-invite select{max-width:280px;padding:6px 10px;font-size:12.5px}

/* rating summary + bars */
.pp-rating-layout{display:grid;grid-template-columns:170px 1fr;gap:22px;align-items:center;padding-bottom:16px;border-bottom:1px solid var(--border-subtle);margin-bottom:14px}
@media (max-width:560px){.pp-rating-layout{grid-template-columns:1fr;text-align:center}}
.pp-rating-summary{display:flex;flex-direction:column;align-items:center;gap:4px}
.pp-rating-huge{font-family:var(--font-mono);font-size:46px;font-weight:700;line-height:1}
.pp-rating-bars{display:grid;gap:6px}
.pp-bar-row{display:flex;align-items:center;gap:10px}
.pp-bar-label{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);width:24px;text-align:right;flex:none}
.pp-bar{flex:1;height:8px;border-radius:99px;background:var(--bg-muted);overflow:hidden}
.pp-bar span{display:block;height:100%;border-radius:99px;background-image:linear-gradient(90deg,#F59E0B,#FBBF24)}
.pp-bar-count{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);width:20px;flex:none}

/* review cards */
.pp-reviews{display:grid;gap:10px}
.pp-review{border:1px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-elevated);padding:14px 16px}
.pp-review-head{display:flex;align-items:center;gap:11px}
.pp-review-av{width:34px;height:34px;border-radius:10px;flex:none;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:14px}
.pp-review-who{min-width:0;flex:1;display:flex;flex-direction:column}
.pp-review-who a{font-weight:600;font-size:13.5px;color:var(--text-primary)}
.pp-review-who a:hover{color:var(--accent)}
.pp-review-meta{font-size:11px;color:var(--text-tertiary);text-transform:capitalize}
.pp-review-stars{flex:none;font-size:13px}
.pp-review-body{font-size:13px;color:var(--text-secondary);line-height:1.55;margin:10px 0 0;padding-left:45px;font-style:italic}
@media (max-width:560px){.pp-review-body{padding-left:0}}

/* empty reviews */
.pp-noreviews{text-align:center;padding:26px 18px;color:var(--text-tertiary)}
.pp-noreviews-ic{width:44px;height:44px;border-radius:13px;margin:0 auto 10px;display:grid;place-items:center;background:var(--bg-muted);color:var(--text-tertiary)}
.pp-noreviews-ic svg{width:20px;height:20px}
.pp-noreviews-t{font-family:var(--font-display);font-weight:700;font-size:14.5px;color:var(--text-secondary);margin-bottom:5px}
.pp-noreviews p{font-size:12.5px;line-height:1.55;max-width:46ch;margin:0 auto}

/* === Model create (mc-*) ============================================== */
.mc-sec{display:grid;gap:14px;margin-bottom:16px}
.mc-sec-head{display:flex;align-items:center;gap:13px;margin-bottom:2px}
.mc-step{width:30px;height:30px;border-radius:10px;flex:none;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;font-family:var(--font-mono);font-weight:700;font-size:13px;box-shadow:0 4px 12px -4px rgba(47,139,252,.55)}
.mc-sec-title{font-family:var(--font-display);font-weight:700;font-size:16.5px;color:var(--text-primary);line-height:1.15}
.mc-sec-sub{font-size:11.5px;color:var(--text-tertiary);margin-top:1px}
.mc-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}
@media (max-width:560px){.mc-row-3{grid-template-columns:1fr}}
.mc-hint{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.05em;text-transform:uppercase;color:var(--text-tertiary);font-weight:500;margin-left:6px}
.mc-uploads{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.mc-uploads{grid-template-columns:1fr}}
.mc-drop{display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;padding:20px 16px;border:1.5px dashed var(--border-strong);border-radius:var(--radius-md);background:var(--bg-muted);cursor:pointer;transition:border-color .15s,background .15s}
.mc-drop:hover{border-color:var(--accent);background:var(--accent-bg)}
.mc-drop.has-file{border-style:solid;border-color:var(--accent-border);background:var(--accent-bg)}
.mc-drop-wide{grid-column:1 / -1}
.mc-drop-ic{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:var(--bg-surface);color:var(--accent);border:1px solid var(--border-default)}
.mc-drop-ic svg{width:18px;height:18px}
.mc-drop-t{font-family:var(--font-display);font-weight:700;font-size:13.5px;color:var(--text-primary)}
.mc-drop-t em{font-style:normal;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);margin-left:5px}
.mc-drop-s{font-size:11.5px;color:var(--text-secondary);max-width:46ch}
.mc-drop-file{font-family:var(--font-mono);font-size:10.5px;color:var(--text-tertiary);margin-top:3px}
.mc-drop.has-file .mc-drop-file{color:var(--accent);font-weight:600}
.mc-ref-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.mc-ref{border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-elevated);padding:8px;display:grid;gap:6px}
.mc-ref img{width:100%;height:120px;object-fit:cover;border-radius:8px}
.mc-ref select,.mc-ref input{font-size:11.5px;padding:5px 8px}
.mc-existing-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:8px}
.mc-existing-item{margin:0}
.mc-existing-item img{width:100%;height:90px;object-fit:cover;border-radius:8px;border:1px solid var(--border-default)}
.mc-existing-item figcaption{font-family:var(--font-mono);font-size:9.5px;color:var(--text-tertiary);text-align:center;margin-top:3px}
.mc-ratings{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:560px){.mc-ratings{grid-template-columns:1fr}}
.mc-rating{position:relative;display:flex;flex-direction:column;gap:3px;padding:13px 14px;border:1.5px solid var(--border-default);border-radius:var(--radius-md);background:var(--bg-elevated);cursor:pointer;transition:border-color .15s,background .15s}
.mc-rating input{position:absolute;opacity:0;pointer-events:none}
.mc-rating:has(input:checked){border-color:var(--accent);background:var(--accent-bg);box-shadow:0 0 0 3px var(--accent-bg)}
.mc-rating-t{font-family:var(--font-display);font-weight:700;font-size:13.5px;color:var(--text-primary)}
.mc-rating-s{font-size:11px;color:var(--text-secondary);line-height:1.4}
.mc-attest{display:flex;gap:11px;align-items:flex-start;padding:12px 14px;border:1px solid var(--border-default);border-radius:var(--radius-sm);background:var(--bg-elevated);cursor:pointer;font-size:12.5px;color:var(--text-secondary);line-height:1.5}
.mc-attest:has(input:checked){border-color:var(--success-border);background:var(--success-bg)}
html.dark .mc-attest:has(input:checked){background:rgba(52,211,153,.08)}
.mc-attest input{margin-top:3px;accent-color:var(--accent);width:15px;height:15px;flex:none}
.mc-attest b{color:var(--text-primary)}

/* === Model page (mp-*) — her presentation ============================= */
.mp-banner{height:170px;background-image:var(--vf-grad);position:relative}
.mp-banner img{width:100%;height:100%;object-fit:cover}
.mp-hero-body{display:flex;gap:18px;align-items:flex-start;padding:0 26px 24px;margin-top:-44px;position:relative}
@media (max-width:620px){.mp-hero-body{flex-direction:column;align-items:center;text-align:center}}
.mp-portrait{width:116px;height:116px;border-radius:28px;flex:none;overflow:hidden;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:44px;border:4px solid var(--bg-surface);box-shadow:0 14px 36px -12px rgba(7,11,20,.5)}
.mp-portrait img{width:100%;height:100%;object-fit:cover}
.mp-hero-main{min-width:0;flex:1;padding-top:52px}
@media (max-width:620px){.mp-hero-main{padding-top:6px}}
.mp-name-row{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
@media (max-width:620px){.mp-name-row{justify-content:center}}
.mp-name{font-family:var(--font-display);font-weight:700;font-size:29px;letter-spacing:-.02em;color:var(--text-primary);margin:0;line-height:1.05}
.mp-tagline{font-size:14.5px;color:var(--text-secondary);margin:7px 0 0;line-height:1.45}
.mp-2col{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:620px){.mp-2col{grid-template-columns:1fr}}
.mp-views{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media (max-width:560px){.mp-views{grid-template-columns:repeat(2,1fr)}}
.mp-view{margin:0;border:1px solid var(--border-default);border-radius:var(--radius-md);overflow:hidden;background:var(--bg-elevated)}
.mp-view img{width:100%;aspect-ratio:3/4;object-fit:cover;display:block}
.mp-view figcaption{font-family:var(--font-mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);text-align:center;padding:7px 4px}
.mp-gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px}
.mp-shot{margin:0;border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-default)}
.mp-shot img{width:100%;aspect-ratio:1;object-fit:cover;display:block;transition:transform .25s}
.mp-shot:hover img{transform:scale(1.04)}
.mp-shot figcaption{font-size:10.5px;color:var(--text-tertiary);padding:6px 9px;background:var(--bg-elevated)}
.mp-checklist{display:grid;grid-template-columns:1fr 1fr;gap:7px;font-size:12.5px;color:var(--text-secondary);margin-bottom:12px}
@media (max-width:560px){.mp-checklist{grid-template-columns:1fr}}
.mp-checklist label{display:flex;align-items:center;gap:8px}
.mp-verdict{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.mp-verdict input[name="note"]{flex:1;min-width:220px}
.mp-queue-row{display:flex;gap:14px;align-items:center}
.mp-queue-thumb{width:62px;height:62px;border-radius:16px;flex:none;overflow:hidden;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:24px}
.mp-queue-thumb img{width:100%;height:100%;object-fit:cover}

/* === Model socials chips + extra platform dot colors ================== */
.mp-socials{display:flex;flex-wrap:wrap;gap:9px}
.mp-soc{display:inline-flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--border-default);border-radius:999px;background:var(--bg-elevated);font-size:12.5px;font-weight:600;color:var(--text-primary);text-decoration:none;transition:border-color .15s,transform .12s}
a.mp-soc:hover{border-color:var(--border-strong);transform:translateY(-1px)}
.mp-soc svg{width:12px;height:12px;color:var(--text-tertiary)}
.mp-soc-bound{border-color:var(--accent-border);background:var(--accent-bg)}
.mp-soc em{font-style:normal;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700}
[data-pf-dot="x"]{background:#536471}
[data-pf-dot="youtube"]{background:#FF0033}
[data-pf-dot="onlyfans"]{background:#00AFF0}
[data-pf-dot="web"]{background:var(--text-tertiary)}

/* === Bound-account metric cards (Her socials) ========================= */
.mp-sa-card{border:1px solid var(--accent-border);background:var(--accent-bg);border-radius:16px;padding:16px 18px}
.mp-sa-card + .mp-sa-card{margin-top:10px}
.mp-sa-head{display:flex;align-items:center;gap:9px;flex-wrap:wrap}
.mp-sa-name{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text-primary)}
.mp-sa-bound{font-style:normal;font-family:var(--font-mono);font-size:9px;letter-spacing:.08em;text-transform:uppercase;color:var(--accent);font-weight:700;border:1px solid var(--accent-border);border-radius:999px;padding:2px 8px}
.mp-sa-visit{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:11.5px;font-weight:600;color:var(--accent);text-decoration:none}
.mp-sa-visit:hover{text-decoration:underline}
.mp-sa-visit svg{width:11px;height:11px}
.mp-sa-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px;margin-top:14px}
.mp-sa-stat{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:12px;padding:12px 14px}
.mp-sa-val{font-family:var(--font-mono);font-weight:700;font-size:21px;letter-spacing:-.02em;color:var(--text-primary);line-height:1.1}
.mp-sa-val.is-up{color:var(--success)}
.mp-sa-val.is-down{color:var(--danger,#ef4444)}
.mp-sa-lbl{font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;margin-top:5px}
.mp-sa-foot{margin-top:11px;font-size:11.5px;color:var(--text-tertiary)}
.mp-gwin{display:inline-flex;border:1px solid var(--border-default);border-radius:999px;padding:2px;background:var(--bg-elevated)}
.mp-gwin-btn{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.04em;padding:4px 12px;border-radius:999px;color:var(--text-tertiary);transition:all .15s}
.mp-gwin-btn.on{background-image:var(--vf-grad);color:#fff}

/* === Platform brand glyphs ============================================ */
.vf-brand{width:18px;height:18px;flex:none}
.mp-soc .vf-brand{width:14px;height:14px}

/* === Interactive connect tutorial modal (tut-*) ======================= */
.tut-overlay{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:20px;background:rgba(10,12,24,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.tut-overlay[hidden]{display:none}
.tut-modal{width:100%;max-width:560px;max-height:90vh;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:22px;box-shadow:0 40px 90px -24px rgba(0,0,0,.55);animation:tutPop .28s cubic-bezier(.2,.9,.3,1.2)}
@keyframes tutPop{from{opacity:0;transform:translateY(14px) scale(.97)}to{opacity:1;transform:none}}
.tut-head{position:relative;display:flex;align-items:center;gap:14px;padding:20px 22px;border-bottom:1px solid var(--border-default);overflow:hidden}
.tut-head .vf-brand{width:30px;height:30px;position:relative;z-index:1}
.tut-head-glow{position:absolute;inset:0;background:radial-gradient(120% 160% at 0% 0%,rgba(24,119,242,.18),transparent 55%),radial-gradient(120% 160% at 100% 0%,rgba(168,85,247,.14),transparent 55%);pointer-events:none}
.tut-kicker{font-family:var(--font-mono);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.tut-title{font-family:var(--font-display);font-weight:800;font-size:18px;color:var(--text-primary);letter-spacing:-.01em}
.tut-x{position:relative;z-index:1;margin-left:auto;width:32px;height:32px;border-radius:10px;display:grid;place-items:center;font-size:20px;line-height:1;color:var(--text-tertiary);transition:all .15s}
.tut-x:hover{background:var(--bg-elevated);color:var(--text-primary)}
.tut-body{padding:22px}
.tut-step{display:none}
.tut-step.on{display:block}
.tut-step.anim{animation:tutStep .25s ease}
@keyframes tutStep{from{opacity:0;transform:translateX(10px)}to{opacity:1;transform:none}}
.tut-qnum{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:8px}
.tut-q{font-size:14.5px;line-height:1.65;color:var(--text-secondary);margin-bottom:14px}
.tut-q b,.tut-q em{color:var(--text-primary)}
.tut-choices{display:grid;gap:9px;margin-top:4px}
.tut-choice{display:flex;align-items:center;gap:13px;width:100%;text-align:left;padding:13px 16px;border:1px solid var(--border-default);border-radius:14px;background:var(--bg-elevated);cursor:pointer;transition:all .15s}
.tut-choice:hover{border-color:var(--accent);transform:translateY(-1px);box-shadow:0 8px 22px -12px rgba(99,102,241,.45)}
.tut-choice-ic{font-size:19px;flex:none}
.tut-choice span:last-child{display:flex;flex-direction:column;gap:1px}
.tut-choice b{font-size:13.5px;color:var(--text-primary)}
.tut-choice small{font-size:11.5px;color:var(--text-tertiary)}
.tut-list{margin:0 0 14px 18px;display:grid;gap:9px;font-size:13.5px;line-height:1.6;color:var(--text-secondary);list-style:decimal}
.tut-list b{color:var(--text-primary)}
.tut-note{border:1px solid var(--accent-border);background:var(--accent-bg);border-radius:12px;padding:11px 14px;font-size:12.5px;line-height:1.6;color:var(--text-secondary);margin-bottom:9px}
.tut-note b{color:var(--text-primary)}
.tut-actions{display:flex;align-items:center;gap:10px;margin-top:16px;flex-wrap:wrap}
.tut-done-ic{font-size:34px;text-align:center;margin:6px 0 10px}
.tut-mock{border:1px dashed var(--border-strong);border-radius:14px;padding:8px;margin-bottom:14px;background:var(--bg-elevated)}
.tut-mock-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:9px;font-size:12.5px}
.tut-mock-row:nth-child(odd){background:var(--bg-surface)}
.tut-mock-dot{width:9px;height:9px;border-radius:50%;background:#1877F2;flex:none}
.tut-mock-name{font-weight:600;color:var(--text-primary)}
.tut-mock-sel{margin-left:auto;font-family:var(--font-mono);font-size:11px;color:var(--accent);border:1px solid var(--accent-border);border-radius:7px;padding:2px 8px;background:var(--accent-bg)}
.tut-mock-row.is-skip .tut-mock-name{color:var(--text-tertiary);font-weight:500}
.tut-mock-row.is-skip .tut-mock-sel{color:var(--text-tertiary);border-color:var(--border-default);background:transparent}

/* === Connect page: branded platform rows (cx-*) ======================= */
.cx-plat{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:14px}
.cx-plat + .cx-plat{border-top:1px solid var(--border-default)}
.cx-plat-ic{width:38px;height:38px;border-radius:12px;display:grid;place-items:center;background:var(--bg-elevated);border:1px solid var(--border-default);flex:none}
.cx-plat-ic .vf-brand{width:20px;height:20px}
.cx-plat-ic .ck-pf-dot{width:12px;height:12px}
.cx-plat-main{min-width:0;flex:1}
.cx-plat-name{font-family:var(--font-display);font-weight:700;font-size:14.5px;color:var(--text-primary);display:flex;align-items:center;gap:8px}
.cx-plat-sub{font-size:12px;color:var(--text-tertiary);margin-top:1px}
.cx-live{display:inline-flex;align-items:center;gap:5px;font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--success);border:1px solid var(--success-border,rgba(16,185,129,.35));border-radius:999px;padding:2px 8px;background:var(--success-bg,rgba(16,185,129,.08))}
.cx-live-dot{width:6px;height:6px;border-radius:50%;background:var(--success);animation:cxPulse 2s ease-in-out infinite}
@keyframes cxPulse{0%,100%{opacity:1}50%{opacity:.35}}
.cx-soon{font-family:var(--font-mono);font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary);border:1px dashed var(--border-strong);border-radius:999px;padding:5px 12px}
.cx-plat.is-soon .cx-plat-ic{opacity:.55}
.cx-plat.is-soon .cx-plat-name,.cx-plat.is-soon .cx-plat-sub{color:var(--text-tertiary)}
.cx-model-link{font-weight:600;color:var(--accent);text-decoration:none}
.cx-model-link:hover{text-decoration:underline}

/* === Connect-a-platform collapse ====================================== */
.cx-toggle{display:flex;align-items:center;gap:13px;width:100%;text-align:left;padding:10px 12px;border-radius:12px;cursor:pointer;transition:background .15s}
.cx-toggle:hover{background:var(--bg-elevated)}
.cx-toggle-ic{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;flex:none}
.cx-toggle-ic svg{width:17px;height:17px}
.cx-toggle-main{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.cx-toggle-title{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--text-primary)}
.cx-toggle-sub{font-size:11.5px;color:var(--text-tertiary)}
.cx-chev{color:var(--text-tertiary);transition:transform .25s ease;flex:none}
.cx-chev svg{width:18px;height:18px}
.cx-connect:not(.is-collapsed) .cx-chev{transform:rotate(180deg)}
.cx-plats{display:grid;grid-template-rows:1fr;transition:grid-template-rows .3s ease}
.cx-plats > div{overflow:hidden}
.cx-connect.is-collapsed .cx-plats{grid-template-rows:0fr}
.cx-connect:not(.is-collapsed) .cx-plats > div{padding-top:6px}

/* === Platform-held custody badge ====================================== */
.cx-held{display:inline-flex;align-items:center;gap:4px;font-family:var(--font-mono);font-size:9px;font-weight:700;letter-spacing:.1em;color:var(--accent);border:1px solid var(--accent-border);border-radius:999px;padding:2px 8px;background:var(--accent-bg)}
.cx-plat.is-soon .cx-held{opacity:.85}

/* === Admin email editor (em-*) ======================================== */
.em-row{display:flex;align-items:center;gap:14px;padding:13px 16px;border-radius:12px;text-decoration:none;transition:background .15s}
.em-row:hover{background:var(--bg-elevated)}
.em-row + .em-row{border-top:1px solid var(--border-default)}
.em-row-ic{width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent);flex:none}
.em-row-ic svg{width:16px;height:16px}
.em-row-main{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1}
.em-row-name{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--text-primary)}
.em-row-desc{font-size:12px;color:var(--text-secondary)}
.em-row-subj{font-size:11px;font-family:var(--font-mono);color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.em-row-meta{display:flex;flex-direction:column;gap:2px;align-items:flex-end;font-size:10.5px;color:var(--text-tertiary);flex:none}
.em-row-meta code{font-size:10px;color:var(--accent)}
.em-row-chev{width:16px;height:16px;color:var(--text-tertiary);flex:none}
.em-split{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,520px);gap:18px;align-items:start}
@media (max-width:1100px){.em-split{grid-template-columns:1fr}}
.em-preview-col{position:sticky;top:80px}
.em-preview{width:100%;height:640px;border:1px solid var(--border-default);border-radius:12px;background:#f4f7fc}
.em-code{font-family:var(--font-mono);font-size:12px;line-height:1.55;white-space:pre;overflow-x:auto}
.em-var{font-family:var(--font-mono);font-size:11.5px;font-weight:700;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-radius:7px;padding:3px 9px;cursor:pointer;transition:all .15s}
.em-var:hover{transform:translateY(-1px)}
.em-var.copied{background:var(--success);color:#fff;border-color:var(--success)}

/* === Register: @username input ======================================== */
.rg-handle{display:flex;align-items:center;gap:0}
.rg-handle > span{font-family:var(--font-mono);font-weight:700;font-size:15px;color:var(--accent);background:var(--accent-bg);border:1px solid var(--accent-border);border-right:0;border-radius:10px 0 0 10px;padding:10px 12px}
.rg-handle .vf-input{border-radius:0 10px 10px 0}

/* === Invite modal (iv-*) ============================================== */
.iv-overlay{position:fixed;inset:0;z-index:120;display:grid;place-items:center;padding:20px;background:rgba(10,12,24,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}
.iv-overlay[hidden]{display:none}
.iv-modal{width:100%;max-width:520px;max-height:90vh;overflow-y:auto;background:var(--bg-surface);border:1px solid var(--border-default);border-radius:22px;box-shadow:0 40px 90px -24px rgba(0,0,0,.55);animation:tutPop .28s cubic-bezier(.2,.9,.3,1.2)}
.iv-head{display:flex;align-items:center;gap:12px;padding:18px 22px;border-bottom:1px solid var(--border-default)}
.iv-kicker{font-family:var(--font-mono);font-size:9.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.iv-title{font-family:var(--font-display);font-weight:800;font-size:17px;color:var(--text-primary)}
.iv-head .tut-x{margin-left:auto}
.iv-body{padding:20px 22px}
.iv-sec-title{font-family:var(--font-display);font-weight:700;font-size:13.5px;color:var(--text-primary)}
.iv-sec-sub{font-size:12px;color:var(--text-tertiary);margin:2px 0 10px}
.iv-worked{display:grid;gap:8px}
.iv-worked-row{display:flex;align-items:center;gap:11px;width:100%;text-align:left;padding:10px 13px;border:1px solid var(--border-default);border-radius:12px;background:var(--bg-elevated);cursor:pointer;transition:all .15s}
.iv-worked-row:hover{border-color:var(--accent)}
.iv-worked-row.on{border-color:var(--accent);background:var(--accent-bg)}
.iv-wr-main{display:flex;flex-direction:column;gap:0;min-width:0;flex:1}
.iv-wr-main b{font-size:13px;color:var(--text-primary)}
.iv-wr-main small{font-size:11px;color:var(--text-tertiary)}
.iv-wr-check{opacity:0;color:var(--accent);font-weight:800}
.iv-worked-row.on .iv-wr-check{opacity:1}
.iv-empty{font-size:12.5px;color:var(--text-tertiary)}
.iv-or{display:flex;align-items:center;gap:12px;margin:16px 0;color:var(--text-tertiary);font-family:var(--font-mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase}
.iv-or::before,.iv-or::after{content:'';height:1px;flex:1;background:var(--border-default)}
.iv-lookup{display:flex;gap:8px;align-items:stretch}
.iv-card{margin-top:12px}
.iv-mini{display:flex;gap:13px;align-items:flex-start;border:1px solid var(--accent-border);background:var(--accent-bg);border-radius:14px;padding:14px}
.iv-mini-av{width:46px;height:46px;font-size:19px;flex:none}
.iv-mini-name{font-family:var(--font-display);font-weight:800;font-size:15px;color:var(--text-primary)}
.iv-mini-sub{font-size:11.5px;color:var(--text-secondary);margin:1px 0 7px}
.iv-mini-roles{display:flex;flex-wrap:wrap;gap:5px}
.iv-mini-warn{margin-top:9px;font-size:12px;color:var(--warning,#b45309);border:1px solid var(--warning-border,rgba(217,119,6,.4));background:var(--warning-bg,rgba(217,119,6,.08));border-radius:9px;padding:7px 11px}
.iv-actions{display:flex;align-items:center;gap:12px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border-default)}

/* === Verify page: fix-email disclosure ================================ */
.otp-fix{margin-top:16px;text-align:center}
.otp-fix summary{cursor:pointer;font-size:12.5px;font-weight:600;color:var(--accent);list-style:none}
.otp-fix summary::-webkit-details-marker{display:none}
.otp-fix summary:hover{text-decoration:underline}
.otp-fix-form{display:flex;gap:8px;margin-top:10px}
.otp-fix-form .vf-input{flex:1}

/* === Email-change confirm modal (ec-*) ================================ */
.ec-ic{width:40px;height:40px;border-radius:13px;display:grid;place-items:center;background-image:var(--vf-grad);color:#fff;flex:none}
.ec-ic svg{width:19px;height:19px}
.ec-line{font-size:14px;line-height:1.65;color:var(--text-secondary);margin-bottom:14px}
.ec-line b{color:var(--text-primary)}
.ec-email{font-family:var(--font-mono);color:var(--accent) !important;word-break:break-all}
.ec-points{display:grid;gap:9px}
.ec-point{display:flex;gap:10px;align-items:flex-start;font-size:12.5px;line-height:1.6;color:var(--text-secondary);border:1px solid var(--border-default);background:var(--bg-elevated);border-radius:12px;padding:10px 13px}
.ec-point span{flex:none;font-size:15px}
.ec-point em{font-style:normal;font-weight:700;color:var(--text-primary)}

/* === Restructure page (rs-*) ========================================== */
.rs-counter{display:flex;align-items:center;gap:14px;flex-wrap:wrap;border-color:var(--accent-border)}
.rs-row{display:flex;gap:16px;align-items:flex-start;padding:14px 2px;border-top:1px solid var(--border-subtle)}
.rs-row:first-of-type{border-top:0}
.rs-row.is-salary{opacity:.55}
.rs-row-main{flex:1;min-width:0}
.rs-row-label{font-weight:600;font-size:14px;color:var(--text-primary);display:flex;align-items:center;flex-wrap:wrap;gap:2px}
.rs-occ{margin-left:6px;color:var(--accent);font-weight:600;text-decoration:none}
.rs-occ:hover{text-decoration:underline}
.rs-open{margin-left:6px;color:var(--text-tertiary);font-size:12px}
.rs-note{font-size:12px;color:var(--text-tertiary);margin-top:3px;line-height:1.55}
.rs-note-warn{color:var(--text-secondary);border:1px solid var(--warning-border);background:rgba(245,158,11,.07);border-radius:10px;padding:7px 11px;margin-top:6px}
.rs-row-num{flex:none;width:150px;text-align:right}
.rs-cur{font-family:var(--font-mono);font-size:10.5px;color:var(--text-tertiary);margin-bottom:4px}
.rs-input{font-family:var(--font-mono);text-align:right;font-weight:700}
.rs-delta{font-family:var(--font-mono);font-size:11px;margin-top:4px;color:var(--text-tertiary);min-height:15px}
.rs-delta.is-free{color:var(--success)}
.rs-delta.is-bad{color:var(--danger)}
.rs-foot{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-top:14px;padding-top:16px;border-top:1px solid var(--border-default)}
.rs-total{font-size:13.5px;color:var(--text-secondary)}
.rs-total b{font-family:var(--font-mono);color:var(--text-primary)}
.rs-verdict{margin-left:8px;font-family:var(--font-mono);font-size:11px;font-weight:700}
.rs-verdict.is-ok{color:var(--success)}
.rs-verdict.is-bad{color:var(--danger)}

/* === Governance v2 (gv-*) ============================================= */
.gv-pending{border:1px solid var(--accent-border);background:var(--accent-bg);border-radius:14px;padding:14px 16px;margin-bottom:14px}
.gv-pending-head{display:flex;align-items:center;gap:10px;flex-wrap:wrap;font-size:13.5px;color:var(--text-primary)}
.gv-pending-badge{font-family:var(--font-mono);font-size:9.5px;font-weight:700;letter-spacing:.1em;color:var(--accent);border:1px solid var(--accent-border);border-radius:999px;padding:3px 9px;background:var(--bg-surface)}
.gv-sigs{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}
.gv-sig{font-family:var(--font-mono);font-size:11px;border:1px solid var(--border-default);border-radius:999px;padding:3px 10px;color:var(--text-tertiary);background:var(--bg-surface)}
.gv-sig.is-signed{color:var(--success);border-color:var(--success-border)}
.gv-sig.is-refused{color:var(--danger);border-color:var(--danger-border);font-weight:700}
.gv-bar{position:relative;height:7px;border-radius:999px;background:var(--bg-muted);margin-top:8px;overflow:visible;display:flex}
.gv-bar-yes{background:var(--success);border-radius:999px 0 0 999px;height:100%}
.gv-bar-no{background:var(--danger);height:100%}
.gv-bar-need{position:absolute;top:-3px;bottom:-3px;width:2px;background:var(--text-primary);opacity:.65;border-radius:2px}

/* === The rendered agreement document (ag-*) =========================== */
.ag-paper{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:14px;padding:28px 32px;max-height:560px;overflow-y:auto}
.ag-doc h1{font-family:var(--font-display);font-size:22px;font-weight:800;color:var(--text-primary);margin-bottom:8px}
.ag-doc h2{font-family:var(--font-display);font-size:14.5px;font-weight:700;color:var(--text-primary);margin:18px 0 6px}
.ag-doc p{font-size:13px;line-height:1.7;color:var(--text-secondary);margin-bottom:8px}
.ag-doc p b{color:var(--text-primary)}
.ag-doc .ag-meta{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}
.ag-doc .ag-remun{margin-left:16px;padding-left:12px;border-left:2px solid var(--accent-border)}
.ag-doc .ag-open{opacity:.75}
.ag-doc .ag-proposed{border:1px solid var(--warning-border);background:rgba(245,158,11,.07);border-radius:10px;padding:10px 14px;font-size:13px;color:var(--text-secondary);margin-bottom:12px}
.ag-doc table.ag-table{width:100%;border-collapse:collapse;margin:8px 0}
.ag-doc table.ag-table th,.ag-doc table.ag-table td{border:1px solid var(--border-default);padding:6px 10px;font-size:12px;text-align:left;color:var(--text-secondary)}
.ag-doc table.ag-table th{background:var(--bg-elevated);color:var(--text-primary);font-weight:700}
.ag-sigblock{margin-top:14px;padding-top:14px;border-top:1px solid var(--border-default)}
.gv-ceremony{margin-top:14px;padding:14px 16px;border:1px solid var(--border-default);border-radius:14px;background:var(--bg-surface)}
.gv-check{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--text-secondary);margin-bottom:10px;cursor:pointer}
.gv-check b{color:var(--text-primary)}
.gv-sign-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:4px}

/* === Floating scroll-to-sign indicator ================================ */
.ag-float{position:fixed;right:24px;bottom:24px;z-index:90;display:flex;align-items:center;gap:8px;background-image:var(--vf-grad);color:#fff;font-family:var(--font-display);font-weight:700;font-size:13.5px;border-radius:999px;padding:12px 20px;box-shadow:0 16px 40px -12px rgba(27,79,216,.6);cursor:grab;user-select:none;touch-action:none;animation:agBounce 2.2s ease-in-out infinite}
.ag-float:active{cursor:grabbing}
.ag-float.is-hidden{opacity:0;pointer-events:none;transition:opacity .25s}
.ag-float-ic{font-size:16px}
.ag-float-arrow{display:inline-block;animation:agArrow 1.2s ease-in-out infinite}
@keyframes agBounce{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
@keyframes agArrow{0%,100%{transform:translateY(0)}50%{transform:translateY(3px)}}

/* === Editor tabs + WYSIWYG + text preview ============================= */
.em-tabs{display:inline-flex;border:1px solid var(--border-default);border-radius:999px;padding:2px;background:var(--bg-elevated)}
.em-tab{font-family:var(--font-mono);font-size:11px;font-weight:700;letter-spacing:.03em;padding:4px 12px;border-radius:999px;color:var(--text-tertiary);transition:all .15s;cursor:pointer}
.em-tab.on{background-image:var(--vf-grad);color:#fff}
.em-tab:disabled{opacity:.45;cursor:not-allowed}
.em-quill-wrap{border:1px solid var(--border-default);border-radius:12px;overflow:hidden;background:#fff}
.em-quill-wrap .ql-toolbar{border:0;border-bottom:1px solid #dce6f5}
.em-quill-wrap .ql-container{border:0;font-size:14px;min-height:280px;color:#0b1426}
.em-textpv{width:100%;height:640px;overflow:auto;border:1px solid var(--border-default);border-radius:12px;background:var(--bg-elevated);color:var(--text-secondary);font-family:var(--font-mono);font-size:12px;line-height:1.6;padding:16px;white-space:pre-wrap}

/* === Deal content feed (cf-*) + media (cm-*) ========================== */
.cf-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(96px,1fr));gap:8px}
.cf-thumb{position:relative;aspect-ratio:1;border-radius:10px;overflow:hidden;border:1px solid var(--border-default);background:var(--bg-elevated);display:block}
.cf-thumb img{width:100%;height:100%;object-fit:cover}
.cf-vid{position:absolute;inset:0;display:grid;place-items:center;color:#fff;font-size:20px;text-shadow:0 1px 4px rgba(0,0,0,.6);pointer-events:none}
.cf-st{position:absolute;top:5px;right:5px;width:9px;height:9px;border-radius:50%;border:1.5px solid #fff;box-shadow:0 0 0 1px rgba(0,0,0,.2)}
.cf-st-accepted{background:#34D399}
.cf-st-rejected{background:#F87171}
.cf-st-draft,.cf-st-pending_review,.cf-st-in_review,.cf-st-needs_revision{background:#F59E0B}
.cm-2col{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}
@media (max-width:760px){.cm-2col{grid-template-columns:1fr}}
.cm-dispo{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-default)}
.cm-comment{border:1px solid var(--border-subtle);border-radius:12px;padding:10px 12px;background:var(--bg-elevated)}
.cm-react-chip{font-size:13px;border:1px solid var(--border-default);border-radius:999px;padding:1px 7px;background:var(--bg-surface)}
.cm-react-btn{font-size:14px;padding:1px 4px;border-radius:6px;opacity:.5;transition:opacity .15s,transform .15s}
.cm-react-btn:hover{opacity:1;transform:scale(1.2)}
/* live post engagement (the real public data, distinct from team discussion) */
.pe-stats{display:flex;gap:10px;flex-wrap:wrap}
.pe-stat{flex:1;min-width:78px;border:1px solid var(--border-subtle);border-radius:12px;padding:8px 10px;background:var(--bg-elevated);text-align:center}
.pe-stat-n{display:block;font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text-primary);line-height:1.1}
.pe-stat-l{display:block;font-size:11px;color:var(--text-tertiary);margin-top:2px}
.pe-comments{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto}
.pe-pub-c{border:1px solid var(--border-subtle);border-radius:10px;padding:8px 10px;background:var(--bg-surface)}
/* wallet */
.wl-balance{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.wl-bal-label{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.05em}
.wl-bal-amount{font-family:var(--font-display);font-weight:700;font-size:40px;line-height:1.1;color:var(--text-primary)}
.wl-bal-sub{font-size:12px;color:var(--text-tertiary);margin-top:2px}
/* pulse store */
.st-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:14px}
.st-card{display:flex;flex-direction:column;gap:6px}
.st-ic{font-size:26px;line-height:1}
.st-name{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--text-primary)}
.st-desc{font-size:13px;color:var(--text-secondary);flex:1}
.st-foot{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.st-price{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text-primary)}
/* pulse upsell gate (out of free refreshes / out of credits) */
.pg-gate{border:1px solid var(--border-default);border-radius:12px;padding:12px;background:var(--bg-elevated);margin-top:8px}
.pg-gate-hot{border-color:var(--accent);background:color-mix(in srgb,var(--accent) 8%,var(--bg-elevated))}
/* store confirm/success modals */
.st-modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.55);display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}
.st-modal-bg[hidden]{display:none}
.st-modal{background:var(--bg-surface);border:1px solid var(--border-default);border-radius:16px;max-width:380px;width:100%;padding:20px;box-shadow:0 20px 60px rgba(0,0,0,.4)}
.st-modal-h{font-family:var(--font-display);font-weight:700;font-size:18px;color:var(--text-primary);margin-bottom:12px}
.st-modal-b{font-size:14px}
.st-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;color:var(--text-secondary)}
.st-row-after b{font-size:18px;color:var(--text-primary)}
.st-hr{border:none;border-top:1px solid var(--border-subtle);margin:6px 0}
.st-short{margin-top:10px;padding:8px 10px;border-radius:8px;background:color-mix(in srgb,var(--danger) 12%,transparent);color:var(--danger);font-size:13px}
.st-modal-f{display:flex;gap:8px;justify-content:flex-end;margin-top:16px}
.st-ok-ic{width:48px;height:48px;border-radius:999px;background:color-mix(in srgb,var(--success) 18%,transparent);color:var(--success);font-size:26px;display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
/* crypto admin */
.cy-stats{display:flex;gap:10px;flex-wrap:wrap}
.cy-stat{flex:1;min-width:96px;border:1px solid var(--border-subtle);border-radius:12px;padding:10px;text-align:center;text-decoration:none;background:var(--bg-elevated)}
.cy-stat-n{display:block;font-family:var(--font-display);font-weight:700;font-size:22px;color:var(--text-primary)}
.cy-stat-l{display:block;font-size:11px;color:var(--text-tertiary);margin-top:2px}
.cy-chain-form{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}
.cy-f{display:flex;flex-direction:column;gap:3px;font-size:11px;color:var(--text-tertiary)}
.cy-f-row{flex-direction:row;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary)}
.cy-tokens{display:flex;flex-direction:column;gap:8px}
.cy-token{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap;border:1px solid var(--border-subtle);border-radius:10px;padding:10px;background:var(--bg-elevated)}
.cy-token-id{flex:1;min-width:200px;font-size:13px;color:var(--text-secondary)}
.fz-row{display:flex;justify-content:space-between;align-items:center;gap:8px;width:100%;text-align:left;padding:9px 11px;border:1px solid var(--border-subtle);border-radius:10px;background:var(--bg-elevated);margin-bottom:6px;font-size:13px;color:var(--text-primary);cursor:pointer}
.fz-row:hover{border-color:var(--accent)}
.fz-row-meta{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);white-space:nowrap}
/* wallet snapshot */
.ws-head{display:flex;justify-content:space-between;align-items:flex-start;gap:10px;padding-bottom:10px;border-bottom:1px solid var(--border-default)}
.ws-who{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--text-primary)}
.ws-email{font-size:12px;color:var(--text-tertiary)}
.ws-bal{font-family:var(--font-display);font-weight:700;font-size:20px;color:var(--text-primary)}
.ws-froze{border:1px solid var(--danger-border,#e5484d);border-radius:10px;padding:10px 12px;margin-top:10px;background:color-mix(in srgb,var(--danger) 8%,transparent)}
.ws-froze-h{font-weight:700;color:var(--danger);font-size:13px}
.ws-froze-r{font-size:13px;color:var(--text-primary);margin-top:3px}
.ws-sec{font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--text-secondary);margin:14px 0 4px;text-transform:uppercase;letter-spacing:.04em}
.ws-chain{font-size:12px;font-weight:600;color:var(--accent);margin-top:6px}
.ws-tbl td{padding:4px 8px;font-size:12.5px}
.ws-addr{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:5px 0;border-bottom:1px solid var(--border-subtle)}
.ws-none{font-size:13px;color:var(--text-tertiary)}
/* user deposit page */
.dp-addr{font-family:var(--font-mono);font-size:13px;word-break:break-all;background:var(--bg-elevated);border:1px solid var(--border-subtle);border-radius:10px;padding:10px 12px}
.dp-chain-hdr{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:700;color:var(--text-secondary);margin:8px 0 4px}
.dp-deprow,.dp-arow{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;padding:8px 10px;border:1px solid var(--border-subtle);border-radius:10px;background:var(--bg-elevated);margin-bottom:5px;cursor:pointer}
.dp-deprow:hover,.dp-arow:hover{border-color:var(--accent)}
.dp-dep-amt{display:block;font-weight:600;font-size:14px;color:var(--text-primary)}
.dp-dep-sub{display:block;font-size:11px;color:var(--text-tertiary)}
.dp-dep-sub code{font-size:11px}
.dp-dep-more{display:block;font-size:11px;color:var(--accent);margin-top:2px}
.dp-kv{display:flex;justify-content:space-between;gap:10px;padding:5px 0;border-bottom:1px solid var(--border-subtle);font-size:13px;color:var(--text-secondary)}
.dp-kv span:last-child{color:var(--text-primary);text-align:right}
.dp-tok{font-size:12px;border:1px solid var(--border-default);border-radius:999px;padding:4px 11px;background:var(--bg-surface);color:var(--text-secondary);cursor:pointer}
.dp-tok:hover{border-color:var(--accent);color:var(--text-primary)}
.dp-qr-wrap{display:flex;gap:16px;align-items:center;flex-wrap:wrap}
.dp-qr{width:140px;height:140px;border-radius:12px;background:#fff;padding:6px;flex-shrink:0;box-shadow:0 2px 10px rgba(0,0,0,.08)}
/* friendly deposit notice — informative, not alarming */
.dp-info{display:flex;gap:12px;align-items:flex-start;border:1px solid var(--border-subtle);border-radius:14px;padding:14px 16px;background:color-mix(in srgb,var(--accent) 5%,var(--bg-surface))}
.dp-info-ic{font-size:20px;line-height:1.4;flex-shrink:0}
.dp-info-body{font-size:13px;line-height:1.65;color:var(--text-secondary)}
.dp-info-body b{color:var(--text-primary);font-weight:600}

/* em-tab works as an anchor (queue/history) too */
a.em-tab{text-decoration:none}

/* ===== Crypto deposit-decision redesign (.cyd-*) — namespaced; existing vars only =====
   Append to static/css/responsive.css (where .st-modal*/.em-tab*/.dp-kv*/.pp-sec-title/.cy-token live).
   No --border or --surface-2 (undefined). No hardcoded colour literals except #fff on the active
   gradient pill (matches the native .em-tab.on). */

/* ---- fraud tabs: force the inline-flex pill capsule to wrap so 4 long labels never clip ---- */
.cyd-fhtabs{display:flex;flex-wrap:wrap;gap:2px;width:100%}
.cyd-fhtabs .em-tab{display:inline-flex;align-items:center;gap:7px}

/* count pills on the tabs — warn/error tone when the queue is non-empty */
.cyd-pill{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;
  border-radius:999px;font-family:var(--font-mono);font-size:10.5px;font-weight:700;line-height:1;
  background:color-mix(in srgb,var(--text-tertiary) 18%,transparent);color:var(--text-secondary)}
.cyd-pill-warn{background:color-mix(in srgb,var(--accent) 18%,transparent);color:var(--accent)}
.cyd-pill-err{background:color-mix(in srgb,var(--danger) 18%,transparent);color:var(--danger)}
/* keep the pill legible on the gradient active tab (the only contrast fix) */
.em-tab.on .cyd-pill{background:rgba(255,255,255,.24);color:#fff}

/* ---- per-tab panel header: a real heading so each tab reads as a section ---- */
.cyd-panel-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap;margin:12px 0 8px}
.cyd-panel-title{font-family:var(--font-display);font-weight:700;font-size:14px;color:var(--text-primary)}
.cyd-panel-sub{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:12px;color:var(--text-tertiary);margin-top:4px}
.cyd-panel-sub b{color:var(--text-secondary)}

/* ---- summary rows (awaiting / held / frozen / blocked) ---- */
.cyd-rows{display:flex;flex-direction:column;gap:8px}
.cyd-row{display:flex;align-items:center;gap:12px;width:100%;text-align:left;
  border:1px solid var(--border-subtle);border-radius:12px;padding:11px 14px;background:var(--bg-elevated);
  cursor:pointer;transition:border-color .15s,transform .12s,box-shadow .15s}
.cyd-row:hover{border-color:var(--border-strong);transform:translateY(-1px);
  box-shadow:0 6px 18px -10px color-mix(in srgb,var(--accent) 45%,transparent)}
.cyd-row:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.cyd-row-static,.cyd-row-static:hover{cursor:default;transform:none;box-shadow:none;border-color:var(--border-subtle)}
.cyd-amt{font-family:var(--font-mono);font-weight:700;font-size:14px;color:var(--text-primary);white-space:nowrap}
.cyd-tok{color:var(--text-tertiary);font-weight:500}
.cyd-meta{flex:1;min-width:120px;font-size:12.5px;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cyd-meta code{font-family:var(--font-mono);font-size:11.5px;color:var(--text-tertiary)}
.cyd-right{display:flex;align-items:center;gap:10px;flex-shrink:0;flex-wrap:wrap;justify-content:flex-end}
.cyd-net{font-family:var(--font-mono);font-weight:700;font-size:13px;color:var(--text-primary)}
.cyd-go{font-family:var(--font-mono);font-size:11px;color:var(--accent);opacity:.7;white-space:nowrap}
.cyd-row:hover .cyd-go,.vf-tr-hover:hover .cyd-go,.cyd-trow:focus-visible .cyd-go{opacity:1}
.cyd-trow{cursor:pointer}
.cyd-trow:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}

/* ---- empty states ---- */
.cyd-empty{display:flex;align-items:center;gap:12px;border:1px dashed var(--border-default);border-radius:12px;
  padding:18px 16px;color:var(--text-tertiary);font-size:13px;background:var(--bg-elevated)}
.cyd-empty-ic{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;
  background:color-mix(in srgb,var(--success) 14%,transparent);color:var(--success);font-weight:700;flex-shrink:0}
.cyd-empty-ic-neutral{background:color-mix(in srgb,var(--text-tertiary) 16%,transparent);color:var(--text-tertiary)}
.cyd-empty-ic-err{background:color-mix(in srgb,var(--danger) 14%,transparent);color:var(--danger)}
.cyd-empty-err{border-color:var(--danger-border)}

/* ===== modal ===== */
.cyd-mhead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}
.cyd-sub{display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-top:6px}
.cyd-sub-time{font-size:11.5px;color:var(--text-tertiary);font-family:var(--font-mono)}
.cyd-mono{font-family:var(--font-mono)}
.cyd-dim{color:var(--text-tertiary)}
.cyd-neg{color:var(--danger)}
.cyd-link{color:var(--accent);text-decoration:none}
.cyd-link:hover{text-decoration:underline}
.cyd-ext{font-size:11px;color:var(--text-tertiary)}

/* ---- lifecycle timeline rail (slim header strip, not a tall card) ---- */
.cyd-timeline{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:12px;
  padding:8px 12px;border:1px solid var(--border-subtle);border-radius:10px;background:var(--bg-elevated)}
.cyd-tl-node{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:10.5px;
  font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--text-tertiary)}
.cyd-tl-node.is-done{color:var(--text-secondary)}
.cyd-tl-node.is-bad.is-done{color:var(--danger)}
.cyd-tl-node.is-warn.is-done{color:var(--accent)}
.cyd-tl-dot{width:8px;height:8px;border-radius:999px;background:color-mix(in srgb,var(--text-tertiary) 40%,transparent)}
.cyd-tl-node.is-done .cyd-tl-dot{background:var(--success)}
.cyd-tl-node.is-bad.is-done .cyd-tl-dot{background:var(--danger)}
.cyd-tl-node.is-warn.is-done .cyd-tl-dot{background:var(--accent)}
.cyd-tl-sep{flex:1;min-width:14px;height:2px;border-radius:999px;background:var(--border-default)}
.cyd-tl-sep.is-done{background:color-mix(in srgb,var(--success) 50%,transparent)}
.cyd-banner{margin-bottom:14px}

/* ---- two-column receipt with left-border accent stripe per column ---- */
.cyd-receipt{display:grid;grid-template-columns:1fr 1fr;gap:14px}
@media (max-width:640px){.cyd-receipt{grid-template-columns:1fr}}
.cyd-col{border:1px solid var(--border-subtle);border-radius:14px;padding:14px;background:var(--bg-elevated)}
.cyd-col-chain{border-left:3px solid var(--accent)}
.cyd-col-ledger{border-left:3px solid var(--success)}
.cyd-col-h{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;font-size:12px;
  text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);margin-bottom:10px}
.cyd-dot{width:8px;height:8px;border-radius:999px;flex-shrink:0}
.cyd-dot-chain{background:var(--accent)}
.cyd-dot-ledger{background:var(--success)}

.cyd-figure{margin-bottom:12px}
.cyd-figure-n{font-family:var(--font-display);font-weight:700;font-size:24px;line-height:1.1;color:var(--text-primary);word-break:break-word}
.cyd-net-big{color:var(--success)}
.cyd-figure-l{font-size:11.5px;color:var(--text-tertiary);margin-top:3px}

/* confirmations meter */
.cyd-conf{margin-bottom:12px}
.cyd-conf-top{display:flex;justify-content:space-between;font-size:11.5px;color:var(--text-secondary);margin-bottom:5px}
.cyd-meter{height:8px;border-radius:999px;background:color-mix(in srgb,var(--accent) 12%,transparent);overflow:hidden}
.cyd-meter-fill{height:100%;border-radius:999px;background-image:var(--vf-grad);transition:width .4s cubic-bezier(.4,0,.2,1)}
.cyd-conf.is-confirmed .cyd-meter-fill{background:var(--success)}
.cyd-conf-state{margin-top:7px}

/* gross − fee = net equation */
.cyd-flow{display:flex;align-items:stretch;gap:6px;margin-bottom:12px;padding:10px;border-radius:12px;
  border:1px solid var(--border-subtle);background:color-mix(in srgb,var(--success) 4%,transparent)}
.cyd-flow-cell{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}
.cyd-flow-lab{font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary);font-family:var(--font-mono)}
.cyd-flow-cell .cyd-mono{font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cyd-flow-net{color:var(--success);font-weight:700}
.cyd-flow-op{display:flex;align-items:center;color:var(--text-tertiary);font-family:var(--font-mono);font-size:13px;flex-shrink:0}

.cyd-kvs .dp-kv:last-child{border-bottom:0}

/* idempotency block */
.cyd-idem{display:flex;align-items:center;gap:10px;margin-top:12px;padding:10px 12px;border-radius:12px;
  border:1px solid var(--accent-border);background:var(--accent-bg)}
.cyd-idem-ic{font-size:15px}
.cyd-idem-h{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-family:var(--font-mono)}
.cyd-idem-k{display:block;font-family:var(--font-mono);font-size:11.5px;color:var(--text-secondary);word-break:break-all;margin-top:2px}

/* reject / return context callout */
.cyd-return{margin-top:14px}
.cyd-return-h{font-family:var(--font-display);font-weight:700;font-size:12px;text-transform:uppercase;
  letter-spacing:.06em;color:var(--text-tertiary);margin-bottom:6px}
.cyd-return .cyd-kvs .dp-kv:last-child{border-bottom:0}

/* wallet destination strip */
.cyd-wallet{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;
  margin-top:14px;padding:12px 14px;border:1px solid var(--border-subtle);border-radius:14px;background:var(--bg-elevated)}
.cyd-wallet-l{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.cyd-wallet-lab{font-size:10.5px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-tertiary);font-family:var(--font-mono)}
.cyd-wallet-id{display:flex;flex-direction:column;gap:1px;min-width:0}
.cyd-wallet-who{font-family:var(--font-display);font-weight:700;color:var(--text-primary);line-height:1.2}
.cyd-wallet-email{font-size:11px;color:var(--text-tertiary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:240px}
.cyd-wallet-r{display:flex;gap:18px;font-size:12.5px;color:var(--text-secondary)}
.cyd-wallet-r .dp-kv span:first-child{color:var(--text-tertiary)}

/* reject / mark-returned sub-forms */
.cyd-reject{margin-top:14px;padding:14px;border:1px solid var(--danger-border);border-radius:14px;
  background:color-mix(in srgb,var(--danger) 5%,transparent)}
#cyd-returned-form{border-color:var(--accent-border);background:var(--accent-bg)}
.cyd-reject-h{font-family:var(--font-display);font-weight:700;font-size:13px;margin-bottom:8px}

/* footer actions: quiet left, decisions right, separated by flex spacer */
.cyd-actions{flex-wrap:wrap;justify-content:space-between;gap:8px;align-items:center}
.cyd-act-left,.cyd-act-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.cyd-act-left{margin-right:auto}

/* These set display via class, so they need an explicit [hidden] override to
   respect the hidden attribute (this codebase has no global [hidden] rule).
   Without it the loading skeleton, the error box (.cyd-empty), and the empty
   return-context band (.dp-info) can never hide — they'd show on every deposit. */
.cyd-loading[hidden],.cyd-empty[hidden],.dp-info[hidden]{display:none}

/* loading skeleton */
.cyd-loading{display:flex;flex-direction:column;gap:10px;padding:8px 0}
.cyd-skel{height:14px;border-radius:6px;background:linear-gradient(90deg,var(--border-subtle),var(--border-default),var(--border-subtle));
  background-size:200% 100%;animation:cyd-shimmer 1.2s ease-in-out infinite}
@keyframes cyd-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ===== Stripe card top-up (.tu-*) — uses tokens.css vars, light+dark ===== */
.tu-packs{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (min-width:520px){.tu-packs{grid-template-columns:repeat(4,1fr)}}
.tu-pack{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:12px 14px;
  border:1px solid var(--border-default);border-radius:12px;background:var(--bg-elevated);cursor:pointer;
  transition:border-color .15s,transform .12s,box-shadow .15s;text-align:left}
.tu-pack:hover{border-color:var(--border-strong);transform:translateY(-1px)}
.tu-pack:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.tu-pack.on{border-color:var(--accent);background:var(--accent-bg);box-shadow:0 0 0 1px var(--accent) inset}
.tu-pack-pay{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--text-primary)}
.tu-pack-credits{font-size:11.5px;color:var(--text-tertiary)}
.tu-card-row{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--border-subtle);cursor:pointer}
.tu-card-row:last-of-type{border-bottom:0}
.tu-card-id{flex:1;font-size:13.5px;color:var(--text-primary)}
.tu-card-exp{font-size:11.5px;color:var(--text-tertiary);font-family:var(--font-mono)}
.tu-save{display:flex;align-items:center;gap:8px;margin-top:10px;font-size:13px;color:var(--text-secondary);cursor:pointer}
#tu-payment-element{min-height:20px;margin-top:4px}

/* ===== Card top-up RETURN / receipt — "the boom" (.tur-*) =====
   Append to static/css/responsive.css. tokens.css vars only; light + dark.
   Pairs with the .cyd-* receipt family (.cyd-skel/.cyd-loading) and
   .vf-card / .vf-btn-* / .vf-badge / .dp-kv / .dp-info. All motion is gated by
   prefers-reduced-motion. Hero number has a solid-color fallback before the
   gradient-clip-text fill so it is never invisible. */

.tur-wrap{max-width:560px;margin:0 auto;padding:18px 20px 64px}

/* the centered stage every state shares */
.tur-stage{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center}
.tur-stage>*{width:100%}

/* --- the glowing gradient success ring --- */
.tur-ring{position:relative;width:104px;height:104px;border-radius:999px;margin:14px auto 0;
  display:grid;place-items:center;padding:5px;
  background:var(--vf-grad);box-shadow:var(--vf-glow);
  animation:tur-ring-in .5s cubic-bezier(.2,.8,.25,1) both}
.tur-ring::before{content:"";position:absolute;inset:-9px;border-radius:999px;z-index:-1;
  background:radial-gradient(closest-side,color-mix(in srgb,var(--accent) 42%,transparent),transparent 78%);
  opacity:.85;animation:tur-glow 2.6s ease-in-out infinite}
.tur-ring-core{width:100%;height:100%;border-radius:999px;background:var(--bg-elevated);
  display:grid;place-items:center}

/* per-state ring tints (override the gradient + glow) */
.tur-ring--success{background:linear-gradient(135deg,var(--success),color-mix(in srgb,var(--success) 55%,var(--accent)))}
.tur-ring--success::before{background:radial-gradient(closest-side,color-mix(in srgb,var(--success) 46%,transparent),transparent 78%)}
.tur-ring--hold{background:var(--vf-grad)}
.tur-ring--fail{background:linear-gradient(135deg,var(--danger),color-mix(in srgb,var(--danger) 55%,var(--accent-active)))}
.tur-ring--fail::before{background:radial-gradient(closest-side,color-mix(in srgb,var(--danger) 38%,transparent),transparent 78%)}
.tur-ring--neutral{background:linear-gradient(135deg,var(--text-tertiary),color-mix(in srgb,var(--text-tertiary) 50%,var(--accent)))}
.tur-ring--neutral::before{background:radial-gradient(closest-side,color-mix(in srgb,var(--text-tertiary) 30%,transparent),transparent 80%)}
.tur-ring--confirm::before{opacity:.6}

/* glyphs sitting in the ring core */
.tur-glyph{width:42px;height:42px}
.tur-success .tur-glyph,.tur-success .tur-check{color:var(--success)}
.tur-hold .tur-glyph{color:var(--accent)}
.tur-fail .tur-glyph{color:var(--danger)}
.tur-neutral .tur-glyph,.tur-confirm .tur-glyph{color:var(--text-tertiary)}

/* the check that draws itself */
.tur-check{width:48px;height:48px;color:var(--success)}
.tur-check-path{stroke:currentColor;stroke-width:5;stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:48;stroke-dashoffset:48;
  animation:tur-draw .5s .28s cubic-bezier(.65,0,.35,1) forwards}

/* confirming: a gentle, calm pulse instead of a spinner */
.tur-ring--pulse .tur-glyph{animation:tur-spin 1.5s linear infinite}
.tur-clock-hand{transform-origin:12px 12px;animation:tur-tick 6s steps(12) infinite}

/* --- copy --- */
.tur-eyebrow{margin-top:18px;font-family:var(--font-mono);font-size:11px;font-weight:600;
  letter-spacing:.14em;text-transform:uppercase;color:var(--success)}
.tur-eyebrow--hold{color:var(--accent)}
.tur-head{margin-top:18px;font-family:var(--font-display);font-weight:700;font-size:23px;
  line-height:1.2;color:var(--text-primary);animation:tur-rise .45s .1s ease-out both}
.tur-sub{margin:10px auto 0;max-width:440px;font-size:13.5px;line-height:1.65;color:var(--text-secondary)}
.tur-sub b{color:var(--text-primary);font-weight:600}

/* the hero figure — the Credits received, scaling in.
   solid-color fallback FIRST, transparent gradient fill only where supported. */
.tur-hero{margin-top:6px;display:flex;flex-direction:column;align-items:center;gap:2px}
.tur-hero-n{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1;
  font-size:clamp(44px,12vw,60px);
  color:var(--accent);
  animation:tur-pop .55s .12s cubic-bezier(.2,1.3,.35,1) both}
.tur-success .tur-hero-n{color:var(--accent)}
@supports ((background-clip:text) or (-webkit-background-clip:text)){
  .tur-hero-n{background:var(--vf-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
  .tur-success .tur-hero-n{background:var(--vf-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
}
.tur-hero-l{font-size:13px;color:var(--text-secondary)}
.tur-balance{margin-top:8px;font-size:15px;color:var(--text-secondary)}
.tur-balance b{font-family:var(--font-mono);font-weight:700;color:var(--text-primary)}

/* --- receipt card (reuses .vf-card + .dp-kv) --- */
.tur-receipt{margin-top:22px;text-align:left;animation:tur-rise .5s .22s ease-out both}
.tur-receipt-h{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:12px}

/* single vertical itemized ledger — reads top-to-bottom like a real receipt */
.tur-ledger .dp-kv{padding:7px 0}
.tur-ledger .dp-kv:last-child{border-bottom:0}
.tur-mono{font-family:var(--font-mono)}
.tur-fee{color:var(--text-tertiary)}
.tur-kv-received .tur-received{color:var(--success);font-weight:700}
.tur-kv-received--hold{background:color-mix(in srgb,var(--accent) 5%,transparent)}
.tur-flow-hold{color:var(--accent);font-weight:700;display:inline-flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end}
.tur-inline-badge{font-weight:500}
.tur-kv-total{margin-top:2px;padding-top:11px;border-top:1px solid var(--border-default)}
.tur-card{font-family:var(--font-mono);font-size:12.5px;color:var(--text-primary)}
.tur-dots{color:var(--text-tertiary);letter-spacing:.05em}
.tur-strong{font-family:var(--font-mono);font-weight:700;color:var(--text-primary)}

.tur-note{margin-top:16px;text-align:left;border-color:var(--danger-border);
  background:color-mix(in srgb,var(--danger) 5%,var(--bg-surface))}

.tur-skelcard{animation:none}

/* --- CTAs --- */
.tur-cta{display:flex;flex-wrap:wrap;justify-content:center;gap:10px;margin-top:24px}
.tur-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;min-width:150px}
.tur-arrow{transition:transform .18s ease}
.tur-btn--go:hover .tur-arrow{transform:translateX(3px)}

/* --- soft confetti (one burst, then gone) --- */
.tur-confetti{position:absolute;top:54px;left:50%;width:0;height:0;pointer-events:none;z-index:2}
.tur-confetti span{position:absolute;top:0;left:0;width:8px;height:8px;border-radius:2px;opacity:0;
  animation:tur-confetti 1.15s .18s ease-out forwards}
.tur-confetti span:nth-child(1){background:var(--accent);--tx:-92px;--tr:-160deg;animation-delay:.16s}
.tur-confetti span:nth-child(2){background:var(--success);--tx:-58px;--tr:120deg;width:6px;height:6px;animation-delay:.22s}
.tur-confetti span:nth-child(3){background:var(--vf-ion);--tx:-30px;--tr:-90deg;animation-delay:.12s}
.tur-confetti span:nth-child(4){background:var(--vf-deep);--tx:-12px;--tr:200deg;width:7px;height:7px;animation-delay:.2s}
.tur-confetti span:nth-child(5){background:var(--success);--tx:14px;--tr:-140deg;animation-delay:.14s}
.tur-confetti span:nth-child(6){background:var(--accent);--tx:34px;--tr:90deg;width:6px;height:6px;animation-delay:.24s}
.tur-confetti span:nth-child(7){background:var(--vf-ion);--tx:60px;--tr:-200deg;animation-delay:.18s}
.tur-confetti span:nth-child(8){background:var(--success);--tx:90px;--tr:150deg;width:7px;height:7px;animation-delay:.1s}
.tur-confetti span:nth-child(9){background:var(--accent);--tx:-74px;--tr:60deg;width:5px;height:5px;animation-delay:.26s}
.tur-confetti span:nth-child(10){background:var(--vf-deep);--tx:76px;--tr:-60deg;width:5px;height:5px;animation-delay:.3s}
.tur-confetti span:nth-child(11){background:var(--vf-ion);--tx:-46px;--tr:240deg;animation-delay:.28s}
.tur-confetti span:nth-child(12){background:var(--success);--tx:48px;--tr:-240deg;animation-delay:.32s}

/* --- keyframes --- */
@keyframes tur-ring-in{from{opacity:0;transform:scale(.6)}to{opacity:1;transform:scale(1)}}
@keyframes tur-glow{0%,100%{opacity:.55;transform:scale(.96)}50%{opacity:.95;transform:scale(1.06)}}
@keyframes tur-draw{to{stroke-dashoffset:0}}
@keyframes tur-pop{0%{opacity:0;transform:scale(.78)}60%{transform:scale(1.04)}100%{opacity:1;transform:scale(1)}}
@keyframes tur-rise{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes tur-spin{to{transform:rotate(360deg)}}
@keyframes tur-tick{to{transform:rotate(360deg)}}
@keyframes tur-confetti{
  0%{opacity:0;transform:translate(0,0) rotate(0) scale(.5)}
  12%{opacity:1}
  100%{opacity:0;transform:translate(var(--tx,0),-46px) rotate(var(--tr,180deg)) scale(1)}}

/* --- dark-surface tints: the token flips handle most of it, but the
   gradient-tinted ledger rows + danger note read better with a touch more
   contrast on the #0C1322 dark surface. --- */
html.dark .tur-kv-received--hold{background:color-mix(in srgb,var(--accent) 9%,transparent)}
html.dark .tur-note{background:color-mix(in srgb,var(--danger) 9%,var(--bg-surface))}

/* --- small phones: keep the inline hold badge from crowding the amount,
   and let any future flow rows stack instead of ellipsizing dollar values --- */
@media (max-width:380px){
  .tur-wrap{padding:14px 14px 56px}
  .tur-flow-hold{justify-content:flex-end}
  .tur-card{font-size:11.5px}
  .tur-btn{min-width:100%}
}

/* --- reduced motion: render everything instant + static --- */
@media (prefers-reduced-motion: reduce){
  .tur-ring,.tur-head,.tur-hero-n,.tur-receipt{animation:none}
  .tur-ring::before{animation:none;opacity:.7}
  .tur-check-path{animation:none;stroke-dashoffset:0}
  .tur-ring--pulse .tur-glyph,.tur-clock-hand{animation:none}
  .tur-confetti{display:none}
  .cyd-skel{animation:none}
  .tur-arrow{transition:none}
}
/* ============================================================================
   /panel/payments — Stripe cockpit. Namespaced .sd-*; builds ONLY on tokens.css
   vars + the existing .cyd-* / .em-tab / .vf-* families. Light + dark auto-flip
   via vars; all motion gated by prefers-reduced-motion at the bottom.
   Append to static/css/responsive.css (where .cyd-* / .em-tab* / .tur-* live).
   ============================================================================ */

/* ---- rail switcher head ---- */
.sd-railhead{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;margin-top:8px}
.sd-rail .em-tab{display:inline-flex;align-items:center;text-decoration:none}
.sd-railmeta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sd-mode{font-family:var(--font-mono);letter-spacing:.04em}
.sd-mode-live{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}
.sd-settle{font-family:var(--font-mono);font-size:11px;color:var(--warning);
  border:1px dashed color-mix(in srgb,var(--warning) 55%,transparent);border-radius:999px;padding:3px 10px;
  background:color-mix(in srgb,var(--warning) 8%,transparent)}

/* ---- STAT CARDS (gradient-accented fintech glance) ---- */
.sd-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:860px){.sd-stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:460px){.sd-stats{grid-template-columns:1fr}}
.sd-stat{position:relative;overflow:hidden;display:block;text-decoration:none;
  border:1px solid var(--border-subtle);border-radius:16px;padding:15px 16px;
  background:var(--bg-elevated);transition:transform .15s,border-color .15s,box-shadow .15s}
a.sd-stat:hover{transform:translateY(-2px);border-color:var(--border-strong);box-shadow:var(--shadow-md)}
.sd-stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background-image:var(--vf-grad);opacity:.85}
.sd-stat-top{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.sd-stat-ic{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:8px;
  background:color-mix(in srgb,var(--accent) 14%,transparent);color:var(--accent);font-size:13px;flex:none}
.sd-stat-l{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}
.sd-stat-n{font-family:var(--font-display);font-weight:700;font-size:27px;line-height:1.05;color:var(--text-primary);
  font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.sd-stat-sub{font-size:11.5px;color:var(--text-tertiary);margin-top:4px}

/* gradient-clipped HERO number (Credited today) — solid fallback FIRST, then a
   guarded clip exactly like .tur-hero-n at responsive.css:2452. Never invisible
   on engines without background-clip:text. */
.sd-stat-hero .sd-stat-n{color:var(--accent)}
@supports ((background-clip:text) or (-webkit-background-clip:text)){
  .sd-stat-hero .sd-stat-n{background:var(--vf-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
}

/* hot/danger/neg accents per card */
.sd-stat-await.is-hot::before{background:linear-gradient(180deg,var(--warning),var(--accent))}
.sd-stat-await.is-hot .sd-stat-ic{background:color-mix(in srgb,var(--warning) 16%,transparent);color:var(--warning)}
.sd-stat-dispute.is-danger::before{background:var(--danger)}
.sd-stat-dispute.is-danger .sd-stat-ic{background:color-mix(in srgb,var(--danger) 16%,transparent);color:var(--danger)}
.sd-stat-dispute.is-danger .sd-stat-n{color:var(--danger)}
.sd-stat-margin.is-neg::before{background:var(--danger)}
.sd-stat-margin.is-neg .sd-stat-n{color:var(--danger)}
.sd-stat-margin .sd-stat-ic{background:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}
.sd-fx{font-family:var(--font-mono);color:var(--text-tertiary)}

/* ---- settings tab-strip + panels ---- */
.sd-settabs .em-tab{display:inline-flex;align-items:center;gap:6px}
.sd-settab[hidden]{display:none}
.sd-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media (max-width:680px){.sd-grid{grid-template-columns:repeat(2,1fr)}}
.sd-f{display:flex;flex-direction:column;gap:4px}

/* card-style toggles: bordered, accent-tinted when checked (:has has 8 precedents) */
.sd-toggles{display:flex;flex-direction:column;gap:10px;padding-top:4px}
.sd-toggle{display:flex;align-items:flex-start;gap:10px;padding:11px 13px;border:1px solid var(--border-subtle);
  border-radius:12px;background:var(--bg-elevated);font-size:13px;color:var(--text-secondary);cursor:pointer;transition:border-color .15s,background .15s}
.sd-toggle:hover{border-color:var(--border-default)}
.sd-toggle:has(input:checked){border-color:var(--accent-border);background:var(--accent-bg)}
.sd-toggle input{margin-top:2px;flex:none}
.sd-toggle-txt{display:flex;flex-direction:column;gap:2px;line-height:1.45}
.sd-toggle-txt b{color:var(--text-primary);font-weight:600}
.sd-toggle-txt em{font-style:normal;font-size:11.5px;color:var(--text-tertiary)}

/* keys + webhook health */
.sd-keys{display:flex;flex-direction:column;margin-bottom:12px}
.sd-keys .dp-kv code{font-size:11.5px}
.sd-health{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
@media (max-width:680px){.sd-health{grid-template-columns:1fr}}
.sd-health-card{border:1px solid var(--border-subtle);border-radius:12px;padding:12px;background:var(--bg-elevated)}
.sd-health-l{font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}
.sd-health-v{font-family:var(--font-display);font-weight:700;font-size:16px;color:var(--text-primary);margin-top:4px}
.sd-health-v.sd-bad{color:var(--danger)}
.sd-health-of{font-size:11px;font-weight:400;color:var(--text-tertiary)}
.sd-bad{color:var(--danger)}
.sd-health-s{font-size:11px;color:var(--text-tertiary);margin-top:2px}

/* ---- Disputes tab urgency ---- */
.sd-disputes-tab.is-open:not(.on){color:var(--danger)}
.sd-disputes-tab.is-open:not(.on) .cyd-pill{background:color-mix(in srgb,var(--danger) 18%,transparent);color:var(--danger)}
.sd-dispute-row{border-color:var(--danger-border)}
.sd-dispute-row:hover{border-color:var(--danger)}

/* evidence-due chip (its own clock — list rows) */
.sd-evchip{display:inline-flex;align-items:center;font-family:var(--font-mono);font-size:10.5px;font-weight:700;
  letter-spacing:.02em;padding:3px 9px;border-radius:999px;white-space:nowrap}
.sd-ev-ok{background:color-mix(in srgb,var(--accent) 13%,transparent);color:var(--accent)}
.sd-ev-soon{background:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}
.sd-ev-over{background:color-mix(in srgb,var(--danger) 16%,transparent);color:var(--danger);animation:sd-pulse 1.6s ease-in-out infinite}
.sd-ev-none{background:color-mix(in srgb,var(--text-tertiary) 14%,transparent);color:var(--text-tertiary)}

/* ---- modal: dispute urgency band — facts + clock tile + exposure card ---- */
.sd-dispute-band{border:1px solid var(--danger-border);border-radius:14px;padding:13px 15px;margin-bottom:12px;
  background:color-mix(in srgb,var(--danger) 6%,var(--bg-surface))}
.sd-dispute-band[hidden]{display:none}
.sd-dispute-h{display:flex;align-items:center;gap:7px;font-family:var(--font-display);font-weight:700;font-size:13px;color:var(--danger);margin-bottom:10px}
.sd-dispute-ic{font-size:15px}
.sd-dispute-layout{display:flex;gap:14px;align-items:stretch;flex-wrap:wrap}
.sd-dispute-facts{flex:1 1 240px;display:grid;grid-template-columns:repeat(2,1fr);gap:10px 18px;align-content:start;min-width:0}
@media (max-width:520px){.sd-dispute-facts{grid-template-columns:1fr}}
.sd-dispute-facts>div{display:flex;flex-direction:column;gap:3px;min-width:0}
.sd-dispute-l{font-family:var(--font-mono);font-size:9.5px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-tertiary)}
.sd-dispute-facts .cyd-mono,.sd-dispute-facts span:last-child{font-size:13.5px;font-weight:700;color:var(--text-primary);word-break:break-word}

/* the boxed countdown 'clock' tile */
.sd-dispute-clock-tile{flex:0 0 132px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;
  padding:10px 12px;border-radius:12px;border:1px solid var(--danger-border);
  background:color-mix(in srgb,var(--danger) 10%,var(--bg-elevated));text-align:center}
.sd-clock-n{font-family:var(--font-display);font-weight:700;font-size:22px;line-height:1;color:var(--danger);text-transform:uppercase;letter-spacing:.02em}
.sd-clock-l{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--danger)}
.sd-clock-when{font-family:var(--font-mono);font-size:10.5px;color:var(--text-secondary);margin-top:3px;line-height:1.3}
.sd-dispute-clock-tile.sd-clock-none{border-color:var(--border-default);background:var(--bg-elevated)}
.sd-dispute-clock-tile.sd-clock-none .sd-clock-n,.sd-dispute-clock-tile.sd-clock-none .sd-clock-l{color:var(--text-tertiary)}

/* explicit covered / spent loss-exposure card */
.sd-dispute-exposure{margin-top:11px;padding:10px 12px;border-radius:12px;border:1px solid var(--border-subtle)}
.sd-dispute-exposure.is-covered{border-color:var(--success-border);background:color-mix(in srgb,var(--success) 7%,var(--bg-elevated))}
.sd-dispute-exposure.is-spent{border-color:var(--danger-border);background:color-mix(in srgb,var(--danger) 8%,var(--bg-elevated))}
.sd-exp-h{font-family:var(--font-display);font-weight:700;font-size:12.5px}
.sd-dispute-exposure.is-covered .sd-exp-h{color:var(--success)}
.sd-dispute-exposure.is-spent .sd-exp-h{color:var(--danger)}
.sd-exp-sub{font-size:11.5px;line-height:1.5;color:var(--text-secondary);margin-top:3px}

/* ---- modal: admin-only MARGIN sub-line ---- */
.sd-margin{margin-top:12px;border:1px solid var(--border-subtle);border-radius:12px;padding:11px 12px;
  background:color-mix(in srgb,var(--success) 5%,var(--bg-elevated))}
.sd-margin-neg{border-color:var(--danger-border);background:color-mix(in srgb,var(--danger) 6%,var(--bg-elevated))}
.sd-margin-fx{border-style:dashed;background:var(--bg-elevated)}
.sd-margin-h{display:flex;align-items:center;justify-content:space-between;
  font-family:var(--font-mono);font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary);margin-bottom:7px}
.sd-margin-tag{font-size:9.5px;padding:2px 7px;border-radius:999px;letter-spacing:.04em}
.sd-tag-est{background:color-mix(in srgb,var(--warning) 16%,transparent);color:var(--warning)}
.sd-tag-settled{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}
.sd-tag-fx{background:color-mix(in srgb,var(--accent) 15%,transparent);color:var(--accent)}
.sd-margin-eq{display:flex;align-items:stretch;gap:8px;font-size:12px;color:var(--text-secondary)}
.sd-margin-fx .sd-margin-eq{line-height:1.5;display:block}
.sd-mg-cell{display:flex;flex-direction:column;gap:1px;flex:1;min-width:0}
.sd-mg-l{font-size:9px;text-transform:uppercase;letter-spacing:.05em;color:var(--text-tertiary);font-family:var(--font-mono)}
.sd-mg-cell .cyd-mono{font-size:13px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.sd-mg-net{font-weight:700;color:var(--success)}
.sd-mg-net.sd-neg,.sd-neg{color:var(--danger)}
.sd-mg-op{display:flex;align-items:center;color:var(--text-tertiary);font-family:var(--font-mono);font-size:13px;flex:none}

/* clawback debt cell in the wallet strip — explicit [hidden] override because
   .dp-kv is display:flex and this codebase has no global [hidden] rule. */
.sd-clawback[hidden]{display:none}

/* ---- motion / a11y ---- */
@keyframes sd-pulse{0%,100%{opacity:1}50%{opacity:.55}}
@media (prefers-reduced-motion:reduce){
  .sd-stat,a.sd-stat:hover{transition:none;transform:none}
  .sd-ev-over{animation:none}
}
/* ===== Accounting hub (/panel/accounting) ===== */
.ac-recon{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}
.ac-recon-ok{border-color:color-mix(in srgb,var(--success) 40%,var(--border))}
.ac-recon-bad{border-color:color-mix(in srgb,var(--danger) 45%,var(--border))}
.ac-tabs{flex-wrap:wrap}
.ac-panel .vf-table{width:100%}

/* ===== Accounting dashboards ===== */
.ac-metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
@media (max-width:860px){.ac-metrics{grid-template-columns:repeat(2,1fr)}}
@media (max-width:460px){.ac-metrics{grid-template-columns:1fr}}
.ac-bars{display:flex;align-items:flex-end;gap:6px;height:160px;padding:8px 0}
.ac-bar{flex:1;display:flex;flex-direction:column;align-items:center;height:100%}
.ac-bar-stack{flex:1;width:60%;min-width:14px;display:flex;flex-direction:column-reverse;justify-content:flex-start;
  background:var(--bg-subtle);border-radius:4px 4px 0 0;overflow:hidden}
.ac-bar-seg{width:100%}
.ac-bar-crypto{background:var(--accent)}
.ac-bar-stripe{background:#7c5cff}
.ac-bar-other{background:var(--text-tertiary)}
.ac-bar-lbl{font-size:10px;color:var(--text-tertiary);margin-top:4px;font-family:var(--font-mono)}
.ac-key{display:inline-block;width:9px;height:9px;border-radius:2px;margin:0 2px 0 8px;vertical-align:middle}
.ac-key-crypto{background:var(--accent)}
.ac-key-stripe{background:#7c5cff}

/* ============================================================================
   PAYOUTS (.po-*) — customer get-paid flow + admin console extras.
   Cockpit-consistent: reuses .sd-* / .cyd-* / .tur-* / .vf-* idioms. Light+dark via tokens.
   ============================================================================ */
/* ---- customer: owed hero (boom-grade gradient figure) ---- */
.po-hero{position:relative;overflow:hidden;display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;
  border:1px solid var(--border-subtle);border-radius:18px;padding:20px 22px;background:var(--bg-elevated);box-shadow:var(--shadow-sm)}
.po-hero::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background-image:var(--vf-grad);opacity:.9}
.po-hero.is-ready::before{background:linear-gradient(180deg,var(--success),color-mix(in srgb,var(--success) 55%,var(--accent)))}
.po-hero-main{min-width:0}
.po-hero-eyebrow{font-family:var(--font-mono);font-size:10.5px;text-transform:uppercase;letter-spacing:.07em;color:var(--text-tertiary)}
.po-hero-n{font-family:var(--font-display);font-weight:700;letter-spacing:-.02em;line-height:1;font-size:clamp(34px,8vw,46px);
  color:var(--accent);margin-top:4px;font-variant-numeric:tabular-nums;animation:tur-pop .55s .08s cubic-bezier(.2,1.3,.35,1) both}
@supports ((background-clip:text) or (-webkit-background-clip:text)){
  .po-hero-n{background:var(--vf-grad);-webkit-background-clip:text;background-clip:text;color:transparent}
  .po-hero.is-ready .po-hero-n{background:linear-gradient(118deg,var(--success),color-mix(in srgb,var(--success) 50%,var(--accent)));-webkit-background-clip:text;background-clip:text;color:transparent}
}
.po-hero-sub{display:block;font-size:12px;color:var(--text-tertiary);margin-top:8px}
.po-hero-side{display:flex;flex-direction:column;align-items:flex-end;gap:6px;text-align:right}
.po-hero-badge{align-self:flex-end}
.po-hero-note{font-size:11.5px;color:var(--text-tertiary);max-width:180px;line-height:1.45}
.po-hero .po-hero-confetti{top:24px;left:34px}
/* ---- customer: rail-aware "add a method" prompt ---- */
.po-prompt{display:flex;align-items:flex-start;gap:12px;border-color:var(--accent-border);background:var(--accent-bg)}
.po-prompt-ic{font-size:22px;line-height:1.2;flex:none}
.po-prompt b{color:var(--text-primary);font-weight:600}
/* ---- customer: early-payout hero (amber accent, distinct from the owed hero) ---- */
.po-early::before{background:linear-gradient(180deg,var(--warning,#f5a524),color-mix(in srgb,var(--warning,#f5a524) 55%,var(--accent)))}
@supports (background:linear-gradient(in srgb,red,red)){
  .po-early .po-hero-n{background:linear-gradient(118deg,var(--warning,#f5a524),color-mix(in srgb,var(--warning,#f5a524) 50%,var(--accent)));-webkit-background-clip:text;background-clip:text;color:transparent}
}
/* ---- customer: setup spine ---- */
.po-spine{display:flex;align-items:flex-start;gap:0;border:1px solid var(--border-subtle);border-radius:16px;padding:16px 14px;background:var(--bg-elevated)}
.po-node{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;gap:4px;min-width:0;padding:0 6px}
.po-node-mark{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:999px;
  font-family:var(--font-display);font-weight:700;font-size:13px;border:1px solid var(--border-default);background:var(--bg-elevated);color:var(--text-tertiary);transition:all .2s}
.po-node.is-active .po-node-mark{border-color:var(--accent);color:var(--accent);background:var(--accent-bg);box-shadow:0 0 0 4px var(--accent-bg)}
.po-node.is-done .po-node-mark{border-color:transparent;background-image:var(--vf-grad);color:#fff}
.po-node.is-skip .po-node-mark{border-style:dashed;color:var(--text-tertiary)}
.po-node-l{font-size:12px;font-weight:600;color:var(--text-secondary)}
.po-node.is-active .po-node-l,.po-node.is-done .po-node-l{color:var(--text-primary)}
.po-node-s{font-size:10.5px;color:var(--text-tertiary);line-height:1.3}
.po-node-link{flex:0 0 22px;height:2px;margin-top:15px;border-radius:2px;background:var(--border-default)}
.po-node-link.is-done{background-image:var(--vf-grad)}
@media (max-width:560px){
  .po-spine{flex-direction:column;align-items:stretch;gap:10px}
  .po-node{flex-direction:row;text-align:left;align-items:center;gap:10px}
  .po-node-mark{flex:none}
  .po-node-link{display:none}
}
/* ---- customer: step cards ---- */
.po-step-card{border:1px solid var(--border-subtle);border-radius:16px;padding:16px 18px;background:var(--bg-elevated)}
.po-step-card.is-active{border-color:var(--accent-border);box-shadow:var(--vf-glow)}
.po-opt{font-size:10px;font-weight:400;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.04em}
.po-save{margin-top:14px}
.po-warn{margin-top:12px;border-color:var(--warning-border);background:color-mix(in srgb,var(--warning) 6%,var(--bg-surface))}
.po-secure{font-size:11.5px;color:var(--text-tertiary);margin-top:10px}
/* ---- customer: rail choice cards ---- */
.po-rails{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:12px}
@media (max-width:560px){.po-rails{grid-template-columns:1fr}}
.po-rail{position:relative;display:flex;align-items:flex-start;gap:12px;padding:15px;border:1px solid var(--border-subtle);
  border-radius:14px;background:var(--bg-elevated);cursor:pointer;transition:border-color .15s,background .15s,transform .15s}
.po-rail:hover{border-color:var(--border-default);transform:translateY(-1px)}
.po-rail input{position:absolute;opacity:0;pointer-events:none}
.po-rail:has(input:checked){border-color:var(--accent-border);background:var(--accent-bg);box-shadow:var(--vf-glow)}
.po-rail-ic{font-size:24px;line-height:1;flex:none}
.po-rail-body{display:flex;flex-direction:column;gap:4px;min-width:0}
.po-rail-t{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text-primary)}
.po-rail-d{font-size:12px;color:var(--text-secondary);line-height:1.45}
.po-rail-stats{font-family:var(--font-mono);font-size:10.5px;color:var(--text-tertiary);margin-top:2px;letter-spacing:.01em}
.po-rail-stats b{color:var(--accent);font-weight:700}
.po-rail-tick{position:absolute;top:12px;right:12px;width:20px;height:20px;border-radius:999px;display:inline-flex;
  align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;background-image:var(--vf-grad);opacity:0;transform:scale(.5);transition:all .18s}
.po-rail:has(input:checked) .po-rail-tick{opacity:1;transform:scale(1)}
.po-detail[hidden]{display:none}
/* ---- customer: KYC + tax trust tiles ---- */
.po-trust{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:560px){.po-trust{grid-template-columns:1fr}}
.po-tile{position:relative;overflow:hidden;border:1px solid var(--border-subtle);border-radius:16px;padding:16px 18px;background:var(--bg-elevated)}
.po-tile.is-pending::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--accent)}
.po-tile.is-done::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--success)}
.po-tile-head{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;margin-bottom:8px}
.po-tile-t{font-family:var(--font-display);font-weight:700;font-size:15px;color:var(--text-primary)}
.po-tile-d{font-size:12.5px;line-height:1.6;color:var(--text-secondary)}
.po-tile-d b{color:var(--text-primary);font-weight:600}
/* ---- customer: methods on file ---- */
.po-methods{display:flex;flex-direction:column;gap:8px;margin-top:10px}
.po-method{position:relative;overflow:hidden;display:flex;align-items:center;gap:12px;padding:12px 14px;border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg-elevated)}
.po-method.is-default::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background-image:var(--vf-grad)}
.po-method-ic{font-size:18px;flex:none}
.po-method-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.po-method-d{font-size:12.5px;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.po-method-label{font-size:11px;color:var(--text-tertiary)}
.po-method-r{display:flex;align-items:center;gap:6px;flex-wrap:wrap;justify-content:flex-end}
/* ---- customer: empty / rail-off ---- */
.po-empty{display:flex;flex-direction:column;align-items:center;text-align:center;gap:10px;padding:36px 22px;border:1px dashed var(--border-default);border-radius:18px;background:var(--bg-elevated)}
.po-empty-t{font-family:var(--font-display);font-weight:700;font-size:17px;color:var(--text-primary)}
.po-empty-s{font-size:13px;color:var(--text-secondary);max-width:340px;line-height:1.6}
/* ---- admin: GREEN 'Ready to pay' stat ---- */
.po-stat-ready.is-ready-pos::before{background:linear-gradient(180deg,var(--success),color-mix(in srgb,var(--success) 50%,var(--accent)))}
.po-stat-ready.is-ready-pos .sd-stat-ic{background:color-mix(in srgb,var(--success) 16%,transparent);color:var(--success)}
.po-stat-ready.is-ready-pos .sd-stat-n{color:var(--success)}
/* ---- admin: settings single-form save row + queue extras ---- */
.po-settab-save[hidden]{display:none}
.po-settab-save{margin-top:4px}
.po-railtag{display:inline-flex;align-items:center;gap:5px}
.po-railtag-none{color:var(--text-tertiary);font-style:italic}
.po-row-blocked{opacity:.82}
.po-blockwhy{font-size:11px;color:var(--text-tertiary)}
/* ---- motion / a11y ---- */
@media (prefers-reduced-motion:reduce){
  .po-hero-n{animation:none}
  .po-rail:hover,.po-rail-tick{transition:none;transform:none}
}
