/* analytics-shared.css — shared styling for the four analytics pages */

:root {
  --pink: #ff2d6b;
  --buy: #3dffa0;
  --hold: #ffd700;
  --weth: #ff6b6b;
  --gold: #ffd700;
  --silver: #c0c8d4;
  --bronze: #c97b3a;

  --r-common: #9ca3af;
  --r-rare: #3b82f6;
  --r-epic: #a855f7;
  --r-legendary: #f59e0b;
  --r-mythic: #ef4444;

  --bg: #0a0a0c;
  --surface: #14141a;
  --surface2: #1c1c24;
  --surface3: #252531;
  --border: #2a2a36;
  --border-bright: #3a3a48;
  --text: #e6e6f0;
  --muted: #8a8a99;
  --dim: #5a5a68;

  --green: #3dffa0;
  --red: #ff6b6b;
}

* { box-sizing: border-box; margin: 0; padding: 0; }
html, body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', sans-serif;
  font-size: 14px;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

body::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image:
    radial-gradient(circle at 12% 8%, rgba(255,45,107,0.05) 0%, transparent 38%),
    radial-gradient(circle at 88% 92%, rgba(255,215,0,0.04) 0%, transparent 42%);
}
body::after {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 1;
  opacity: 0.02;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

main { position: relative; z-index: 2; }

/* ── TOPBAR ───────────────────────────────────────────────────────────── */
.topbar {
  position: sticky; top: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 24px;
  background: rgba(10,10,12,0.92); backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
}
.topbar-left { display: flex; align-items: center; gap: 14px; }
.topbar-logo img { height: 36px; width: auto; display: block; }

/* ── SECTION DROPDOWN MENU ──────────────────────────────────────────────
   Pattern: pill-shaped trigger that opens a floating menu.
   The trigger always shows the current section so users always know
   where they are. Tap to switch sections. */
.section-menu { position: relative; }
.section-menu-trigger {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: 'Permanent Marker', cursive; font-size: 14px;
  background: #1a1a22; border: 2px solid var(--border); border-radius: 100px;
  padding: 5px 14px 5px 16px;
  color: var(--text);
  cursor: pointer;
  transition: all 0.18s ease;
  white-space: nowrap;
  letter-spacing: 0.5px;
}
.section-menu-trigger:hover { transform: translateY(-1px); }
.section-menu-trigger.accent-pink  { border-color: var(--pink);   color: var(--pink); }
.section-menu-trigger.accent-green { border-color: var(--green);  color: var(--green); }
.section-menu-trigger.accent-gold  { border-color: var(--gold);   color: var(--gold); }
.section-menu-trigger.accent-pink:hover  { background: rgba(255,45,107,0.12); }
.section-menu-trigger.accent-green:hover { background: rgba(61,255,160,0.10); }
.section-menu-trigger.accent-gold:hover  { background: rgba(255,215,0,0.10); }

.section-menu-trigger .smt-caret {
  font-size: 10px;
  opacity: 0.7;
  transition: transform 0.2s ease;
  margin-top: 1px;
}
.section-menu.open .section-menu-trigger .smt-caret { transform: rotate(180deg); }

.section-menu-panel {
  position: absolute;
  top: calc(100% + 8px); left: 0;
  min-width: 200px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 6px;
  box-shadow: 0 18px 50px rgba(0,0,0,0.6);
  opacity: 0; visibility: hidden;
  transform: translateY(-6px);
  transition: opacity 0.16s ease, visibility 0.16s, transform 0.16s ease;
  z-index: 200;
}
.section-menu.open .section-menu-panel {
  opacity: 1; visibility: visible; transform: translateY(0);
}
.section-menu-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 10px 14px;
  border-radius: 10px;
  font-family: 'Permanent Marker', cursive; font-size: 15px;
  letter-spacing: 0.5px;
  transition: all 0.12s ease;
}
.section-menu-item .smi-check { font-size: 9px; opacity: 0.7; }
.section-menu-item.accent-pink  { color: var(--pink); }
.section-menu-item.accent-green { color: var(--green); }
.section-menu-item.accent-gold  { color: var(--gold); }
.section-menu-item.accent-pink:hover  { background: rgba(255,45,107,0.10); }
.section-menu-item.accent-green:hover { background: rgba(61,255,160,0.10); }
.section-menu-item.accent-gold:hover  { background: rgba(255,215,0,0.10); }
.section-menu-item.current.accent-pink  { background: rgba(255,45,107,0.06); }
.section-menu-item.current.accent-green { background: rgba(61,255,160,0.06); }
.section-menu-item.current.accent-gold  { background: rgba(255,215,0,0.06); }

