/* ================================================================
   DEX LEDGER — UI/UX OVERHAUL EXTRAS
   Additional component styles and refinements
   ================================================================ */

/* ================================================================
   CUSTOM DROPDOWN NAV
   Replaces the native <select> category nav with styled dropdowns.
   ================================================================ */

/* ---- Group wrapper ---- */
.category-nav__group {
  position: relative;
}

/* ---- Trigger button ---- */
.nav-drop__trigger {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--oh-border);
  border-radius: 8px;
  color: var(--oh-text-2);
  font-size: 0.8rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  white-space: nowrap;
  cursor: pointer;
  transition: color 0.15s ease, background 0.15s ease, border-color 0.15s ease;
  font-family: var(--oh-font-ui);
}
.nav-drop__trigger:hover {
  background: rgba(255,255,255,0.08);
  color: var(--oh-text);
  border-color: rgba(201,168,76,0.3);
}
.nav-drop.is-open .nav-drop__trigger {
  color: var(--oh-gold);
  background: rgba(201,168,76,0.08);
  border-color: rgba(201,168,76,0.4);
}

/* ---- Chevron icon ---- */
.nav-drop__chevron {
  width: 10px;
  height: 10px;
  transition: transform 0.18s ease;
  flex-shrink: 0;
  opacity: 0.7;
}
.nav-drop.is-open .nav-drop__chevron {
  transform: rotate(180deg);
  opacity: 1;
}

/* ---- Dropdown panel ---- */
.nav-drop__panel {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  z-index: 300;
  min-width: 200px;
  background: var(--oh-card);
  border: 1px solid var(--oh-border);
  border-radius: 12px;
  box-shadow: 0 12px 40px rgba(0,0,0,0.55), 0 2px 8px rgba(0,0,0,0.3);
  padding: 5px;
  overflow: hidden;
  /* Animate open */
  animation: nav-drop-in 0.14s ease forwards;
}
@keyframes nav-drop-in {
  from { opacity: 0; transform: translateY(-6px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0)    scale(1); }
}

/* ---- Panel items ---- */
.nav-drop__item {
  display: block;
  width: 100%;
  padding: 9px 14px;
  background: transparent;
  border: none;
  border-radius: 8px;
  color: var(--oh-text-2);
  font-size: 0.82rem;
  font-weight: 500;
  text-align: left;
  white-space: nowrap;
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
  font-family: var(--oh-font-ui);
}
.nav-drop__item:hover {
  background: rgba(255,255,255,0.07);
  color: var(--oh-text);
}
.nav-drop__item:active {
  background: rgba(201,168,76,0.1);
  color: var(--oh-gold);
}

/* ---- Light mode ---- */
:root[data-theme="light"] .nav-drop__trigger {
  background: rgba(0,0,0,0.04);
  border-color: rgba(0,0,0,0.12);
  color: var(--oh-text-2);
}
:root[data-theme="light"] .nav-drop__trigger:hover {
  background: rgba(0,0,0,0.07);
}
:root[data-theme="light"] .nav-drop__panel {
  background: var(--oh-card);
  box-shadow: 0 8px 24px rgba(0,0,0,0.15), 0 2px 6px rgba(0,0,0,0.1);
}
:root[data-theme="light"] .nav-drop__item:hover {
  background: rgba(0,0,0,0.06);
}

/* ================================================================
   HAMBURGER BUTTON — visible on all screen sizes
   ================================================================ */
.nav-hamburger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  height: 38px;
  padding: 0 12px 0 10px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--oh-border);
  border-radius: 8px;
  color: var(--oh-text-2);
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation; /* prevents 300ms tap delay + double-fire on mobile */
  position: relative;
  z-index: 540;
}
.nav-hamburger:hover,
.nav-hamburger[aria-expanded="true"] {
  background: rgba(201,168,76,0.1);
  color: var(--oh-gold);
  border-color: rgba(201,168,76,0.35);
}
.nav-hamburger__label {
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
}
.nav-hamburger-host {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto 12px;
}
.nav-hamburger-host--standalone {
  position: relative;
  z-index: 5;
}
/* Hide label on very small screens */
@media (max-width: 360px) {
  .nav-hamburger__label { display: none; }
}

/* Language selector sitting next to the nav button */
.nav-lang-select {
  height: 38px;
  padding: 0 10px;
  font-size: 0.78rem;
}

/* ================================================================
   NAVIGATION DRAWER (mobile full-screen slide-in)
   ================================================================ */

/* Backdrop */
.nav-drawer-overlay {
  position: fixed;
  inset: 0;
  z-index: 490;
  background: rgba(0,0,0,0.65);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.25s ease;
  backdrop-filter: blur(3px);
  -webkit-backdrop-filter: blur(3px);
}
.nav-drawer-overlay.is-visible {
  opacity: 1;
  pointer-events: auto;
}

/* Drawer panel — always in DOM, slides in/out via .is-open class */
.nav-drawer {
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  z-index: 500;
  width: min(320px, 88vw);
  background: var(--oh-surface);
  border-left: 1px solid var(--oh-border);
  display: flex;
  flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.28s cubic-bezier(0.4,0,0.2,1);
  overflow: hidden;
  pointer-events: none;
}
.nav-drawer.is-open {
  transform: translateX(0);
  pointer-events: auto;
}

