/* ═══════════════════════════════════════════════════════════════════════
   KRYPTON MEMPOOL — Premium dark explorer stylesheet
   Chargé après mempool-space-theme.css (UI mempool.space) sur toutes les pages.
   Scope : body:is(.mempool-space-ui, .page-mempool) = pages où ce fichier est inclus.
   Titres : Rajdhani  ·  Mono : JetBrains Mono (voir layout.pug)
   ═══════════════════════════════════════════════════════════════════════ */

/* ─── 0. Tokens locaux (complètent --mp-* de mempool-space-theme.css) ─── */
:root {
  --kyp-accent-rgb:      46, 230, 200;
  --kyp-warn-rgb:        255, 176, 32;
  --kyp-danger-rgb:      255, 107, 107;
  --kyp-purple:          #7c5cfc;
  --kyp-purple-dim:      rgba(124, 92, 252, 0.14);
  --kyp-confirmed:       #22c55e;
  --kyp-confirmed-dim:   rgba(34, 197, 94, 0.14);
  --kyp-pending:         #ffb020;
  --kyp-pending-dim:     rgba(255, 176, 32, 0.14);
  --kyp-unconfirmed:     #ff6b6b;
  --kyp-unconfirmed-dim: rgba(255, 107, 107, 0.14);
  --kyp-shimmer-dur:     1.6s;
  --kyp-row-hover:       rgba(46, 230, 200, 0.06);
  --kyp-separator:       linear-gradient(90deg, transparent, rgba(46, 230, 200, 0.2) 40%, rgba(46, 230, 200, 0.2) 60%, transparent);
  /* Alias pour blocs alertes (section globale) */
  --kyp-warn-dim:        rgba(255, 176, 32, 0.14);
  --kyp-warn-border:     rgba(255, 176, 32, 0.3);
  --kyp-danger-dim:      rgba(255, 107, 107, 0.14);
  --kyp-danger-border:   rgba(255, 107, 107, 0.3);
}

/* ─── 1. En-tête de page ─────────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) #page-header-container {
  padding-bottom: 0.65rem;
  border-bottom: 1px solid transparent;
  border-image: var(--kyp-separator) 1;
  margin-bottom: 1.25rem;
}

body:is(.mempool-space-ui, .page-mempool) #page-header-container h3#page-title {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: clamp(1.3rem, 2.5vw, 1.65rem);
  letter-spacing: 0.04em;
  text-transform: uppercase;
  color: var(--mp-text);
  position: relative;
  display: inline-block;
}

body:is(.mempool-space-ui, .page-mempool) #page-header-container h3#page-title::after {
  content: '';
  position: absolute;
  bottom: -4px;
  left: 0;
  width: 2.4em;
  height: 2px;
  background: linear-gradient(90deg, var(--mp-accent), transparent);
  border-radius: 2px;
}

/* ─── 2. Cards ───────────────────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .card.bg-dark.border-secondary {
  background: linear-gradient(160deg,
    var(--mp-elevated) 0%,
    var(--mp-elevated2) 100%) !important;
  border: 1px solid var(--mp-border) !important;
  border-radius: var(--mp-radius) !important;
  box-shadow: var(--mp-shadow-sm), var(--mp-shadow-inset);
  transition:
    box-shadow 0.25s var(--mp-ease),
    border-color 0.25s var(--mp-ease),
    transform 0.2s var(--mp-ease-spring);
  overflow: hidden;
  position: relative;
}

body:is(.mempool-space-ui, .page-mempool) .card.bg-dark.border-secondary::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 1px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(var(--kyp-accent-rgb), 0.35) 30%,
    rgba(var(--kyp-accent-rgb), 0.35) 70%,
    transparent 100%);
  pointer-events: none;
}

body:is(.mempool-space-ui, .page-mempool) .card.bg-dark.border-secondary:hover {
  box-shadow:
    0 0 0 1px rgba(var(--kyp-accent-rgb), 0.3),
    0 8px 40px rgba(0, 0, 0, 0.55),
    0 0 60px rgba(var(--kyp-accent-rgb), 0.07);
  border-color: rgba(var(--kyp-accent-rgb), 0.28) !important;
  transform: translateY(-1px);
}

body:is(.mempool-space-ui, .page-mempool) .card-header {
  background: rgba(0, 0, 0, 0.18) !important;
  border-bottom: 1px solid var(--mp-border) !important;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  font-size: 0.92rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--mp-muted) !important;
  padding: 0.65rem 1rem;
}

body:is(.mempool-space-ui, .page-mempool) .card-body {
  padding: 1rem 1rem 1.1rem;
}

/* ─── 3. Table mempool transactions ─────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body td {
  font-size: 0.84rem;
  vertical-align: middle;
  padding: 0.6rem 0.75rem;
  border-color: rgba(255, 255, 255, 0.04) !important;
  transition: background 0.15s ease;
}

body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body tr {
  transition: background 0.15s ease;
}

body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body tr:hover td {
  background: var(--kyp-row-hover) !important;
}

body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body td.hash-cell,
body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body td.addr-cell,
body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body .tx-hash,
body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body .addr {
  font-family: var(--mp-mono);
  font-size: 0.78rem;
  letter-spacing: 0.015em;
  color: var(--mp-muted) !important;
}

body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body a {
  color: var(--mp-accent) !important;
  text-decoration: none;
  transition: color 0.18s ease, opacity 0.18s ease;
}

body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body a:hover {
  color: #fff !important;
  text-decoration: none;
  opacity: 0.9;
}

body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body a.hash-link {
  display: inline-block;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: bottom;
}

/* En-têtes : thead précède tbody#mempool-txs-body — pas de ~ sur tbody */
body:is(.mempool-space-ui, .page-mempool) .mp-mempool-table-wrap thead th,
body:is(.mempool-space-ui, .page-mempool) .table thead th,
body:is(.mempool-space-ui, .page-mempool) table.dataTable thead th {
  font-family: 'Rajdhani', sans-serif;
  font-weight: 700;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--mp-muted) !important;
  border-bottom: 1px solid var(--mp-border) !important;
  padding: 0.55rem 0.75rem;
  white-space: nowrap;
}