.topbar-status {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  color: var(--muted);
  display: inline-flex; align-items: center; gap: 6px;
}
.topbar-status .dot {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--gold); animation: pulse 1.5s ease-in-out infinite;
}
.topbar-status.live .dot { background: var(--green); animation: pulse 2s ease-in-out infinite; }
.topbar-status.error .dot { background: var(--red); animation: none; }
@keyframes pulse {
  0%,100% { opacity: 0.4; transform: scale(1); }
  50% { opacity: 1; transform: scale(1.3); }
}

/* Subnav strip below topbar */
.subnav {
  position: sticky; top: 56px; z-index: 99;
  background: rgba(10,10,12,0.92); backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border);
  overflow-x: auto;
  scrollbar-width: none;
}
.subnav::-webkit-scrollbar { display: none; }
.subnav-inner {
  display: flex; gap: 4px; padding: 8px 24px;
  max-width: 1480px; margin: 0 auto;
}
.subnav-pill {
  font-family: 'Syne', sans-serif; font-weight: 700; font-size: 11px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--muted);
  padding: 6px 14px; border-radius: 100px;
  border: 1px solid transparent;
  white-space: nowrap;
  transition: all 0.15s ease;
}
.subnav-pill:hover { color: var(--text); }
.subnav-pill.active {
  background: var(--surface); border-color: var(--border);
  color: var(--text);
}

@media (max-width: 768px) {
  .topbar { padding: 8px 12px; gap: 8px; }
  .topbar-left { gap: 10px; }
  .topbar-logo img { height: 30px; }
  .section-menu-trigger { font-size: 13px; padding: 5px 12px; }
  .section-menu-panel { min-width: 180px; }
  .subnav { top: 48px; }
  .subnav-inner { padding: 7px 12px; }
  /* Hide the timestamp on the live indicator on tight screens */
  .topbar-status .t { display: none; }
}

/* ── HERO + PAGE LAYOUT ──────────────────────────────────────────────── */
.page { max-width: 1480px; margin: 0 auto; padding: 16px 24px 80px; position: relative; z-index: 2; }
@media (max-width: 768px) { .page { padding: 12px 12px 60px; } }
.hero { display: flex; flex-direction: column; align-items: center; margin-bottom: 14px; }
.hero h1 {
  font-family: 'Permanent Marker', cursive;
  font-size: clamp(24px, 3.5vw, 36px);
  letter-spacing: 1px; line-height: 1;
  background: linear-gradient(105deg, var(--gold) 0%, var(--pink) 60%, #ff8aa1 100%);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.hero p {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--muted); margin-top: 4px; text-align: center;
}

.section-head {
  display: flex; align-items: baseline; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
  margin: 28px 0 14px; padding-bottom: 8px;
  border-bottom: 2px solid var(--border);
}
.section-head h2 {
  font-family: 'Permanent Marker', cursive;
  font-size: clamp(20px, 2.8vw, 28px);
  letter-spacing: 1px;
}
.section-head .sub {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--muted);
}

/* ── PULSE ────────────────────────────────────────────────────────────── */
.pulse { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-bottom: 24px; }
@media (max-width: 760px) { .pulse { grid-template-columns: 1fr; } }
.pulse-card {
  background: var(--surface); border: 1px solid var(--border); border-radius: 12px;
  padding: 16px 18px; position: relative; overflow: hidden;
}
.pulse-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
}
.pulse-card.xeet::before { background: linear-gradient(90deg, transparent, var(--pink), transparent); }
.pulse-card.os::before   { background: linear-gradient(90deg, transparent, var(--gold), transparent); }
.pulse-head { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: 12px; }
.pulse-head .label { font-family: 'Permanent Marker', cursive; font-size: 18px; letter-spacing: 1px; }
.pulse-card.xeet .pulse-head .label { color: var(--pink); }
.pulse-card.os .pulse-head .label { color: var(--gold); }
.pulse-head .currency { font-family: 'JetBrains Mono', monospace; font-size: 10px; color: var(--muted); letter-spacing: 1.5px; text-transform: uppercase; }
.pulse-stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 480px) { .pulse-stats { grid-template-columns: repeat(2, 1fr); } }
.pulse-stat .v { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 24px; line-height: 1; }
.pulse-stat .l { font-family: 'JetBrains Mono', monospace; font-size: 9px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--muted); margin-top: 4px; }