/* Drawer header */
.nav-drawer__header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--oh-border);
  flex-shrink: 0;
}
.nav-drawer__title {
  font-family: var(--oh-font-head);
  font-size: 1rem;
  font-weight: 700;
  color: var(--oh-text);
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.nav-drawer__close {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 34px;
  height: 34px;
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--oh-border);
  border-radius: 8px;
  color: var(--oh-text-3);
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
}
.nav-drawer__close:hover {
  background: rgba(255,255,255,0.1);
  color: var(--oh-text);
}

/* Scrollable body */
.nav-drawer__body {
  flex: 1;
  overflow-y: auto;
  padding: 12px 12px 0;
  -webkit-overflow-scrolling: touch;
}

/* Section */
.nav-drawer__section {
  margin-bottom: 4px;
}
.nav-drawer__section-title {
  font-family: var(--oh-font-head);
  font-size: 0.65rem;
  font-weight: 800;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--oh-gold-2);
  padding: 14px 8px 6px;
  margin: 0;
}

/* List */
.nav-drawer__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

/* Items */
.nav-drawer__item {
  display: block;
  width: 100%;
  padding: 11px 14px;
  background: transparent;
  border: none;
  border-radius: 10px;
  color: var(--oh-text-2);
  font-size: 0.9rem;
  font-weight: 500;
  text-align: left;
  cursor: pointer;
  transition: background 0.12s ease, color 0.12s ease;
  font-family: var(--oh-font-ui);
  -webkit-tap-highlight-color: transparent;
}
.nav-drawer__item:hover,
.nav-drawer__item:focus-visible {
  background: rgba(255,255,255,0.07);
  color: var(--oh-text);
  outline: none;
}
.nav-drawer__item:active {
  background: rgba(201,168,76,0.1);
  color: var(--oh-gold);
}

/* Empty state */
.nav-drawer__empty {
  padding: 20px 8px;
  color: var(--oh-text-3);
  font-size: 0.85rem;
}

/* Footer */
.nav-drawer__footer {
  padding: 14px 20px;
  border-top: 1px solid var(--oh-border);
  flex-shrink: 0;
}
.nav-drawer__footer-actions {
  display: grid;
  gap: 10px;
}
.nav-drawer__footer-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--oh-text-3);
  font-size: 0.8rem;
  font-weight: 600;
  text-decoration: none;
  transition: color 0.15s ease;
}
.nav-drawer__footer-link:hover {
  color: var(--oh-gold);
}
.nav-drawer__footer-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  min-height: 44px;
  padding: 0 16px;
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.30);
  border-radius: 10px;
  color: #f87171;
  font: inherit;
  font-size: 0.875rem;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}
.nav-drawer__footer-button:hover,
.nav-drawer__footer-button:focus-visible {
  background: rgba(239,68,68,0.16);
  border-color: rgba(239,68,68,0.55);
  color: #fca5a5;
  outline: none;
}
/* Light mode logout button */
:root[data-theme="light"] .nav-drawer__footer-button {
  background: rgba(239,68,68,0.07);
  border-color: rgba(239,68,68,0.25);
  color: #dc2626;
}
:root[data-theme="light"] .nav-drawer__footer-button:hover,
:root[data-theme="light"] .nav-drawer__footer-button:focus-visible {
  background: rgba(239,68,68,0.14);
  border-color: rgba(239,68,68,0.45);
  color: #b91c1c;
}
@media (prefers-color-scheme: light) {
  :root:not([data-theme]) .nav-drawer__footer-button {
    background: rgba(239,68,68,0.07);
    border-color: rgba(239,68,68,0.25);
    color: #dc2626;
  }
  :root:not([data-theme]) .nav-drawer__footer-button:hover,
  :root:not([data-theme]) .nav-drawer__footer-button:focus-visible {
    background: rgba(239,68,68,0.14);
    border-color: rgba(239,68,68,0.45);
    color: #b91c1c;
  }
}

/* Prevent body scroll when drawer is open */
body.nav-drawer-open {
  overflow: hidden;
}