/* ─── 4. Badges de statut transaction ───────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .badge-confirmed,
body:is(.mempool-space-ui, .page-mempool) .badge.bg-success,
body:is(.mempool-space-ui, .page-mempool) span.confirmed {
  background: var(--kyp-confirmed-dim) !important;
  color: var(--kyp-confirmed) !important;
  border: 1px solid rgba(34, 197, 94, 0.3) !important;
  font-family: var(--mp-mono);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  padding: 0.25em 0.55em;
  border-radius: 4px;
}

body:is(.mempool-space-ui, .page-mempool) .badge-pending,
body:is(.mempool-space-ui, .page-mempool) .badge.bg-warning,
body:is(.mempool-space-ui, .page-mempool) span.pending {
  background: var(--kyp-pending-dim) !important;
  color: var(--kyp-pending) !important;
  border: 1px solid rgba(255, 176, 32, 0.3) !important;
  font-family: var(--mp-mono);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  padding: 0.25em 0.55em;
  border-radius: 4px;
}

body:is(.mempool-space-ui, .page-mempool) .badge-unconfirmed,
body:is(.mempool-space-ui, .page-mempool) .badge.bg-danger,
body:is(.mempool-space-ui, .page-mempool) span.unconfirmed {
  background: var(--kyp-unconfirmed-dim) !important;
  color: var(--kyp-unconfirmed) !important;
  border: 1px solid rgba(255, 107, 107, 0.3) !important;
  font-family: var(--mp-mono);
  font-size: 0.7rem;
  letter-spacing: 0.04em;
  padding: 0.25em 0.55em;
  border-radius: 4px;
}

/* ─── 5. Valeurs numériques & fees ──────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .tx-amount,
body:is(.mempool-space-ui, .page-mempool) .fee-value,
body:is(.mempool-space-ui, .page-mempool) .block-reward,
body:is(.mempool-space-ui, .page-mempool) td.amount,
body:is(.mempool-space-ui, .page-mempool) td.fee {
  font-family: var(--mp-mono);
  font-variant-numeric: tabular-nums;
  font-size: 0.83rem;
}

body:is(.mempool-space-ui, .page-mempool) .amount-positive { color: var(--kyp-confirmed) !important; }
body:is(.mempool-space-ui, .page-mempool) .amount-negative { color: var(--kyp-unconfirmed) !important; }

body:is(.mempool-space-ui, .page-mempool) .fee-rate-low    { color: var(--kyp-confirmed); }
body:is(.mempool-space-ui, .page-mempool) .fee-rate-medium { color: var(--kyp-pending); }
body:is(.mempool-space-ui, .page-mempool) .fee-rate-high   { color: var(--kyp-unconfirmed); }

/* ─── 6. Skeleton / chargement (shimmer) ────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .kyp-skeleton {
  background: linear-gradient(
    90deg,
    var(--mp-elevated) 25%,
    var(--mp-elevated2) 50%,
    var(--mp-elevated) 75%
  );
  background-size: 400% 100%;
  animation: kyp-shimmer var(--kyp-shimmer-dur) ease-in-out infinite;
  border-radius: 4px;
  display: inline-block;
}

@keyframes kyp-shimmer {
  0%   { background-position: 100% 0; }
  100% { background-position: -100% 0; }
}

/* ─── 7. Barre de progression mempool fee ───────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .mp-fee-bar {
  height: 5px;
  border-radius: 3px;
  background: var(--mp-elevated2);
  overflow: hidden;
  margin-top: 4px;
}

body:is(.mempool-space-ui, .page-mempool) .mp-fee-bar-fill {
  height: 100%;
  border-radius: 3px;
  background: linear-gradient(90deg, var(--mp-accent), rgba(var(--kyp-accent-rgb), 0.5));
  transition: width 0.6s var(--mp-ease);
}

/* ─── 8. Tuiles statistiques (#mp-stats-row) ────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) #mp-stats-row .mp-stat-card {
  background: linear-gradient(145deg, var(--mp-elevated) 0%, var(--mp-elevated2) 100%) !important;
  border: 1px solid var(--mp-border) !important;
  border-radius: var(--mp-radius) !important;
  box-shadow: var(--mp-shadow-sm), var(--mp-shadow-inset);
  padding: 1rem 1.1rem;
  position: relative;
  overflow: hidden;
  transition: box-shadow 0.25s var(--mp-ease), border-color 0.25s var(--mp-ease);
}

body:is(.mempool-space-ui, .page-mempool) #mp-stats-row .mp-stat-card::after {
  content: '';
  position: absolute;
  bottom: -12px; right: -12px;
  width: 56px; height: 56px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(var(--kyp-accent-rgb), 0.12), transparent 70%);
  pointer-events: none;
}

body:is(.mempool-space-ui, .page-mempool) #mp-stats-row .mp-stat-card:hover {
  border-color: rgba(var(--kyp-accent-rgb), 0.25) !important;
  box-shadow:
    var(--mp-shadow-sm),
    0 0 32px rgba(var(--kyp-accent-rgb), 0.1);
}

body:is(.mempool-space-ui, .page-mempool) .mp-stat-label {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--mp-muted) !important;
  margin-bottom: 0.3rem;
  font-family: 'Rajdhani', sans-serif;
}

body:is(.mempool-space-ui, .page-mempool) .mp-stat-value {
  font-family: var(--mp-mono);
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--mp-text) !important;
  font-variant-numeric: tabular-nums;
  line-height: 1.2;
}

body:is(.mempool-space-ui, .page-mempool) .mp-stat-sub {
  font-size: 0.72rem;
  color: var(--mp-muted);
  margin-top: 0.2rem;
}

/* ─── 9. Visualiseur de bloc ─────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .mp-block-vis {
  display: flex;
  gap: 0.4rem;
  align-items: flex-end;
  padding: 0.5rem 0;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-vis .mp-block-item {
  flex: 1;
  min-height: 28px;
  max-height: 72px;
  border-radius: 5px;
  background: var(--mp-elevated2);
  border: 1px solid var(--mp-border);
  cursor: pointer;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    transform 0.2s var(--mp-ease-spring);
  position: relative;
  overflow: hidden;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-vis .mp-block-item::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(var(--kyp-accent-rgb), 0.08) 0%, transparent 100%);
  opacity: 0;
  transition: opacity 0.2s ease;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-vis .mp-block-item:hover {
  border-color: rgba(var(--kyp-accent-rgb), 0.4);
  transform: scaleY(1.04) scaleX(1.02);
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-vis .mp-block-item:hover::after {
  opacity: 1;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-vis .mp-block-item.latest {
  border-color: rgba(var(--kyp-accent-rgb), 0.45);
  background: linear-gradient(180deg,
    rgba(var(--kyp-accent-rgb), 0.12),
    rgba(var(--kyp-accent-rgb), 0.04));
}

/* ─── 10. Panneau détail bloc / transaction ─────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .mp-detail-panel {
  background: var(--mp-elevated);
  border: 1px solid var(--mp-border);
  border-radius: var(--mp-radius);
  padding: 1.25rem 1.4rem;
  box-shadow: var(--mp-shadow-inset);
}

body:is(.mempool-space-ui, .page-mempool) .mp-detail-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 0.5rem 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
  gap: 1rem;
}

body:is(.mempool-space-ui, .page-mempool) .mp-detail-row:last-child {
  border-bottom: none;
}

body:is(.mempool-space-ui, .page-mempool) .mp-detail-label {
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--mp-muted);
  white-space: nowrap;
  flex-shrink: 0;
}

body:is(.mempool-space-ui, .page-mempool) .mp-detail-value {
  font-family: var(--mp-mono);
  font-size: 0.82rem;
  color: var(--mp-text);
  text-align: right;
  word-break: break-all;
}

/* ─── 11. Barre de recherche ─────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .mp-search-wrap {
  position: relative;
  max-width: 560px;
}

body:is(.mempool-space-ui, .page-mempool) .mp-search-wrap .mp-search-icon {
  position: absolute;
  left: 0.9rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--mp-muted);
  pointer-events: none;
  font-size: 0.9rem;
}

body:is(.mempool-space-ui, .page-mempool) .mp-search-wrap input.form-control {
  padding-left: 2.5rem !important;
  background: var(--mp-elevated) !important;
  border: 1px solid var(--mp-border) !important;
  border-radius: var(--mp-radius-sm) !important;
  color: var(--mp-text) !important;
  font-family: var(--mp-mono);
  font-size: 0.83rem;
  height: 2.6rem;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  box-shadow: var(--mp-shadow-inset);
}

body:is(.mempool-space-ui, .page-mempool) .mp-search-wrap input.form-control:focus {
  border-color: rgba(var(--kyp-accent-rgb), 0.5) !important;
  box-shadow:
    0 0 0 3px rgba(var(--kyp-accent-rgb), 0.1),
    var(--mp-shadow-inset) !important;
  outline: none;
  background: var(--mp-elevated2) !important;
}

body:is(.mempool-space-ui, .page-mempool) .mp-search-wrap input.form-control::placeholder {
  color: var(--mp-muted);
  opacity: 0.65;
}

/* ─── 12. Boutons (sans UI globale : hero mempool garde le dégradé du thème) */
body:not(.mempool-space-ui) .btn-mp-primary {
  background: linear-gradient(135deg,
    rgba(var(--kyp-accent-rgb), 0.2) 0%,
    rgba(var(--kyp-accent-rgb), 0.1) 100%) !important;
  border: 1px solid rgba(var(--kyp-accent-rgb), 0.4) !important;
  color: var(--mp-accent) !important;
  font-family: 'Rajdhani', sans-serif;
  font-weight: 600;
  letter-spacing: 0.06em;
  font-size: 0.88rem;
  padding: 0.45rem 1.1rem;
  border-radius: var(--mp-radius-sm) !important;
  transition:
    background 0.2s ease,
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.15s var(--mp-ease-spring);
}