/* ── SEARCH ───────────────────────────────────────────────────────────── */
#search-wrap { position: relative; max-width: 520px; margin: 0 auto 16px; }
.search-input {
  width: 100%; padding: 8px 16px;
  background: var(--surface); border: 1.5px solid var(--border); border-radius: 100px;
  color: var(--text); font-size: 13px; outline: none;
  transition: all 0.18s ease;
}
.search-input::placeholder { color: var(--muted); }
.search-input:focus { border-color: var(--pink); box-shadow: 0 0 0 4px rgba(255,45,107,0.12); }
.search-results {
  position: absolute; top: calc(100% + 8px); left: 0; right: 0;
  background: var(--surface); border: 1px solid var(--border); border-radius: 14px;
  max-height: 380px; overflow-y: auto;
  display: none; z-index: 50;
  box-shadow: 0 12px 40px rgba(0,0,0,0.6);
}
.search-results.open { display: block; }
.search-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; cursor: pointer;
  border-bottom: 1px solid rgba(255,255,255,0.04);
}
.search-row:last-child { border-bottom: none; }
.search-row:hover { background: var(--surface2); }
.search-row img { width: 34px; height: 34px; border-radius: 50%; object-fit: cover; border: 2px solid var(--border); }
.search-row .sr-name { font-weight: 600; font-size: 13px; }
.search-row .sr-handle { font-family: 'JetBrains Mono', monospace; font-size: 11px; color: var(--muted); }
.search-row .sr-meta { margin-left: auto; font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 13px; color: var(--gold); }
.search-empty { padding: 20px; text-align: center; color: var(--muted); font-size: 13px; }

/* ── RARITY BADGES ────────────────────────────────────────────────────── */
.rarity-badge {
  display: inline-flex; align-items: center;
  font-family: 'JetBrains Mono', monospace; font-size: 9px;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 3px 8px; border-radius: 100px;
  border: 1px solid currentColor;
  background: rgba(255,255,255,0.02);
}
.rarity-badge.r-Common    { color: var(--r-common); }
.rarity-badge.r-Rare      { color: var(--r-rare); }
.rarity-badge.r-Epic      { color: var(--r-epic); }
.rarity-badge.r-Legendary { color: var(--r-legendary); }
.rarity-badge.r-Mythic    { color: var(--r-mythic); }

/* ── CARD MODAL ───────────────────────────────────────────────────────── */
.modal {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.78); backdrop-filter: blur(8px);
  z-index: 1000; display: none;
  align-items: flex-start; justify-content: center;
  padding: 40px 16px; overflow-y: auto;
}
.modal.open { display: flex; }
.modal-panel {
  width: 100%; max-width: 880px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: 18px; overflow: hidden;
  position: relative;
  animation: panelIn 0.25s ease-out;
}
@keyframes panelIn {
  from { opacity: 0; transform: translateY(16px); }
  to { opacity: 1; transform: translateY(0); }
}
.modal-close {
  position: absolute; top: 14px; right: 14px;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--surface2); border: 1px solid var(--border);
  color: var(--muted);
  font-size: 20px; line-height: 1;
  display: flex; align-items: center; justify-content: center;
  z-index: 5;
  transition: all 0.15s ease;
}
.modal-close:hover { color: var(--text); border-color: var(--pink); }
.modal-body { padding: 22px; max-height: 90vh; overflow-y: auto; }
.modal-loading { padding: 80px; text-align: center; color: var(--muted); font-family: 'JetBrains Mono', monospace; font-size: 12px; }