/* Light mode */
:root[data-theme="light"] .nav-drawer {
  background: var(--oh-surface);
  border-left-color: rgba(0,0,0,0.1);
}
:root[data-theme="light"] .nav-drawer__item:hover {
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .nav-drawer__item:active {
  background: rgba(201,168,76,0.08);
}
:root[data-theme="light"] .nav-drawer-overlay {
  background: rgba(0,0,0,0.45);
}

/* ----------------------------------------------------------------
   LANDING NAV BUTTONS
   ---------------------------------------------------------------- */
.landing-nav-link-btn {
  color: var(--oh-text-2);
  font-size: 0.875rem;
  font-weight: 500;
  padding: 6px 12px;
  border-radius: var(--oh-r-md);
  transition: color var(--oh-t-fast) ease, background var(--oh-t-fast) ease;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.landing-nav-link-btn:hover {
  color: var(--oh-text);
  background: rgba(255,255,255,0.06);
  text-decoration: none;
}
.landing-nav-link-btn--primary {
  background: linear-gradient(135deg, var(--oh-gold), var(--oh-gold-2));
  color: #09090d !important;
  font-weight: 700;
  padding: 6px 16px;
  border-radius: var(--oh-r-pill);
  box-shadow: var(--oh-shadow-gold);
}
.landing-nav-link-btn--primary:hover {
  background: linear-gradient(135deg, var(--oh-gold-2), var(--oh-gold-3));
  color: #09090d !important;
  transform: translateY(-1px);
  box-shadow: 0 6px 20px rgba(201,168,76,0.40);
  text-decoration: none;
}

/* ----------------------------------------------------------------
   LANDING STEP CARDS
   ---------------------------------------------------------------- */
.landing-step-card,
.landing-steps-grid > article {
  background: var(--oh-card);
  border: 1px solid var(--oh-border);
  border-radius: var(--oh-r-xl);
  padding: 24px;
  display: grid;
  gap: 10px;
  align-content: start;
  transition:
    border-color var(--oh-t-base) ease,
    background var(--oh-t-base) ease,
    transform var(--oh-t-base) var(--oh-ease),
    box-shadow var(--oh-t-base) ease;
}
.landing-step-card:hover,
.landing-steps-grid > article:hover {
  border-color: var(--oh-gold-border);
  background: linear-gradient(160deg, var(--oh-gold-dim), var(--oh-card));
  transform: translateY(-4px);
  box-shadow: var(--oh-shadow-gold);
}
.landing-step-card__number,
.landing-steps-grid > article > span:first-child {
  font-family: "Syne", sans-serif;
  font-size: 2.4rem;
  font-weight: 800;
  color: var(--oh-gold);
  opacity: 0.55;
  line-height: 1;
}
.landing-step-card h3 { font-size: 1.0625rem; font-weight: 700; color: var(--oh-text); }
.landing-step-card p  { font-size: 0.875rem; color: var(--oh-text-2); line-height: 1.6; margin: 0; }

/* ----------------------------------------------------------------
   GLASS CARD & AUTH GRID
   ---------------------------------------------------------------- */
.glass-card {
  background: var(--oh-card-hi);
  border: 1px solid var(--oh-border-2);
  border-radius: var(--oh-r-xl);
  box-shadow: var(--oh-shadow-md);
  padding: 28px;
}

.landing-auth-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(24px, 4vw, 56px);
  align-items: start;
  max-width: 960px;
  margin: 0 auto;
}

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

.landing-auth-tabs {
  display: flex;
  gap: 4px;
  margin: 16px 0;
  background: rgba(255,255,255,0.03);
  border-radius: var(--oh-r-pill);
  padding: 3px;
  border: 1px solid var(--oh-border);
}
.landing-auth-tabs .tab-btn {
  flex: 1;
  justify-content: center;
  border-radius: var(--oh-r-pill);
  padding: 7px 8px;
  font-size: 0.8rem;
}

/* ----------------------------------------------------------------
   BETA BANNER
   ---------------------------------------------------------------- */
.launch-top-beta {
  background: var(--oh-gold-dim);
  border-bottom: 1px solid var(--oh-gold-border);
  padding: 8px 16px;
  text-align: center;
  font-size: 0.8125rem;
  color: var(--oh-gold-2);
  font-weight: 500;
}

/* ----------------------------------------------------------------
   PILL LINK & PILL SELECT
   ---------------------------------------------------------------- */
.pill-link {
  display: inline-flex;
  align-items: center;
  padding: 5px 12px;
  border-radius: var(--oh-r-pill);
  font-size: 0.8125rem;
  font-weight: 600;
  color: var(--oh-text-2);
  border: 1px solid var(--oh-border);
  background: rgba(255,255,255,0.04);
  transition: all var(--oh-t-fast) ease;
  text-decoration: none;
  cursor: pointer;
}
.pill-link:hover {
  border-color: var(--oh-border-2);
  background: rgba(255,255,255,0.08);
  color: var(--oh-text);
  text-decoration: none;
}

.pill-select {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--oh-border);
  border-radius: var(--oh-r-pill);
  color: var(--oh-text-2);
  font-size: 0.8125rem;
  font-weight: 600;
  padding: 5px 10px;
  cursor: pointer;
  transition: border-color var(--oh-t-fast) ease;
}
.pill-select:hover { border-color: var(--oh-border-2); }
.pill-select:focus-visible { outline: none; box-shadow: var(--oh-gold-ring); }

/* ----------------------------------------------------------------
   FEATURES / DETAIL GRID
   ---------------------------------------------------------------- */
.detail-hero {
  padding: clamp(40px, 6vw, 80px) 0 clamp(24px, 4vw, 48px);
}
.detail-hero h1 { font-size: clamp(1.8rem, 4vw, 3rem); }

.detail-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.detail-card {
  background: var(--oh-card);
  border: 1px solid var(--oh-border);
  border-radius: var(--oh-r-xl);
  padding: 24px;
  display: grid;
  gap: 10px;
  transition: border-color var(--oh-t-base) ease, transform var(--oh-t-base) var(--oh-ease), box-shadow var(--oh-t-base) ease;
}
.detail-card:hover {
  border-color: var(--oh-gold-border);
  transform: translateY(-3px);
  box-shadow: var(--oh-shadow-gold);
}
@media (max-width: 900px) { .detail-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .detail-grid { grid-template-columns: 1fr; } }

