/* ============================================================
   Trade Rankz — Complete UI Overhaul
   ============================================================ */

/* ── Page wrapper ─────────────────────────────────────────── */
.cr-trade-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 0 60px;
}

/* ── Header ───────────────────────────────────────────────── */
.cr-trade-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(148,163,184,0.12);
}
.cr-trade-header-left { flex: 1; min-width: 0; }
.cr-trade-header-left h1 {
  margin: 0 0 5px;
  font-size: 1.75rem;
  font-weight: 800;
  letter-spacing: -.3px;
}
.cr-trade-header-left p {
  margin: 0;
  font-size: .88rem;
  color: rgba(148,163,184,0.8);
  line-height: 1.45;
}
.cr-trade-header-right {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

/* ── Live dot ─────────────────────────────────────────────── */
.cr-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  border-radius: 999px;
  border: 1px solid rgba(34,197,94,0.35);
  background: rgba(34,197,94,0.08);
  font-size: .78rem;
  font-weight: 700;
  color: rgba(134,239,172,0.9);
  white-space: nowrap;
}
.cr-live-dot-pulse {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #4ade80;
  animation: cr-pulse 2s infinite;
  flex-shrink: 0;
}
@keyframes cr-pulse {
  0%,100% { opacity:1; transform:scale(1); }
  50%      { opacity:.45; transform:scale(0.75); }
}

/* ── Webhook info box ─────────────────────────────────────── */
.cr-webhook-box {
  background: rgba(15,23,42,0.6);
  border: 1px solid rgba(148,163,184,0.14);
  border-radius: 14px;
  padding: 16px 20px;
  margin-bottom: 24px;
  font-size: .82rem;
  color: rgba(148,163,184,0.85);
}
.cr-webhook-box summary {
  cursor: pointer;
  font-weight: 700;
  color: rgba(226,232,240,0.9);
  list-style: none;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cr-webhook-box summary::before {
  content: '▶';
  font-size: .7rem;
  transition: transform .2s;
}
.cr-webhook-box[open] summary::before { transform: rotate(90deg); }
.cr-webhook-box pre {
  margin: 12px 0 0;
  background: rgba(2,6,23,0.7);
  border: 1px solid rgba(148,163,184,0.1);
  border-radius: 10px;
  padding: 14px;
  font-size: .78rem;
  overflow-x: auto;
  line-height: 1.6;
  color: rgba(165,243,252,0.9);
}

/* ── Controls section (view row + filter rows) ────────────── */
.cr-controls-section {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 16px;
  padding: 10px 0 4px;
  border-bottom: 1px solid rgba(148,163,184,.08);
}

/* Each filter row: label flush left, buttons inline */
.cr-filter-row {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: nowrap;
  min-height: 32px;
  overflow-x: auto;     /* scroll horizontally on mobile instead of clipping */
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none; /* hide scrollbar but keep scroll */
}
.cr-filter-row::-webkit-scrollbar { display: none; }
.cr-filter-label {
  font-size: .65rem;
  font-weight: 700;
  color: rgba(148,163,184,0.45);
  text-transform: uppercase;
  letter-spacing: .5px;
  white-space: nowrap;
  width: 72px;
  min-width: 72px;
  flex-shrink: 0;
}
/* Archive days inline */
.cr-archive-days-inline {
  display: inline-flex;
  gap: 4px;
  flex-wrap: nowrap;
  align-items: center;
  overflow-x: auto;
}
.cr-filter-btn {
  padding: 5px 11px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,0.18);
  background: rgba(255,255,255,0.04);
  color: rgba(226,232,240,0.75);
  font-size: .78rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.cr-filter-btn:hover {
  background: rgba(148,163,184,0.1);
  border-color: rgba(148,163,184,0.35);
  color: #e2e8f0;
}
.cr-filter-btn.is-active {
  color: #e2e8f0;
}
.cr-filter-btn.is-active[data-cr-tab="long"],
.cr-filter-btn.is-active[data-cr-rank="HIGH"] {
  background: rgba(34,211,238,0.15);
  border-color: rgba(34,211,238,0.5);
  color: #a5f3fc;
}
.cr-filter-btn.is-active[data-cr-tab="short"] {
  background: rgba(249,115,22,0.15);
  border-color: rgba(249,115,22,0.5);
  color: #fed7aa;
}
.cr-filter-btn.is-active[data-cr-tab="all"],
.cr-filter-btn.is-active[data-cr-rank="all"] {
  background: rgba(148,163,184,0.14);
  border-color: rgba(148,163,184,0.4);
  color: #e2e8f0;
}
.cr-filter-btn.is-active[data-cr-rank="MEDIUM"] {
  background: rgba(250,204,21,0.15);
  border-color: rgba(250,204,21,0.5);
  color: #fef08a;
}
.cr-filter-btn.is-active[data-cr-rank="LOW"] {
  background: rgba(167,139,250,0.15);
  border-color: rgba(167,139,250,0.5);
  color: #ddd6fe;
}
/* Status filter active states */
.cr-filter-btn.is-active[data-cr-status="active"] {
  border-color: rgba(34,197,94,.6);
  background: rgba(34,197,94,.12);
  color: #4ade80;
}
.cr-filter-btn.is-active[data-cr-status="closed"] {
  border-color: rgba(248,113,113,.5);
  background: rgba(248,113,113,.1);
  color: #f87171;
}
.cr-filter-divider {
  width: 1px;
  height: 22px;
  background: rgba(148,163,184,0.18);
  margin: 0 6px;
  flex-shrink: 0;
  align-self: center;
}

/* ── Signal cards grid ────────────────────────────────────── */
.cr-signals-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 14px;
}
@media(max-width: 640px) {
  .cr-signals-grid { grid-template-columns: 1fr; }
}