body:not(.mempool-space-ui) .btn-mp-primary:hover {
  background: linear-gradient(135deg,
    rgba(var(--kyp-accent-rgb), 0.3) 0%,
    rgba(var(--kyp-accent-rgb), 0.15) 100%) !important;
  border-color: rgba(var(--kyp-accent-rgb), 0.6) !important;
  box-shadow: 0 0 20px rgba(var(--kyp-accent-rgb), 0.15) !important;
  transform: translateY(-1px);
}

body:not(.mempool-space-ui) .btn-mp-primary:active {
  transform: translateY(0);
}

body:is(.mempool-space-ui, .page-mempool) .btn-mp-ghost {
  background: transparent !important;
  border: 1px solid var(--mp-border) !important;
  color: var(--mp-muted) !important;
  font-size: 0.83rem;
  padding: 0.4rem 0.9rem;
  border-radius: var(--mp-radius-sm) !important;
  transition: border-color 0.2s ease, color 0.2s ease, background 0.2s ease;
}

body:is(.mempool-space-ui, .page-mempool) .btn-mp-ghost:hover {
  border-color: rgba(var(--kyp-accent-rgb), 0.35) !important;
  color: var(--mp-text) !important;
  background: rgba(var(--kyp-accent-rgb), 0.06) !important;
}