/* ----------------------------------------------------------------
   COLLECTION CARD GRID
   ---------------------------------------------------------------- */
.collection-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 14px;
}

/* ----------------------------------------------------------------
   MOBILE QUICK NAV SELECT
   ---------------------------------------------------------------- */
.mobile-tab-nav {
  display: none;
}
@media (max-width: 640px) {
  .mobile-tab-nav {
    display: grid;
    gap: 4px;
    padding: 8px 0;
  }
  .mobile-tab-nav__label {
    font-size: 0.75rem;
    color: var(--oh-text-3);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 700;
  }
  .mobile-tab-nav__select { width: 100%; }
}

/* ----------------------------------------------------------------
   QR PAGE, LABEL PAGE, VERIFY PAGE
   ---------------------------------------------------------------- */
.qr-card,
.label-card,
.verify-card {
  max-width: 480px;
  margin: 40px auto;
  background: var(--oh-card);
  border: 1px solid var(--oh-border);
  border-radius: var(--oh-r-xl);
  padding: 32px;
  box-shadow: var(--oh-shadow-md);
}

/* ----------------------------------------------------------------
   SHOP BACKOFFICE / INVENTORY
   ---------------------------------------------------------------- */
.shop-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

/* ----------------------------------------------------------------
   PROFILE PAGE
   ---------------------------------------------------------------- */
.profile-hero {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 20px;
  align-items: center;
  padding: 24px;
  background: var(--oh-card-hi);
  border: 1px solid var(--oh-border-2);
  border-radius: var(--oh-r-xl);
}

.profile-avatar {
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 2px solid var(--oh-gold-border);
  background: var(--oh-gold-dim);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  font-weight: 800;
  color: var(--oh-gold);
}

/* ---- Collector Profile tab — override old panel/card styles ---- */

/* Main panel wrapper */
.tab-panel[data-tab-panel="profile"] .panel {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
  box-shadow: var(--oh-shadow-md) !important;
}

/* Profile identity card */
.page-app .dashboard-profile-card {
  background: var(--oh-card-hi);
  border: 1px solid var(--oh-border-2);
  border-radius: var(--oh-r-xl);
  padding: 20px;
}

/* Stat tiles inside identity card */
.page-app .dashboard-profile-stat {
  background: var(--oh-surface) !important;
  border: 1px solid var(--oh-border) !important;
  border-radius: var(--oh-r-lg) !important;
}
.page-app .dashboard-profile-stat span {
  color: var(--oh-text-3) !important;
  font-size: 0.75rem !important;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.page-app .dashboard-profile-stat strong {
  color: var(--oh-text) !important;
  font-size: 1.1rem !important;
}

/* Score / progress bar section */
.page-app .dashboard-score-progress {
  background: linear-gradient(135deg, rgba(62,207,178,0.10), rgba(62,207,178,0.04)) !important;
  border: 1px solid var(--oh-teal-border) !important;
  border-radius: var(--oh-r-lg) !important;
}
.page-app .dashboard-score-progress__copy strong {
  color: var(--oh-teal) !important;
}
.page-app .dashboard-score-progress__copy span {
  color: var(--oh-text-2) !important;
}

/* Bio / edit panel (settings-note inside profile) */
.tab-panel[data-tab-panel="profile"] .settings-note {
  background: var(--oh-surface) !important;
  border: 1px solid var(--oh-border) !important;
  border-radius: var(--oh-r-xl) !important;
}
.tab-panel[data-tab-panel="profile"] .settings-note .eyebrow {
  color: var(--oh-gold-2) !important;
}
.tab-panel[data-tab-panel="profile"] label > span {
  color: var(--oh-text-2) !important;
  font-size: 0.8rem;
  font-weight: 600;
}

/* Name / badge text */
.page-app .dashboard-profile-card__copy strong {
  color: var(--oh-text) !important;
  font-size: 1.1rem;
}
.page-app .dashboard-profile-card__copy span {
  color: var(--oh-text-2) !important;
}

/* Rank strip */
.page-app .profile-rank-strip .dashboard-profile-stat {
  background: linear-gradient(135deg, var(--oh-gold-dim), var(--oh-surface)) !important;
  border-color: var(--oh-gold-border) !important;
}
.page-app .profile-rank-strip .dashboard-profile-stat strong {
  color: var(--oh-gold) !important;
}

/* Showcase / section cards inside profile */
.tab-panel[data-tab-panel="profile"] .dashboard-section-card {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
  box-shadow: var(--oh-shadow-sm) !important;
}
.tab-panel[data-tab-panel="profile"] .dashboard-section-card .panel__header .eyebrow {
  color: var(--oh-gold-2) !important;
}
.tab-panel[data-tab-panel="profile"] .dashboard-section-card h3 {
  color: var(--oh-text) !important;
}

/* Section headings inside profile */
.tab-panel[data-tab-panel="profile"] h2,
.tab-panel[data-tab-panel="profile"] h3 {
  color: var(--oh-text) !important;
}
.tab-panel[data-tab-panel="profile"] .muted {
  color: var(--oh-text-2) !important;
}
.tab-panel[data-tab-panel="profile"] .eyebrow {
  color: var(--oh-text-3) !important;
}

/* Light mode — warm neutrals, no glaring white backgrounds */
:root[data-theme="light"] .tab-panel[data-tab-panel="profile"] .panel {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
}
:root[data-theme="light"] .page-app .dashboard-profile-card {
  background: var(--oh-card-hi) !important;
  border-color: var(--oh-border-2) !important;
}
:root[data-theme="light"] .tab-panel[data-tab-panel="profile"] .dashboard-section-card {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
}
:root[data-theme="light"] .page-app .dashboard-profile-stat {
  background: var(--oh-surface) !important;
  border-color: var(--oh-border) !important;
}
:root[data-theme="light"] .tab-panel[data-tab-panel="profile"] .settings-note {
  background: var(--oh-surface) !important;
  border-color: var(--oh-border) !important;
}

/* ----------------------------------------------------------------
   CONTACT / LEGAL / FAQ CONTENT
   ---------------------------------------------------------------- */
.content-page {
  max-width: 720px;
  margin: 0 auto;
  padding: clamp(32px, 5vw, 64px) clamp(16px, 4vw, 48px);
}

.content-page h1 { margin-bottom: 8px; }
.content-page .eyebrow { margin-bottom: 16px; }
.content-page p { color: var(--oh-text-2); margin-bottom: 16px; line-height: 1.75; }
.content-page h2 { font-size: 1.25rem; margin: 28px 0 10px; color: var(--oh-text); }
.content-page h3 { font-size: 1.05rem; margin: 20px 0 8px; color: var(--oh-text); }

/* ----------------------------------------------------------------
   DECK BUILDER
   ---------------------------------------------------------------- */
.deck-builder-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 20px;
  align-items: start;
}
@media (max-width: 900px) {
  .deck-builder-layout { grid-template-columns: 1fr; }
}