.modal-grid {
  display: grid; grid-template-columns: 320px 1fr; gap: 22px;
}
@media (max-width: 720px) { .modal-grid { grid-template-columns: 1fr; } }
.modal-img {
  position: relative; aspect-ratio: 1 / 1;
  background: var(--surface2); border-radius: 12px; overflow: hidden;
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
}
.modal-img img {
  max-width: 100%; max-height: 100%;
  width: auto; height: auto;
  object-fit: contain; display: block;
}
.modal-img-placeholder {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  color: var(--dim);
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 1.5px;
}
.modal-rarity-badge {
  position: absolute; top: 10px; left: 10px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 1.5px; text-transform: uppercase;
  padding: 4px 10px; border-radius: 100px;
  border: 1px solid;
  background: rgba(10,10,12,0.7); backdrop-filter: blur(6px);
}
/* Rarity strip below image — small badges showing all rarities for this creator */
.modal-rarities {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-top: 12px;
}
.modal-rarity-pill {
  font-family: 'JetBrains Mono', monospace; font-size: 9.5px;
  letter-spacing: 1.3px; text-transform: uppercase;
  padding: 4px 9px; border-radius: 100px;
  border: 1px solid;
  background: rgba(10,10,12,0.5);
}
.modal-info { display: flex; flex-direction: column; min-width: 0; }
.modal-name {
  font-family: 'Permanent Marker', cursive; font-size: 28px; letter-spacing: 0.5px;
  margin-bottom: 4px;
  word-break: break-word;
}
.modal-handle {
  font-family: 'JetBrains Mono', monospace; font-size: 13px;
  color: var(--muted);
  margin-bottom: 18px;
  text-decoration: underline; text-decoration-color: var(--border);
  transition: color 0.15s ease;
}
.modal-handle:hover { color: var(--pink); text-decoration-color: var(--pink); }

.modal-marketplaces {
  display: grid; grid-template-columns: 1fr 1fr; gap: 12px;
}
@media (max-width: 540px) { .modal-marketplaces { grid-template-columns: 1fr; } }
.mm-card {
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px;
  position: relative;
}
.mm-card::before {
  content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px;
}
.mm-card.xeet::before { background: var(--pink); }
.mm-card.os::before   { background: var(--gold); }
.mm-head {
  font-family: 'Permanent Marker', cursive; font-size: 13px;
  letter-spacing: 0.5px;
  margin-bottom: 10px;
}
.mm-card.xeet .mm-head { color: var(--pink); }
.mm-card.os .mm-head   { color: var(--gold); }
.mm-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 5px 0;
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  border-bottom: 1px dashed rgba(255,255,255,0.05);
}
.mm-row:last-of-type { border-bottom: none; }
.mm-row span { color: var(--muted); letter-spacing: 0.5px; text-transform: uppercase; }
.mm-row strong {
  font-family: 'Barlow Condensed', sans-serif; font-weight: 700;
  font-size: 15px; color: var(--text);
}
.mm-row strong small { color: var(--muted); font-weight: 400; font-size: 10px; margin-left: 4px; }
.mm-spark { margin-top: 10px; }

/* Modal activity chart — full chart with axes, dots for actual sales */
.modal-chart-section {
  margin-top: 18px;
  background: var(--surface2); border: 1px solid var(--border);
  border-radius: 10px; padding: 14px 16px;
}
.modal-chart-head {
  display: flex; align-items: baseline; justify-content: space-between;
  margin-bottom: 10px;
}
.modal-chart-title {
  font-family: 'Permanent Marker', cursive; font-size: 14px;
  letter-spacing: 0.5px; color: var(--text);
}
.modal-chart-sub {
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 1px; text-transform: uppercase;
  color: var(--muted);
}
.modal-chart-legend {
  display: flex; gap: 14px; margin-top: 6px; flex-wrap: wrap;
}
.modal-chart-legend .lg {
  display: inline-flex; align-items: center; gap: 5px;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 0.8px; text-transform: uppercase;
  color: var(--muted);
}
.modal-chart-legend .lg .swatch {
  width: 8px; height: 8px; border-radius: 2px;
}
.modal-chart-legend .lg .dot {
  width: 6px; height: 6px; border-radius: 50%;
  border: 1.5px solid;
  background: var(--surface);
}
.mm-link {
  display: block; margin-top: 10px;
  text-align: center;
  font-family: 'JetBrains Mono', monospace; font-size: 10px;
  letter-spacing: 1.5px; text-transform: uppercase;
  color: var(--gold);
  padding: 6px;
  border: 1px dashed var(--border);
  border-radius: 6px;
  transition: all 0.15s ease;
}
.mm-link:hover { border-color: var(--gold); background: rgba(255,215,0,0.04); }

.sparkline { width: 100%; height: 28px; display: block; }

/* ── COMMON DATA TABLE STYLES ─────────────────────────────────────────── */
.empty-state {
  padding: 60px 20px; text-align: center; color: var(--muted);
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  letter-spacing: 1px;
}
.loading-state {
  padding: 40px; text-align: center; color: var(--muted);
  font-family: 'JetBrains Mono', monospace; font-size: 11px;
  letter-spacing: 1px;
}