/* ─── 13. Indicateurs live / pulse ──────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .kyp-live-dot {
  display: inline-block;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--kyp-confirmed);
  box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.5);
  animation: kyp-pulse 2.2s ease-in-out infinite;
  vertical-align: middle;
  margin-right: 5px;
}

@keyframes kyp-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0.5); }
  50%       { box-shadow: 0 0 0 5px rgba(34, 197, 94, 0); }
}

body:is(.mempool-space-ui, .page-mempool) .kyp-live-dot.warn {
  background: var(--kyp-pending);
  animation-name: kyp-pulse-warn;
}

@keyframes kyp-pulse-warn {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255, 176, 32, 0.5); }
  50%       { box-shadow: 0 0 0 5px rgba(255, 176, 32, 0); }
}

/* ─── 14. Copier dans le presse-papier ──────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .kyp-copy-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 4px;
  background: transparent;
  border: 1px solid transparent;
  color: var(--mp-muted);
  cursor: pointer;
  margin-left: 4px;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease;
  vertical-align: middle;
  padding: 0;
}

body:is(.mempool-space-ui, .page-mempool) .kyp-copy-btn:hover {
  background: rgba(var(--kyp-accent-rgb), 0.1);
  border-color: rgba(var(--kyp-accent-rgb), 0.25);
  color: var(--mp-accent);
}

body:is(.mempool-space-ui, .page-mempool) .kyp-copy-btn.copied {
  color: var(--kyp-confirmed);
  border-color: rgba(34, 197, 94, 0.3);
  background: rgba(34, 197, 94, 0.08);
}

/* ─── 15. Toast ─────────────────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .kyp-toast {
  position: fixed;
  bottom: 1.5rem;
  right: 1.5rem;
  background: var(--mp-elevated2);
  border: 1px solid var(--mp-border);
  border-left: 3px solid var(--mp-accent);
  border-radius: var(--mp-radius-sm);
  padding: 0.7rem 1.1rem;
  font-size: 0.83rem;
  color: var(--mp-text);
  box-shadow: var(--mp-shadow-md);
  z-index: 9999;
  animation: kyp-slide-in 0.3s var(--mp-ease-spring) both;
  max-width: 320px;
}

body:is(.mempool-space-ui, .page-mempool) .kyp-toast.warn  { border-left-color: var(--kyp-pending); }
body:is(.mempool-space-ui, .page-mempool) .kyp-toast.error { border-left-color: var(--kyp-unconfirmed); }

@keyframes kyp-slide-in {
  from { opacity: 0; transform: translateX(1rem); }
  to   { opacity: 1; transform: translateX(0); }
}

/* ─── 16. Code & hashes inline ──────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) code.hash,
body:is(.mempool-space-ui, .page-mempool) .inline-hash {
  font-family: var(--mp-mono);
  font-size: 0.78rem;
  background: rgba(var(--kyp-accent-rgb), 0.07);
  border: 1px solid rgba(var(--kyp-accent-rgb), 0.14);
  border-radius: 4px;
  padding: 0.15em 0.45em;
  color: var(--mp-accent);
  word-break: break-all;
}

/* ─── 17. Timeline derniers blocs ───────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .mp-blocks-timeline {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.55rem 0.8rem;
  border-radius: var(--mp-radius-xs);
  border: 1px solid transparent;
  background: transparent;
  transition: background 0.15s ease, border-color 0.15s ease;
  cursor: pointer;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-row:hover {
  background: var(--kyp-row-hover);
  border-color: rgba(var(--kyp-accent-rgb), 0.12);
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-row .block-height {
  font-family: var(--mp-mono);
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--mp-accent);
  min-width: 5em;
  flex-shrink: 0;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-row .block-time {
  font-size: 0.75rem;
  color: var(--mp-muted);
  min-width: 4em;
  flex-shrink: 0;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-row .block-txs {
  font-family: var(--mp-mono);
  font-size: 0.75rem;
  color: var(--mp-muted);
  flex: 1;
}

body:is(.mempool-space-ui, .page-mempool) .mp-block-row .block-size {
  font-family: var(--mp-mono);
  font-size: 0.75rem;
  color: var(--mp-muted);
  text-align: right;
}

/* ─── 18. Séparateur section ───────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .kyp-section-divider {
  border: none;
  height: 1px;
  background: var(--kyp-separator);
  margin: 1.5rem 0;
  opacity: 1;
}

/* ─── 19. Pagination & onglets (toutes les pages) ───────────────────── */
body:is(.mempool-space-ui, .page-mempool) .page-item .page-link {
  background: var(--mp-elevated) !important;
  border-color: var(--mp-border) !important;
  color: var(--mp-muted) !important;
  border-radius: var(--mp-radius-xs) !important;
  min-width: 2.25rem;
  text-align: center;
  font-size: 0.82rem;
  font-weight: 500;
  padding: 0.38rem 0.6rem;
  transition: background 0.18s ease, color 0.18s ease, border-color 0.18s ease, transform 0.14s var(--mp-ease-spring);
}