/* ----------------------------------------------------------------
   UPDATES PAGE — stat cards & weekly grid
   ---------------------------------------------------------------- */
.page-updates .updates-stat-card {
  background: var(--oh-card-hi) !important;
  border-color: var(--oh-border) !important;
}
.page-updates .updates-stat-card span {
  color: var(--oh-text-3) !important;
}
.page-updates .updates-stat-card strong {
  color: var(--oh-text) !important;
  font-family: "Syne", sans-serif;
  letter-spacing: -0.03em;
}
.page-updates .updates-weekly-grid article {
  background: var(--oh-surface) !important;
  border-color: var(--oh-border) !important;
}
.page-updates .updates-weekly-grid h3 {
  color: var(--oh-text) !important;
}
.page-updates .updates-weekly-grid ul li {
  color: var(--oh-text-2);
}

/* ----------------------------------------------------------------
   PUBLIC VERIFICATION PAGE — proof state cards
   ---------------------------------------------------------------- */
.proof-state-card {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
  border-radius: var(--oh-r-lg) !important;
}
.proof-state-card strong,
.proof-state-card p { color: var(--oh-text) !important; }
.proof-state-card .muted { color: var(--oh-text-2) !important; }

/* ----------------------------------------------------------------
   UPDATES / CHANGELOG
   ---------------------------------------------------------------- */
.update-entry {
  background: var(--oh-card);
  border: 1px solid var(--oh-border);
  border-radius: var(--oh-r-lg);
  padding: 20px 24px;
  display: grid;
  gap: 10px;
}
.update-entry:hover { border-color: var(--oh-border-2); }

.update-entry-date {
  font-size: 0.8125rem;
  color: var(--oh-gold);
  font-weight: 700;
  letter-spacing: 0.04em;
}

/* ----------------------------------------------------------------
   PUBLIC VERIFICATION PAGE
   ---------------------------------------------------------------- */
.verify-result {
  border-radius: var(--oh-r-xl);
  padding: 24px;
  display: grid;
  gap: 12px;
}

.verify-result--ok {
  background: var(--oh-teal-dim);
  border: 1px solid var(--oh-teal-border);
}

.verify-result--fail {
  background: rgba(239,68,68,0.08);
  border: 1px solid rgba(239,68,68,0.28);
}

/* ----------------------------------------------------------------
   REWARDS PAGE
   ---------------------------------------------------------------- */
.rewards-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
@media (max-width: 768px) {
  .rewards-grid { grid-template-columns: 1fr; }
}

/* ----------------------------------------------------------------
   PURCHASE CREDITS
   ---------------------------------------------------------------- */
.credits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 16px;
}

.credit-pack {
  background: var(--oh-card);
  border: 1px solid var(--oh-border);
  border-radius: var(--oh-r-xl);
  padding: 24px;
  text-align: center;
  display: grid;
  gap: 12px;
  transition: border-color var(--oh-t-base) ease, transform var(--oh-t-base) var(--oh-ease), box-shadow var(--oh-t-base) ease;
}
.credit-pack:hover {
  border-color: var(--oh-gold-border);
  transform: translateY(-3px);
  box-shadow: var(--oh-shadow-gold);
}
.credit-pack--featured {
  border-color: var(--oh-gold-border);
  background: linear-gradient(160deg, var(--oh-gold-dim), var(--oh-card));
}

.credit-pack__price {
  font-family: "Syne", sans-serif;
  font-size: 2rem;
  font-weight: 800;
  color: var(--oh-gold);
  letter-spacing: -0.04em;
}