/* ── Signal card ──────────────────────────────────────────── */
.cr-signal-card {
  position: relative;
  border-radius: 16px;
  padding: 16px 18px;
  background: rgba(15,23,42,0.65);
  border: 1px solid rgba(148,163,184,0.12);
  transition: transform .15s, box-shadow .15s;
  overflow: hidden;
}
.cr-signal-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 3px;
  border-radius: 16px 16px 0 0;
  background: rgba(148,163,184,0.15);
}
.cr-signal-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(0,0,0,0.3);
}

/* Rank accent lines */
.cr-signal-card.rank-HIGH::before  { background: linear-gradient(90deg, #22d3ee, #0ea5e9); }
.cr-signal-card.rank-HIGH  { border-color: rgba(34,211,238,0.25); box-shadow: 0 0 0 1px rgba(34,211,238,0.08), 0 4px 20px rgba(34,211,238,0.06); }
.cr-signal-card.rank-MEDIUM::before{ background: linear-gradient(90deg, #facc15, #f59e0b); }
.cr-signal-card.rank-MEDIUM{ border-color: rgba(250,204,21,0.22); }
.cr-signal-card.rank-LOW::before   { background: linear-gradient(90deg, #a78bfa, #8b5cf6); }
.cr-signal-card.rank-LOW   { border-color: rgba(167,139,250,0.2); }

/* Locked (pro-gated exits) */
.cr-signal-card.is-locked .cr-card-price,
.cr-signal-card.is-locked .cr-card-pair,
.cr-signal-card.is-locked .cr-card-when {
  filter: blur(5px);
  user-select: none;
}
.cr-lock-overlay {
  display: none;
  position: absolute;
  inset: 0;
  border-radius: 16px;
  align-items: center;
  justify-content: center;
  background: rgba(2,6,23,0.55);
  backdrop-filter: blur(1px);
}
.cr-signal-card.is-locked .cr-lock-overlay { display: flex; }
.cr-lock-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  border-radius: 999px;
  background: rgba(250,204,21,0.18);
  border: 1px solid rgba(250,204,21,0.4);
  font-size: .78rem;
  font-weight: 800;
  color: #fef08a;
  text-decoration: none;
}

/* ── Card internals ───────────────────────────────────────── */
.cr-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.cr-card-badges {
  display: flex;
  align-items: center;
  gap: 6px;
}
.cr-rank-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .4px;
  text-transform: uppercase;
  border: 1px solid rgba(148,163,184,0.2);
  background: rgba(148,163,184,0.08);
  color: rgba(226,232,240,0.8);
}
.cr-rank-pill.HIGH   { border-color: rgba(34,211,238,0.5);  background: rgba(34,211,238,0.12);  color: #a5f3fc; }
.cr-rank-pill.MEDIUM { border-color: rgba(250,204,21,0.5);  background: rgba(250,204,21,0.12);  color: #fef08a; }
.cr-rank-pill.LOW    { border-color: rgba(167,139,250,0.5); background: rgba(167,139,250,0.12); color: #ddd6fe; }

.cr-side-pill {
  display: inline-flex;
  align-items: center;
  padding: 3px 10px;
  border-radius: 999px;
  font-size: .72rem;
  font-weight: 800;
  letter-spacing: .4px;
  text-transform: uppercase;
}
.cr-side-pill.LONG  { border: 1px solid rgba(34,197,94,0.5);  background: rgba(34,197,94,0.12);  color: #86efac; }
.cr-side-pill.SHORT { border: 1px solid rgba(239,68,68,0.5);  background: rgba(239,68,68,0.12);  color: #fca5a5; }
.cr-side-pill.EXIT  { border: 1px solid rgba(148,163,184,0.3); background: rgba(148,163,184,0.08); color: rgba(148,163,184,0.9); }

.cr-card-type {
  font-size: .72rem;
  font-weight: 700;
  color: rgba(148,163,184,0.6);
  text-transform: uppercase;
  letter-spacing: .4px;
}

.cr-card-pair {
  font-size: 1.25rem;
  font-weight: 800;
  color: #e2e8f0;
  margin-bottom: 4px;
  letter-spacing: -.2px;
}
.cr-card-exchange {
  font-size: .78rem;
  color: rgba(148,163,184,0.6);
  margin-bottom: 10px;
}
.cr-card-price-row {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 8px;
}
.cr-card-price-label {
  font-size: .75rem;
  color: rgba(148,163,184,0.6);
  font-weight: 600;
}
.cr-card-price {
  font-size: 1.05rem;
  font-weight: 700;
  color: #e2e8f0;
  font-variant-numeric: tabular-nums;
}
.cr-card-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid rgba(148,163,184,0.08);
}
.cr-card-when {
  font-size: .75rem;
  color: rgba(148,163,184,0.55);
}
.cr-card-reason {
  font-size: .72rem;
  color: rgba(148,163,184,0.5);
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Empty / loading state ────────────────────────────────── */
.cr-state-box {
  text-align: center;
  padding: 48px 20px;
  color: rgba(148,163,184,0.55);
  font-size: .9rem;
  grid-column: 1 / -1;
}
.cr-state-box svg {
  display: block;
  margin: 0 auto 14px;
  opacity: .35;
}

/* ── Section label ────────────────────────────────────────── */
.cr-section-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .6px;
  color: rgba(148,163,184,0.5);
  margin: 20px 0 10px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.cr-section-label::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(148,163,184,0.1);
}


/* ============================================================
   SIGNAL DETAIL DRAWER
   ============================================================ */
.cr-drawer-overlay {
  display: none;
  position: fixed; inset: 0;
  background: rgba(2,8,23,0.7);
  backdrop-filter: blur(4px);
  z-index: 1150;
  opacity: 0;
  transition: opacity 300ms ease;
}
.cr-drawer-overlay.is-open { display: block; opacity: 1; }

.cr-signal-drawer {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  max-height: 90vh;
  background: #0b1220;
  border-top: 1px solid rgba(148,163,184,0.15);
  border-radius: 20px 20px 0 0;
  z-index: 1200;
  overflow-y: auto;
  transform: translateY(100%);
  transition: transform 380ms cubic-bezier(0.16,1,0.3,1);
  box-shadow: 0 -16px 48px rgba(2,8,23,0.8);
}
.cr-signal-drawer.is-open { transform: translateY(0); }

@media (min-width: 720px) {
  .cr-signal-drawer {
    left: auto; bottom: auto;
    top: 50%; right: 24px;
    transform: translateX(120%) translateY(-50%);
    width: 420px; max-height: 85vh;
    border-radius: 16px;
    border: 1px solid rgba(148,163,184,0.15);
  }
  .cr-signal-drawer.is-open { transform: translateX(0) translateY(-50%); }
}

.cr-drawer-inner { padding: 20px; }

.cr-drawer-header {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid rgba(148,163,184,0.1);
}
.cr-drawer-title-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.cr-drawer-badges { display: flex; gap: 6px; flex-wrap: wrap; }
.cr-drawer-close {
  background: rgba(148,163,184,0.1); border: none;
  color: #94a3b8; width: 32px; height: 32px;
  border-radius: 50%; cursor: pointer; font-size: 14px;
  display: flex; align-items: center; justify-content: center;
  transition: background 200ms, color 200ms;
  flex-shrink: 0;
}
.cr-drawer-close:hover { background: rgba(239,68,68,0.15); color: #ef4444; }

.cr-drawer-pair {
  font-size: 22px; font-weight: 800;
  color: #f1f5f9; letter-spacing: -0.5px;
}
.cr-drawer-exchange {
  font-size: 11px; color: #64748b; margin-top: 2px; text-transform: uppercase; letter-spacing: 0.5px;
}

.cr-drawer-section {
  margin-bottom: 16px;
  padding: 14px;
  background: rgba(15,23,42,0.6);
  border: 1px solid rgba(148,163,184,0.08);
  border-radius: 12px;
}
.cr-drawer-pro-section {
  border-color: rgba(34,211,238,0.15);
  background: rgba(34,211,238,0.03);
}
.cr-drawer-pro-label {
  font-size: 11px; font-weight: 700; text-transform: uppercase;
  letter-spacing: 1px; color: #22d3ee; margin-bottom: 10px;
}

.cr-drawer-row {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 6px 0;
  border-bottom: 1px solid rgba(148,163,184,0.06);
  font-size: 13px; gap: 12px;
}
.cr-drawer-row:last-child { border-bottom: none; }
.cr-drawer-row > span:first-child { color: #64748b; white-space: nowrap; }
.cr-drawer-row > strong, .cr-drawer-row > span:last-child {
  color: #f1f5f9; font-weight: 600; text-align: right;
}
.cr-drawer-row em { font-style: normal; color: #64748b; font-size: 11px; }
.cr-drawer-reason span { color: #94a3b8; font-size: 12px; line-height: 1.5; }
.cr-pos { color: #22c55e !important; }
.cr-neg { color: #ef4444 !important; }

/* Pro gate */
.cr-drawer-gate {
  text-align: center;
  padding: 20px 16px;
  background: rgba(15,23,42,0.5);
  border: 1px solid rgba(148,163,184,0.1);
  border-radius: 12px;
  margin-bottom: 16px;
}
.cr-drawer-gate-icon { font-size: 32px; margin-bottom: 8px; }
.cr-drawer-gate-title { font-size: 16px; font-weight: 700; color: #f1f5f9; margin-bottom: 6px; }
.cr-drawer-gate-body { font-size: 13px; color: #64748b; line-height: 1.5; margin-bottom: 16px; }
.cr-drawer-gate-preview { text-align: left; margin-bottom: 16px; }
.cr-blurred { filter: blur(4px); pointer-events: none; user-select: none; opacity: 0.5; }

.cr-drawer-actions { display: flex; flex-direction: column; gap: 8px; }
.cr-drawer-btn {
  display: block; text-align: center; padding: 11px 16px;
  border-radius: 10px; font-size: 13px; font-weight: 600;
  text-decoration: none; transition: all 200ms;
}
.cr-drawer-btn-primary {
  background: linear-gradient(135deg, #22c55e, #22d3ee);
  color: #020817;
}
.cr-drawer-btn-primary:hover { opacity: 0.9; }
.cr-drawer-btn-secondary {
  background: rgba(148,163,184,0.08);
  border: 1px solid rgba(148,163,184,0.15);
  color: #94a3b8;
}
.cr-drawer-btn-secondary:hover { color: #f1f5f9; border-color: rgba(148,163,184,0.3); }
.cr-drawer-btn-upgrade {
  background: linear-gradient(135deg, #facc15, #f97316);
  color: #020817; font-weight: 700;
}
.cr-drawer-btn-upgrade:hover { opacity: 0.9; }

/* Tap hint on cards */
.cr-card-tap-hint {
  font-size: 10px; color: #475569; text-align: right;
  margin-top: 6px; letter-spacing: 0.3px;
}
.cr-signal-card { cursor: pointer; }
.cr-signal-card:hover .cr-card-tap-hint { color: #22d3ee; }

/* Follow button */
.cr-follow-btn {
  background: rgba(148,163,184,0.08);
  border: 1px solid rgba(148,163,184,0.2);
  color: #94a3b8;
  transition: all 200ms;
}
.cr-follow-btn:hover { color: #facc15; border-color: rgba(250,204,21,0.4); background: rgba(250,204,21,0.07); }
.cr-follow-btn.is-following { color: #facc15; border-color: rgba(250,204,21,0.5); background: rgba(250,204,21,0.1); }
.cr-follow-btn.is-limit { color: #64748b; border-color: rgba(148,163,184,0.1); cursor: not-allowed; }

/* Compliance disclaimer */
.cr-drawer-disclaimer {
  font-size: 11px; color: #475569; line-height: 1.5;
  padding: 10px 14px; margin-bottom: 10px;
  background: rgba(15,23,42,0.4);
  border: 1px solid rgba(148,163,184,0.06);
  border-radius: 8px;
  font-style: italic;
}

/* Page-level disclaimer on Trade Rankz page */
.cr-page-disclaimer {
  font-size: 11px; color: #475569; line-height: 1.5;
  text-align: center; padding: 16px 20px;
  border-top: 1px solid rgba(148,163,184,0.06);
  margin-top: 24px;
}

/* ── Timeframe badge on signal card ─────────────────────────────────────── */
.cr-tf-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  background: rgba(129,140,248,.15);
  color: #818cf8;
  border: 1px solid rgba(129,140,248,.3);
  line-height: 1.4;
}

/* ── Trade category badge ────────────────────────────────────────────────── */
.cr-cat-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  border-radius: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
  line-height: 1.4;
}
.cr-cat-scalp    { background: rgba(34,211,238,.12); color:#22d3ee; border:1px solid rgba(34,211,238,.3); }
.cr-cat-intraday { background: rgba(250,204,21,.12);  color:#fbbf24; border:1px solid rgba(250,204,21,.3); }
.cr-cat-swing    { background: rgba(34,197,94,.12);   color:#4ade80; border:1px solid rgba(34,197,94,.3); }

/* ── Tracked alerts in dashboard ─────────────────────────────────────────── */
.cr-tracked-table { width:100%; border-collapse:collapse; font-size:13px; }
.cr-tracked-table th { text-align:left; padding:6px 10px; color:#64748b; font-size:11px; text-transform:uppercase; letter-spacing:.05em; border-bottom:1px solid rgba(148,163,184,.1); }
.cr-tracked-table td { padding:10px; border-bottom:1px solid rgba(148,163,184,.07); color:#e2e8f0; vertical-align:middle; }
.cr-tracked-table tr:last-child td { border-bottom:none; }
.cr-tracked-table tr:hover td { background:rgba(148,163,184,.04); }
.cr-tracked-coin { font-weight:700; }
.cr-tracked-side.long  { color:#4ade80; }
.cr-tracked-side.short { color:#f87171; }
.cr-tracked-remove { background:none; border:none; cursor:pointer; color:#475569; font-size:14px; padding:2px 6px; border-radius:4px; transition:color .15s; }
.cr-tracked-remove:hover { color:#f87171; }

/* ── Target hit badge in drawer ──────────────────────────────────────────── */
.cr-target-row.is-hit strong { color: #4ade80 !important; }
.cr-target-hit-badge {
  display: inline-block;
  background: rgba(34,197,94,.18);
  border: 1px solid rgba(34,197,94,.4);
  color: #4ade80;
  border-radius: 5px;
  padding: 1px 7px;
  font-size: 10px;
  font-weight: 700;
  margin-left: 6px;
  vertical-align: middle;
  animation: cr-pop .3s ease;
}
@keyframes cr-pop { 0%{transform:scale(.8);opacity:0} 100%{transform:scale(1);opacity:1} }

/* ── Coin page Trade Rankz section ───────────────────────────────────────── */
.cr-coin-signals-section {
  margin: 24px 0;
  background: rgba(7,15,31,.6);
  border: 1px solid rgba(148,163,184,.12);
  border-radius: 14px;
  overflow: hidden;
}
.cr-coin-signals-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px 12px;
  border-bottom: 1px solid rgba(148,163,184,.1);
  flex-wrap: wrap;
  gap: 8px;
}
.cr-coin-signals-header h2 {
  font-size: 1rem;
  font-weight: 700;
  color: #f1f5f9;
  margin: 0;
}
.cr-coin-signals-sub {
  font-size: 11px;
  color: #64748b;
  margin-top: 2px;
  display: block;
}
.cr-coin-signals-grid {
  padding: 16px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 12px;
}
.cr-coin-sig-loading, .cr-coin-sig-empty {
  grid-column: 1 / -1;
  text-align: center;
  padding: 28px 0;
  color: #475569;
  font-size: 13px;
}
.cr-coin-sig-card {
  background: rgba(15,30,51,.8);
  border: 1px solid rgba(148,163,184,.15);
  border-radius: 10px;
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  transition: border-color .2s;
}
.cr-coin-sig-card:hover { border-color: rgba(34,211,238,.3); }
.cr-coin-sig-card.rank-high { border-left: 3px solid #22c55e; }
.cr-coin-sig-card.rank-medium { border-left: 3px solid #facc15; }
.cr-coin-sig-card.rank-low { border-left: 3px solid #818cf8; }
.cr-coin-sig-badges { display: flex; flex-wrap: wrap; gap: 5px; align-items: center; }
.cr-coin-sig-reason { font-size: 12px; color: #94a3b8; line-height: 1.5; }
.cr-coin-sig-price { font-size: 11px; color: #64748b; }
.cr-coin-sig-targets { display: flex; flex-direction: column; gap: 4px; margin-top: 2px; }
.cr-coin-sig-target {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  color: #64748b;
  padding: 3px 8px;
  background: rgba(148,163,184,.05);
  border-radius: 5px;
  border: 1px solid rgba(148,163,184,.1);
}
.cr-coin-sig-target.hit {
  background: rgba(34,197,94,.15);
  border-color: rgba(34,197,94,.55);
  color: #4ade80;
  font-weight: 700;
  box-shadow: 0 0 6px rgba(34,197,94,.2);
}
.cr-coin-sig-target em { font-size: 10px; color: #4ade80; margin-left: 4px; font-style: normal; }
.cr-coin-sig-link {
  font-size: 11px;
  color: #22d3ee;
  text-decoration: none;
  margin-top: 4px;
  transition: color .15s;
}
.cr-coin-sig-link:hover { color: #67e8f9; }

/* ── Archive bar (shows when past day is selected) ────────── */
.cr-archive-bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 7px 12px;
  background: rgba(34,211,238,.06);
  border: 1px solid rgba(34,211,238,.18);
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  color: #67e8f9;
  flex-wrap: wrap;
}
.cr-back-live-btn {
  font-size: .76rem !important;
  padding: 3px 11px !important;
}

/* ── Archive status badges on cards ─────────────────────────────────────── */
.cr-status-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 5px;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .04em;
}
.cr-status-badge.stopped     { background:rgba(239,68,68,.12); color:#f87171; border:1px solid rgba(239,68,68,.3); }
.cr-status-badge.all-hit     { background:rgba(34,197,94,.12); color:#4ade80; border:1px solid rgba(34,197,94,.3); }
.cr-status-badge.partial-hit { background:rgba(250,204,21,.1); color:#fbbf24; border:1px solid rgba(250,204,21,.3); }

/* ── Top Coins tab switcher ────────────────────────────────── */
.cr-tab-row {
  display: flex;
  gap: 8px;
  padding: 16px 0 0;
  margin-bottom: 20px;
  justify-content: flex-start;
}
.cr-tab-pill {
  display: inline-flex;
  align-items: center;
  padding: 9px 22px;
  border-radius: 999px;
  border: 1px solid rgba(148,163,184,0.2);
  background: rgba(255,255,255,0.04);
  color: rgba(226,232,240,0.7);
  font-size: .88rem;
  font-weight: 600;
  text-decoration: none;
  transition: all .15s;
}
.cr-tab-pill:hover {
  background: rgba(148,163,184,0.1);
  border-color: rgba(148,163,184,0.4);
  color: #e2e8f0;
}
.cr-tab-pill.is-active {
  background: rgba(34,211,238,0.12);
  border-color: rgba(34,211,238,0.5);
  color: #a5f3fc;
}

/* ── Coin Search Bar ─────────────────────────────────────────────────────── */
.cr-coin-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex: 1;
  max-width: 320px;
}
.cr-coin-search-input {
  width: 100%;
  background: rgba(15,23,42,.7);
  border: 1px solid rgba(148,163,184,.25);
  border-radius: 8px;
  color: #f1f5f9;
  font-size: 13px;
  padding: 7px 32px 7px 12px;
  outline: none;
  transition: border-color .2s;
}
.cr-coin-search-input:focus {
  border-color: rgba(34,211,238,.5);
}
.cr-coin-search-input::placeholder { color: #475569; }
.cr-coin-search-clear {
  position: absolute;
  right: 8px;
  background: none;
  border: none;
  color: #64748b;
  cursor: pointer;
  font-size: 12px;
  padding: 2px 4px;
  line-height: 1;
}
.cr-coin-search-clear:hover { color: #f1f5f9; }

/* ── Clickable signal cards (coin page) ─────────────────────────────────── */
.cr-coin-sig-card[style*="pointer"] {
  transition: transform .15s, box-shadow .15s;
}
.cr-coin-sig-card[style*="pointer"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(34,211,238,.15);
}

/* ════════════════════════════════════════════════════════════════════════════
   MASTER COIN CARDS
   ════════════════════════════════════════════════════════════════════════════ */
.cr-master-card {
  background: #0f172a;
  border: 1px solid rgba(148,163,184,.12);
  border-radius: 14px;
  padding: 16px;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
  position: relative;
  overflow: hidden;
}
.cr-master-card::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 14px;
  opacity: 0;
  transition: opacity .18s;
  pointer-events: none;
}
.cr-master-card:hover { transform: translateY(-3px); box-shadow: 0 8px 32px rgba(0,0,0,.4); }
.cr-master-card.rank-HIGH   { border-top: 2px solid rgba(34,197,94,.6); }
.cr-master-card.rank-HIGH:hover { border-color: rgba(34,197,94,.9); box-shadow: 0 8px 32px rgba(34,197,94,.15); }
.cr-master-card.rank-MEDIUM { border-top: 2px solid rgba(250,204,21,.5); }
.cr-master-card.rank-MEDIUM:hover { border-color: rgba(250,204,21,.8); box-shadow: 0 8px 32px rgba(250,204,21,.1); }
.cr-master-card.rank-LOW    { border-top: 2px solid rgba(129,140,248,.4); }

.cr-master-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 10px;
}
.cr-master-sym {
  font-size: 20px;
  font-weight: 700;
  color: #f1f5f9;
  letter-spacing: -.3px;
  line-height: 1.1;
}
.cr-master-bias-row {
  display: flex;
  gap: 6px;
  margin-top: 5px;
  flex-wrap: wrap;
}
.cr-master-bias {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 7px;
  border-radius: 20px;
  letter-spacing: .3px;
}
.cr-master-bias.bull { background: rgba(34,197,94,.12); color: #4ade80; border: 1px solid rgba(34,197,94,.2); }
.cr-master-bias.bear { background: rgba(239,68,68,.12);  color: #f87171; border: 1px solid rgba(239,68,68,.2); }

.cr-master-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 5px;
}
.cr-master-count {
  font-size: 11px;
  color: #64748b;
  font-weight: 500;
}

.cr-master-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px;
}
.cr-master-pill {
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 20px;
  font-weight: 600;
  border: 1px solid transparent;
}
.cr-master-pill.rank-HIGH   { background: rgba(34,197,94,.1);  color: #4ade80; border-color: rgba(34,197,94,.2); }
.cr-master-pill.rank-MEDIUM { background: rgba(250,204,21,.1); color: #fcd34d; border-color: rgba(250,204,21,.2); }
.cr-master-pill.rank-LOW    { background: rgba(129,140,248,.1);color: #a5b4fc; border-color: rgba(129,140,248,.2); }
.cr-master-pill.status-stopped { opacity: .55; }
.cr-master-pill.status-closed  { opacity: .65; }
.cr-master-more { font-size: 11px; color: #475569; padding: 3px 8px; }

.cr-master-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-top: 1px solid rgba(148,163,184,.1);
  padding-top: 9px;
  margin-top: 2px;
}
.cr-master-active { font-size: 11px; color: #22c55e; font-weight: 600; }
.cr-master-when   { font-size: 11px; color: #475569; }
.cr-master-tap    { font-size: 11px; color: #22d3ee; opacity: .7; }

/* ════════════════════════════════════════════════════════════════════════════
   COIN PANEL (slides up from bottom, level-1 drill-down)
   ════════════════════════════════════════════════════════════════════════════ */
.cr-coin-panel {
  position: fixed;
  inset: 0;
  z-index: 1100;
  pointer-events: none;
  opacity: 0;
  transition: opacity .22s ease;
}
.cr-coin-panel.is-open {
  pointer-events: all;
  opacity: 1;
}
.cr-coin-panel-inner {
  position: absolute;
  inset: 0;
  top: 0;
  background: #080e1e;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform .3s cubic-bezier(.16,1,.3,1);
  overflow: hidden;
}
.cr-coin-panel.is-open .cr-coin-panel-inner {
  transform: translateY(0);
}

.cr-coin-panel-header {
  background: #0b1220;
  border-bottom: 1px solid rgba(148,163,184,.12);
  padding: 14px 16px 10px;
  flex-shrink: 0;
}
.cr-coin-panel-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 12px;
}
.cr-coin-panel-back {
  background: rgba(30,41,59,.8);
  border: 1px solid rgba(148,163,184,.2);
  color: #94a3b8;
  font-size: 13px;
  font-weight: 600;
  padding: 6px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: color .15s, border-color .15s;
  flex-shrink: 0;
}
.cr-coin-panel-back:hover { color: #f1f5f9; border-color: rgba(148,163,184,.4); }
.cr-coin-panel-sym {
  font-size: 22px;
  font-weight: 800;
  color: #f1f5f9;
  flex: 1;
  letter-spacing: -.3px;
}
.cr-coin-panel-chart-link {
  font-size: 12px;
  color: #22d3ee;
  text-decoration: none;
  padding: 5px 10px;
  border: 1px solid rgba(34,211,238,.25);
  border-radius: 8px;
  white-space: nowrap;
  transition: background .15s;
  flex-shrink: 0;
}
.cr-coin-panel-chart-link:hover { background: rgba(34,211,238,.08); }

.cr-coin-panel-filters {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.cr-panel-filter-group {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}
.cr-panel-btn {
  background: rgba(30,41,59,.6);
  border: 1px solid rgba(148,163,184,.18);
  color: #94a3b8;
  font-size: 12px;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 20px;
  cursor: pointer;
  transition: all .15s;
}
.cr-panel-btn:hover       { color: #f1f5f9; border-color: rgba(148,163,184,.4); }
.cr-panel-btn.is-active   { background: rgba(34,211,238,.12); color: #22d3ee; border-color: rgba(34,211,238,.35); }

.cr-coin-panel-list {
  flex: 1;
  overflow-y: auto;
  padding: 12px 16px 24px;
  -webkit-overflow-scrolling: touch;
}

.cr-panel-empty {
  text-align: center;
  color: #475569;
  padding: 48px 16px;
  font-size: 14px;
}

/* Panel signal row */
.cr-panel-signal-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: #0f172a;
  border: 1px solid rgba(148,163,184,.1);
  border-radius: 12px;
  padding: 13px 14px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: transform .15s, border-color .15s, box-shadow .15s;
}
.cr-panel-signal-row:hover {
  transform: translateX(3px);
  border-color: rgba(34,211,238,.25);
  box-shadow: 0 2px 12px rgba(34,211,238,.08);
}
.cr-panel-signal-row:active { transform: scale(.98); }
.cr-panel-row-left   { flex: 1; min-width: 0; }
.cr-panel-row-badges { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 7px; }
.cr-panel-row-meta   { display: flex; gap: 12px; align-items: center; }
.cr-panel-row-price  { font-size: 13px; font-weight: 700; color: #f1f5f9; }
.cr-panel-row-when   { font-size: 11px; color: #475569; }
.cr-panel-row-reason { font-size: 11px; color: #64748b; margin-top: 5px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 100%; }
.cr-panel-row-arrow  { font-size: 22px; color: #334155; margin-left: 10px; flex-shrink: 0; transition: color .15s; }
.cr-panel-signal-row:hover .cr-panel-row-arrow { color: #22d3ee; }

/* ════════════════════════════════════════════════════════════════════════════
   STATUS BADGE (used in both panel and cards)
   ════════════════════════════════════════════════════════════════════════════ */
.cr-status-badge.open {
  background: rgba(34,197,94,.1);
  color: #4ade80;
  border: 1px solid rgba(34,197,94,.2);
  font-size: 10px;
  padding: 2px 7px;
  border-radius: 20px;
  font-weight: 600;
}

/* ════════════════════════════════════════════════════════════════════════════
   SEARCH BAR (Trade Rankz page)
   ════════════════════════════════════════════════════════════════════════════ */
.cr-coin-search-wrap {
  position: relative;
  display: flex;
  align-items: center;
  flex: 1;
  max-width: 320px;
}
.cr-coin-search-input {
  width: 100%;
  background: rgba(15,23,42,.7);
  border: 1px solid rgba(148,163,184,.25);
  border-radius: 8px;
  color: #f1f5f9;
  font-size: 13px;
  padding: 7px 32px 7px 12px;
  outline: none;
  transition: border-color .2s;
}
.cr-coin-search-input:focus { border-color: rgba(34,211,238,.5); }
.cr-coin-search-input::placeholder { color: #475569; }
.cr-coin-search-clear {
  position: absolute;
  right: 8px;
  background: none;
  border: none;
  color: #64748b;
  cursor: pointer;
  font-size: 12px;
  padding: 2px 4px;
  line-height: 1;
}
.cr-coin-search-clear:hover { color: #f1f5f9; }

/* ════════════════════════════════════════════════════════════════════════════
   CLICKABLE COIN PAGE SIGNAL CARDS
   ════════════════════════════════════════════════════════════════════════════ */
.cr-coin-sig-card[style*="pointer"]:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(34,211,238,.12);
}

.cr-master-pro-pill { font-size:10px; padding:2px 7px; border-radius:10px; background:rgba(251,191,36,.15); border:1px solid rgba(251,191,36,.35); color:#fbbf24; font-weight:600; }
.cr-master-pro-cta {
  font-size: 12px;
  color: #fbbf24;
  font-weight: 700;
  text-decoration: none;
  padding: 3px 10px;
  border-radius: 999px;
  background: rgba(251,191,36,.12);
  border: 1px solid rgba(251,191,36,.3);
  transition: background 180ms;
}
.cr-master-pro-cta:hover { background: rgba(251,191,36,.22); }