body:is(.mempool-space-ui, .page-mempool) .page-item:not(.disabled) .page-link:hover {
  background: rgba(var(--kyp-accent-rgb), 0.1) !important;
  border-color: rgba(var(--kyp-accent-rgb), 0.35) !important;
  color: var(--mp-text) !important;
  transform: translateY(-1px);
}

body:is(.mempool-space-ui, .page-mempool) .page-item.active .page-link {
  background: linear-gradient(135deg, rgba(var(--kyp-accent-rgb), 0.22), rgba(var(--kyp-accent-rgb), 0.08)) !important;
  border-color: rgba(var(--kyp-accent-rgb), 0.42) !important;
  color: var(--mp-accent) !important;
  box-shadow: 0 0 18px rgba(var(--kyp-accent-rgb), 0.12);
  font-weight: 700;
}

body:is(.mempool-space-ui, .page-mempool) .page-item.disabled .page-link { opacity: 0.35; }

body:is(.mempool-space-ui, .page-mempool) .nav-tabs { border-bottom: 1px solid var(--mp-border) !important; gap: 2px; }

body:is(.mempool-space-ui, .page-mempool) .nav-tabs .nav-link {
  font-family: 'Rajdhani', sans-serif;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.07em;
  text-transform: uppercase;
  color: var(--mp-muted) !important;
  border-radius: var(--mp-radius-xs) var(--mp-radius-xs) 0 0 !important;
  border: 1px solid transparent !important;
  padding: 0.5rem 0.9rem;
  transition: color 0.2s ease, background 0.2s ease;
}