/* ----------------------------------------------------------------
   SCAN PAGE IMPROVEMENTS
   ---------------------------------------------------------------- */
.scan-root-panel .panel__header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--oh-border);
  margin-bottom: 0;
}

.scan-queue-preview {
  background: var(--oh-surface);
  border-top: 1px solid var(--oh-border);
  padding: 16px;
}

/* Scan confidence badge */
.scan-confidence-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: var(--oh-r-pill);
  font-size: 0.8125rem;
  font-weight: 700;
}
.scan-confidence-badge--high   { background: var(--oh-teal-dim); border: 1px solid var(--oh-teal-border); color: var(--oh-teal); }
.scan-confidence-badge--medium { background: rgba(245,213,71,0.10); border: 1px solid rgba(245,213,71,0.30); color: #f5d547; }
.scan-confidence-badge--low    { background: rgba(239,68,68,0.08); border: 1px solid rgba(239,68,68,0.28); color: #f87171; }

/* ----------------------------------------------------------------
   PUBLIC COLLECTOR PROFILE PAGE (profile.html?user=...)
   ---------------------------------------------------------------- */

/* Page background — match site dark theme, subtle teal accent at top */
.page-public-profile {
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(62,207,178,0.09), transparent 55%),
    var(--oh-bg) !important;
  min-height: 100vh;
  color: var(--oh-text);
}

/* Hero panel */
.page-public-profile .public-profile-hero.panel {
  background: linear-gradient(160deg, var(--oh-card-hi2), var(--oh-card)) !important;
  border: 1px solid var(--oh-border-2) !important;
  box-shadow: var(--oh-shadow-md) !important;
}

/* All panels on the profile page */
.page-public-profile .panel {
  background: var(--oh-card) !important;
  border: 1px solid var(--oh-border) !important;
  box-shadow: var(--oh-shadow-sm) !important;
}

/* Metric cards row (Collector Score, Trust Rating, Value, HashLocked) */
.page-public-profile .ui-metric-card {
  background: var(--oh-card-hi) !important;
  border: 1px solid var(--oh-border-2) !important;
  box-shadow: none !important;
}
.page-public-profile .ui-metric-card h2 {
  color: var(--oh-text) !important;
  font-family: "Syne", sans-serif;
  font-size: clamp(1.5rem, 2.5vw, 2rem);
  letter-spacing: -0.04em;
}
.page-public-profile .ui-metric-card p.muted,
.page-public-profile .ui-metric-card span.muted {
  color: var(--oh-text-3) !important;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}

/* Profile avatar */
.page-public-profile .public-profile-avatar {
  border: 2px solid var(--oh-gold-border) !important;
  background: var(--oh-gold-dim) !important;
}

/* Profile name / username / sub-headings */
.page-public-profile h1 { color: var(--oh-text) !important; }
.page-public-profile .public-profile-hero__sub {
  color: var(--oh-gold-2) !important;
}
.page-public-profile .eyebrow { color: var(--oh-text-3) !important; }
.page-public-profile h2 { color: var(--oh-text) !important; }
.page-public-profile .muted,
.page-public-profile .muted.small { color: var(--oh-text-2) !important; }

/* Breakdown grid articles (By Category / Grade / Era) */
.page-public-profile .profile-breakdown-grid article {
  background: var(--oh-surface) !important;
  border: 1px solid var(--oh-border) !important;
  border-radius: var(--oh-r-lg) !important;
}
.page-public-profile .profile-breakdown-grid .eyebrow {
  color: var(--oh-gold-2) !important;
}

/* Card rows (mini-list items) */
.page-public-profile .ui-card-row {
  background: var(--oh-surface) !important;
  border-color: var(--oh-border) !important;
}
.page-public-profile .ui-card-row strong { color: var(--oh-text) !important; }
.page-public-profile .ui-card-row span  { color: var(--oh-text-2) !important; }
.page-public-profile .dashboard-mini-list__meta { color: var(--oh-text-3) !important; }

/* Timeline / activity / achievements */
.page-public-profile .ui-timeline-item {
  background: var(--oh-surface) !important;
  border-color: var(--oh-border) !important;
}
.page-public-profile .ui-timeline-item strong { color: var(--oh-text) !important; }
.page-public-profile .ui-timeline-item__meta  { color: var(--oh-text-3) !important; }
.page-public-profile .dashboard-feed-time      { color: var(--oh-text-3) !important; }

/* Settings (theme picker) dropdown */
.page-public-profile .public-profile-settings {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
}
.page-public-profile .public-profile-settings summary {
  color: var(--oh-text-2) !important;
}
.page-public-profile .public-profile-settings__field {
  color: var(--oh-text-2) !important;
}

/* Bio block */
.page-public-profile .profile-public-bio {
  border-top-color: var(--oh-border) !important;
  color: var(--oh-text-2) !important;
}

/* Verification badge pills */
.page-public-profile .pill.pill-soft {
  background: var(--oh-gold-dim) !important;
  border: 1px solid var(--oh-gold-border) !important;
  color: var(--oh-gold-2) !important;
}

/* Section header panel eyebrows */
.page-public-profile .panel__header .eyebrow {
  color: var(--oh-gold-2) !important;
}

/* Collection browser card tiles */
.page-public-profile .collection-card-tile {
  background: var(--oh-card-hi) !important;
  border-color: var(--oh-border) !important;
}
.page-public-profile .collection-card-tile:hover {
  border-color: var(--oh-gold-border) !important;
  box-shadow: var(--oh-shadow-gold) !important;
}

/* Light mode — override the old blue gradient to match site light theme */
:root[data-theme="light"] .page-public-profile {
  background:
    radial-gradient(ellipse 80% 40% at 50% 0%, rgba(62,207,178,0.06), transparent 55%),
    var(--oh-bg) !important;
}
:root[data-theme="light"] .page-public-profile .panel,
:root[data-theme="light"] .page-public-profile .ui-metric-card {
  background: var(--oh-card) !important;
  border-color: var(--oh-border) !important;
}
:root[data-theme="light"] .page-public-profile .profile-breakdown-grid article,
:root[data-theme="light"] .page-public-profile .ui-card-row,
:root[data-theme="light"] .page-public-profile .ui-timeline-item {
  background: var(--oh-surface) !important;
  border-color: var(--oh-border) !important;
}

/* ----------------------------------------------------------------
   LIGHT MODE EXTRAS
   ---------------------------------------------------------------- */
:root[data-theme="light"] .landing-nav-link-btn { color: var(--oh-text-2); }
:root[data-theme="light"] .landing-nav-link-btn:hover {
  color: var(--oh-text);
  background: rgba(0,0,0,0.05);
}
:root[data-theme="light"] .launch-top-beta {
  background: rgba(201,168,76,0.08);
  border-color: rgba(201,168,76,0.24);
}
:root[data-theme="light"] .glass-card,
:root[data-theme="light"] .landing-auth-card {
  background: #ffffff;
  border-color: rgba(0,0,0,0.10);
}
:root[data-theme="light"] .pill-link {
  background: rgba(0,0,0,0.04);
  border-color: rgba(0,0,0,0.12);
  color: var(--oh-text-2);
}
:root[data-theme="light"] .pill-link:hover {
  background: rgba(0,0,0,0.07);
  color: var(--oh-text);
}

/* ----------------------------------------------------------------
   GLOBAL READABILITY NORMALIZATION
   Keep shared surfaces on clear white-on-dark / black-on-light text.
   ---------------------------------------------------------------- */
:where(
  .panel,
  .ui-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-drawer,
  .nav-drop__panel,
  .landing-auth-card,
  .trade-card,
  .cert-data-item,
  .cert-photo-wrap,
  .cert-digest-block,
  .cert-chain-item,
  .cert-proof-upload,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) {
  color: var(--text, var(--oh-text, #111111));
}

:where(
  .panel,
  .ui-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-drawer,
  .nav-drop__panel,
  .landing-auth-card,
  .trade-card,
  .cert-data-item,
  .cert-digest-block,
  .cert-chain-item,
  .cert-proof-upload,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(h1, h2, h3, h4, h5, h6, strong, th, td, label, legend) {
  color: var(--text, var(--oh-text, #111111)) !important;
}

:where(
  .panel,
  .ui-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-drawer,
  .nav-drop__panel,
  .landing-auth-card,
  .trade-card,
  .cert-data-item,
  .cert-digest-block,
  .cert-chain-item,
  .cert-proof-upload,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(
  p,
  li,
  dt,
  dd,
  small,
  .muted,
  .small,
  .note,
  .helper,
  .caption,
  .description,
  .subtitle,
  .meta,
  .empty,
  .empty-state,
  .dashboard-feed-time,
  .dashboard-mini-list__meta,
  .app-section-shell__breadcrumb,
  .category-nav__label
) {
  color: var(--text-soft, var(--oh-text-2, #1f2937)) !important;
}

:where(
  .panel,
  .ui-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-drawer,
  .nav-drop__panel,
  .landing-auth-card,
  .trade-card,
  .cert-data-item,
  .cert-digest-block,
  .cert-chain-item,
  .cert-proof-upload,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(
  .eyebrow,
  .panel__eyebrow,
  .cert-subtitle,
  .cert-photo-label,
  .cert-qr-label,
  .cert-section-label,
  .cert-chain-content p,
  .pv-banner__meta,
  .pv-check-note
) {
  color: var(--text-muted, var(--oh-text-3, #334155)) !important;
}

/* ----------------------------------------------------------------
   LIGHT MODE ACCENT TEXT NORMALIZATION
   On light surfaces, keep emphasis in backgrounds/borders and use dark text.
   ---------------------------------------------------------------- */
:root[data-theme="light"] :is(
  .eyebrow,
  .panel__eyebrow,
  .text-gold,
  .status-wishlist,
  .status-chip.status-wishlist,
  .pill-demo,
  .pill.pill-soft,
  .tab-btn[aria-selected="true"],
  .tab-btn.is-active
) {
  color: var(--oh-text) !important;
}

:root[data-theme="light"] .page-public-profile .pill.pill-soft,
:root[data-theme="light"] .page-public-profile .panel__header .eyebrow,
:root[data-theme="light"] .page-public-profile .profile-breakdown-grid .eyebrow,
:root[data-theme="light"] .tab-panel[data-tab-panel="profile"] .settings-note .eyebrow,
:root[data-theme="light"] .tab-panel[data-tab-panel="profile"] .dashboard-section-card .panel__header .eyebrow {
  color: var(--oh-text) !important;
}

@media (prefers-color-scheme: light) {
  :root:not([data-theme]) :is(
    .eyebrow,
    .panel__eyebrow,
    .text-gold,
    .status-wishlist,
    .status-chip.status-wishlist,
    .pill-demo,
    .pill.pill-soft,
    .tab-btn[aria-selected="true"],
    .tab-btn.is-active
  ) {
    color: var(--oh-text) !important;
  }

  :root:not([data-theme]) .page-public-profile .pill.pill-soft,
  :root:not([data-theme]) .page-public-profile .panel__header .eyebrow,
  :root:not([data-theme]) .page-public-profile .profile-breakdown-grid .eyebrow,
  :root:not([data-theme]) .tab-panel[data-tab-panel="profile"] .settings-note .eyebrow,
  :root:not([data-theme]) .tab-panel[data-tab-panel="profile"] .dashboard-section-card .panel__header .eyebrow {
    color: var(--oh-text) !important;
  }
}

/* ----------------------------------------------------------------
   GLOBAL THEME READABILITY + SPACING NORMALIZATION
   Keep text polarity consistent across dark/light/system surfaces and
   prevent common card/panel/header content from bunching together.
   ---------------------------------------------------------------- */
:root {
  --theme-readable-text: var(--text, var(--oh-text, #f8fafc));
  --theme-readable-soft: var(--text-soft, var(--oh-text-2, #e7edf5));
  --theme-readable-muted: var(--text-muted, var(--oh-text-3, #cbd5e1));
  --theme-readable-border: var(--border, var(--oh-border, rgba(255,255,255,0.12)));
  --theme-readable-surface: var(--panel, var(--oh-card, rgba(255,255,255,0.18)));
}

body,
main,
section,
article,
aside,
form,
table,
thead,
tbody,
tfoot,
tr,
td,
th {
  color: var(--theme-readable-text);
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) {
  color: var(--theme-readable-text);
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(h1, h2, h3, h4, h5, h6, strong, b, label, legend, summary, .button, .pill-link, .tab-btn) {
  color: var(--theme-readable-text) !important;
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(
  p,
  li,
  span,
  small,
  .muted,
  .small,
  .note,
  .helper,
  .caption,
  .description,
  .subtitle,
  .meta,
  .empty,
  .empty-state,
  .dashboard-feed-time,
  .dashboard-mini-list__meta,
  .app-section-shell__breadcrumb,
  .category-nav__label
) {
  color: var(--theme-readable-soft) !important;
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(.eyebrow, .panel__eyebrow, .brand-trust) {
  color: var(--theme-readable-muted) !important;
}

:is(
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-drop__panel,
  .nav-drawer,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(input:not([type="checkbox"]):not([type="radio"]), select, textarea) {
  color: var(--theme-readable-text) !important;
  background: var(--theme-readable-surface) !important;
  border-color: var(--theme-readable-border) !important;
}

:is(
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-drop__panel,
  .nav-drawer,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(input::placeholder, textarea::placeholder) {
  color: var(--theme-readable-muted) !important;
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(.button-ghost, .pill, .pill-soft, .pill-link, .pill-select, .nav-drop__item, .tab-btn) {
  color: var(--theme-readable-text) !important;
  border-color: var(--theme-readable-border) !important;
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(.button-ghost, .pill-soft, .pill-select, .nav-drop__item) {
  background: var(--theme-readable-surface) !important;
}

:is(
  .page,
  .panel,
  .ui-card,
  .glass-card,
  .settings-note,
  .tab-panel,
  .modal-content,
  .nav-toolbar,
  .landing-nav,
  .nav-drawer,
  .nav-drop__panel,
  .page-module-nav,
  .app-section-shell,
  .app-intro,
  .catalog-scan-camera-panel,
  .scan-root-panel,
  .landing-auth-card,
  .trade-card,
  .pv-banner,
  .pv-check-item,
  .pv-explain-box,
  .dm-card,
  .dm-topbar,
  .dm-kpi,
  .dm-feed-item
) :is(select option) {
  color: var(--theme-readable-text) !important;
  background: var(--theme-readable-surface) !important;
}

@media (max-width: 820px) {
  :is(
    .panel,
    .ui-card,
    .glass-card,
    .settings-note,
    .tab-panel,
    .modal-content,
    .landing-auth-card,
    .trade-card,
    .pv-banner,
    .pv-check-item,
    .pv-explain-box,
    .dm-card,
    .dm-topbar,
    .dm-kpi,
    .dm-feed-item
  ) {
    max-width: 100%;
    min-width: 0;
    overflow-wrap: anywhere;
  }

  :is(
    .panel__header,
    .form-actions,
    .pill-group,
    .nav__actions,
    .landing-nav .nav__actions,
    .dashboard-update-banner__actions,
    .landing-hero__actions,
    .landing-final-cta__actions
  ) {
    gap: 8px !important;
    flex-wrap: wrap !important;
  }

  :is(
    .panel__header,
    .dashboard-update-banner,
    .app-section-shell,
    .app-intro,
    .scan-section-header
  ) {
    align-items: flex-start !important;
  }
}