body:is(.mempool-space-ui, .page-mempool) .nav-tabs .nav-link:hover {
  color: var(--mp-text) !important;
  background: rgba(var(--kyp-accent-rgb), 0.06) !important;
}

body:is(.mempool-space-ui, .page-mempool) .nav-tabs .nav-link.active {
  color: var(--mp-accent) !important;
  background: rgba(var(--kyp-accent-rgb), 0.08) !important;
  border-color: var(--mp-border) var(--mp-border) transparent !important;
  border-bottom: 2px solid var(--mp-accent) !important;
  margin-bottom: -1px;
}

/* ─── 20. Scrollbar ─────────────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) ::-webkit-scrollbar { width: 7px; height: 7px; }
body:is(.mempool-space-ui, .page-mempool) ::-webkit-scrollbar-track { background: var(--mp-bg); }
body:is(.mempool-space-ui, .page-mempool) ::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, rgba(var(--kyp-accent-rgb), 0.28), rgba(42, 42, 61, 0.95));
  border-radius: 6px;
  border: 1.5px solid var(--mp-bg);
}
body:is(.mempool-space-ui, .page-mempool) ::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, rgba(var(--kyp-accent-rgb), 0.48), rgba(60, 60, 85, 0.98));
}

/* ─── 21. Champs formulaire (hors header nav déjà stylé par le thème) ─ */
body:is(.mempool-space-ui, .page-mempool) #main-container .form-select,
body:is(.mempool-space-ui, .page-mempool) #main-container .form-control:not(:focus),
body:is(.mempool-space-ui, .page-mempool) #main-container select,
body:is(.mempool-space-ui, .page-mempool) #main-container input[type="text"],
body:is(.mempool-space-ui, .page-mempool) #main-container input[type="search"],
body:is(.mempool-space-ui, .page-mempool) #main-container input[type="number"] {
  background: var(--mp-elevated) !important;
  border: 1px solid var(--mp-border) !important;
  color: var(--mp-text) !important;
  border-radius: var(--mp-radius-sm) !important;
  font-size: 0.82rem;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.03);
}

body:is(.mempool-space-ui, .page-mempool) #main-container .form-select:focus,
body:is(.mempool-space-ui, .page-mempool) #main-container .form-control:focus,
body:is(.mempool-space-ui, .page-mempool) #main-container input[type="text"]:focus,
body:is(.mempool-space-ui, .page-mempool) #main-container input[type="search"]:focus {
  background: var(--mp-elevated2) !important;
  border-color: rgba(var(--kyp-accent-rgb), 0.5) !important;
  box-shadow: 0 0 0 3px rgba(var(--kyp-accent-rgb), 0.1) !important;
  outline: none;
}

/* ─── 22. DataTables (libellés) ─────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .dataTables_wrapper .dataTables_length,
body:is(.mempool-space-ui, .page-mempool) .dataTables_wrapper .dataTables_info,
body:is(.mempool-space-ui, .page-mempool) .dataTables_wrapper .dataTables_filter label {
  font-size: 0.78rem !important;
  color: var(--mp-muted) !important;
}

/* ─── 23. Menus déroulants ───────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .dropdown-menu {
  background: var(--mp-elevated) !important;
  border: 1px solid var(--mp-border) !important;
  border-radius: var(--mp-radius-sm) !important;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.45), 0 0 0 1px rgba(0, 0, 0, 0.15) !important;
  padding: 0.35rem !important;
}

body:is(.mempool-space-ui, .page-mempool) .dropdown-item {
  color: var(--mp-muted) !important;
  border-radius: 6px !important;
  font-size: 0.84rem;
  padding: 0.45rem 0.75rem;
  transition: background 0.14s ease, color 0.14s ease;
}

body:is(.mempool-space-ui, .page-mempool) .dropdown-item:hover,
body:is(.mempool-space-ui, .page-mempool) .dropdown-item:focus {
  background: rgba(var(--kyp-accent-rgb), 0.1) !important;
  color: var(--mp-text) !important;
}

body:is(.mempool-space-ui, .page-mempool) .dropdown-divider {
  border-color: var(--mp-border) !important;
  opacity: 1;
  margin: 0.25rem 0;
}

/* ─── 24. Modales ───────────────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .modal-content {
  background: var(--mp-elevated) !important;
  border: 1px solid var(--mp-border) !important;
  border-radius: var(--mp-radius) !important;
  box-shadow: 0 16px 64px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(255, 255, 255, 0.04) !important;
}

body:is(.mempool-space-ui, .page-mempool) .modal-header { border-bottom: 1px solid var(--mp-border) !important; padding: 1rem 1.25rem; }

body:is(.mempool-space-ui, .page-mempool) .modal-title {
  font-family: 'Rajdhani', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase;
}

body:is(.mempool-space-ui, .page-mempool) .modal-footer { border-top: 1px solid var(--mp-border) !important; padding: 0.85rem 1.25rem; }
body:is(.mempool-space-ui, .page-mempool) .modal-backdrop.show { opacity: 0.65; }
body:is(.mempool-space-ui, .page-mempool) .btn-close { filter: invert(1); opacity: 0.55; transition: opacity 0.15s; }
body:is(.mempool-space-ui, .page-mempool) .btn-close:hover { opacity: 0.9; }

/* ─── 25. Alertes (variantes Krypton) ───────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .alert { border-radius: var(--mp-radius-sm) !important; font-size: 0.84rem; border-left-width: 3px !important; }
body:is(.mempool-space-ui, .page-mempool) .alert-info {
  background: rgba(var(--kyp-accent-rgb), 0.08) !important;
  border-color: rgba(var(--kyp-accent-rgb), 0.3) !important;
  color: var(--mp-text) !important;
  border-left-color: var(--mp-accent) !important;
}
body:is(.mempool-space-ui, .page-mempool) .alert-warning {
  background: var(--kyp-warn-dim) !important;
  border-color: var(--kyp-warn-border) !important;
  color: var(--mp-text) !important;
  border-left-color: var(--kyp-pending) !important;
}
body:is(.mempool-space-ui, .page-mempool) .alert-danger {
  background: var(--kyp-danger-dim) !important;
  border-color: var(--kyp-danger-border) !important;
  color: var(--mp-text) !important;
  border-left-color: var(--kyp-unconfirmed) !important;
}

/* ─── 26. Fil d’Ariane ──────────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .breadcrumb {
  background: rgba(0, 0, 0, 0.18) !important;
  border: 1px solid var(--mp-border);
  border-radius: var(--mp-radius-sm);
  padding: 0.45rem 0.9rem !important;
  font-size: 0.8rem;
  margin-bottom: 1rem;
}
body:is(.mempool-space-ui, .page-mempool) .breadcrumb-item + .breadcrumb-item::before { color: var(--mp-muted); opacity: 0.5; }
body:is(.mempool-space-ui, .page-mempool) .breadcrumb-item a { color: var(--mp-muted) !important; transition: color 0.15s; }
body:is(.mempool-space-ui, .page-mempool) .breadcrumb-item a:hover { color: var(--mp-accent) !important; }
body:is(.mempool-space-ui, .page-mempool) .breadcrumb-item.active { color: var(--mp-text) !important; }

/* ─── 27. Sélection texte ───────────────────────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) ::selection {
  background: rgba(var(--kyp-accent-rgb), 0.28);
  color: var(--mp-text);
}

/* ─── 28. Animations d’entrée (utilitaires) ─────────────────────────── */
body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in   { animation: kyp-fade-in 0.4s var(--mp-ease) both; }
body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-1 { animation-delay: 0.05s; }
body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-2 { animation-delay: 0.10s; }
body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-3 { animation-delay: 0.15s; }
body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-4 { animation-delay: 0.20s; }
body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-5 { animation-delay: 0.25s; }

@keyframes kyp-fade-in {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ─── 29. Responsive ─────────────────────────────────────────────────── */
@media (max-width: 991.98px) {
  body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body a.hash-link,
  body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body .hash-truncate { max-width: 110px; }

  body:is(.mempool-space-ui, .page-mempool) .mp-stat-value { font-size: 1.1rem !important; }

  body:is(.mempool-space-ui, .page-mempool) .card-body { padding: 0.85rem; }
}

@media (max-width: 767.98px) {
  body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body a.hash-link { max-width: 100px; }

  body:is(.mempool-space-ui, .page-mempool) .mp-stat-value { font-size: 1.1rem; }

  body:is(.mempool-space-ui, .page-mempool) .mp-detail-row {
    flex-direction: column;
    gap: 0.2rem;
  }

  body:is(.mempool-space-ui, .page-mempool) .mp-detail-value { text-align: left; }

  body:is(.mempool-space-ui, .page-mempool) .card-body { padding: 0.75rem; }

  body:is(.mempool-space-ui, .page-mempool) #page-header-container h3#page-title { font-size: 1.1rem; }

  body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body td { padding: 0.5rem 0.6rem; font-size: 0.78rem; }

  body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body a.hash-link,
  body:is(.mempool-space-ui, .page-mempool) #mempool-txs-body .hash-truncate { max-width: 80px; }

  body:is(.mempool-space-ui, .page-mempool) .kyp-toast {
    right: 0.75rem;
    bottom: 0.75rem;
    left: 0.75rem;
    max-width: none;
  }
}

/* ─── 30. Accessibilité : réduction de mouvement ─────────────────────── */
@media (prefers-reduced-motion: reduce) {
  body:is(.mempool-space-ui, .page-mempool) .kyp-skeleton,
  body:is(.mempool-space-ui, .page-mempool) .kyp-live-dot,
  body:is(.mempool-space-ui, .page-mempool) .kyp-live-dot.warn,
  body:is(.mempool-space-ui, .page-mempool) .kyp-toast,
  body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in,
  body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-1,
  body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-2,
  body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-3,
  body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-4,
  body:is(.mempool-space-ui, .page-mempool) .kyp-fade-in-5 {
    animation: none !important;
  }

  body:is(.mempool-space-ui, .page-mempool) .card.bg-dark.border-secondary:hover,
  body:is(.mempool-space-ui, .page-mempool) .btn-mp-primary:hover,
  body:is(.mempool-space-ui, .page-mempool) .mp-block-vis .mp-block-item:hover,
  body:is(.mempool-space-ui, .page-mempool) .page-item:not(.disabled) .page-link:hover {
    transform: none !important;
  }
}
