/* ── Reset & Base ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; -moz-text-size-adjust: 100%; text-size-adjust: 100%; }
button, a, input, select, label, .badge, .main-nav-tab { touch-action: manipulation; }

:root,
[data-theme="dark"] {
  --bg-primary: #0a0e17;
  --bg-secondary: #111827;
  --bg-panel: #1a1f2e;
  --border: #2a3042;
  --text-primary: #e2e8f0;
  --text-secondary: #8892a6;
  --accent-green: #00e676;
  --accent-red: #ff1744;
  --accent-blue: #448aff;
  --accent-yellow: #ffd600;
  --accent-orange: #ff9100;
  --accent-purple: #7c4dff;
  --shadow-color: rgba(0, 0, 0, 0.4);
  --code-bg: #0d1117;
  --code-text: #c9d1d9;
  --logo-icon-invert: none;
}

[data-theme="light"] {
  --bg-primary: #f0f2f5;
  --bg-secondary: #ffffff;
  --bg-panel: #f8f9fb;
  --border: #d1d5db;
  --text-primary: #1a1a2e;
  --text-secondary: #6b7280;
  --accent-green: #059669;
  --accent-red: #dc2626;
  --accent-blue: #2563eb;
  --accent-yellow: #d97706;
  --accent-orange: #ea580c;
  --accent-purple: #7c3aed;
  --shadow-color: rgba(0, 0, 0, 0.1);
  --code-bg: #f6f8fa;
  --code-text: #24292f;
  --logo-icon-invert: brightness(0.3);
}

body {
  font-family: 'Segoe UI', -apple-system, BlinkMacSystemFont, monospace;
  background: var(--bg-primary);
  color: var(--text-primary);
  min-height: 100vh;
  transition: background 0.3s, color 0.3s;
}

/* ── Header ── */
/* TradingView Ticker Tape */
.tv-ticker-wrap {
  width: 100%;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  background: var(--bg-secondary);
}
.tv-ticker-wrap .tradingview-widget-container { margin: 0; }
.tv-ticker-wrap .tradingview-widget-copyright { display: none; }

.header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 16px 24px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  transition: background 0.3s, border-color 0.3s;
}

.header-left {
  display: flex;
  align-items: center;
  gap: 12px;
}

.logo-icon {
  width: 30px;
  height: 30px;
  object-fit: contain;
  filter: var(--logo-icon-invert, none) drop-shadow(0 0 6px rgba(0, 230, 118, 0.4));
  transition: filter 0.3s;
}

/* ── Theme Toggle ── */
.theme-toggle {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.5px;
}

.theme-toggle:hover {
  border-color: var(--accent-blue);
  background: rgba(68, 138, 255, 0.08);
}

.logo {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: 2px;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-green));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.badge {
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
  background: var(--accent-orange);
  color: #000;
  letter-spacing: 1px;
}

.header-right {
  display: flex;
  align-items: center;
  gap: 20px;
}

.status {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--text-secondary);
}

.status-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent-yellow);
  animation: pulse 1.5s infinite;
}

.status.connected .status-dot {
  background: var(--accent-green);
  animation: none;
}

.status.error .status-dot {
  background: var(--accent-red);
  animation: none;
}

.last-updated {
  font-size: 12px;
  color: var(--text-secondary);
}

/* ── User Auth ── */
.user-auth {
  display: flex;
  align-items: center;
}

.login-btn {
  display: flex;
  align-items: center;
  gap: 6px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 5px 12px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.3px;
  transition: all 0.2s;
}

.login-btn:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
  background: rgba(68, 138, 255, 0.08);
}

.login-btn svg {
  flex-shrink: 0;
}

.user-info {
  display: flex;
  align-items: center;
  gap: 8px;
}

.user-avatar {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: 2px solid var(--accent-blue);
  object-fit: cover;
}

.user-name {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.logout-btn {
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.3px;
  transition: all 0.2s;
}

.logout-btn:hover {
  border-color: var(--accent-red);
  color: var(--accent-red);
  background: rgba(255, 23, 68, 0.08);
}

/* ── Main Navigation Tabs ── */
.main-nav {
  display: flex;
  background: var(--bg-secondary);
  border-bottom: 2px solid var(--border);
  padding: 0 24px;
  gap: 0;
  transition: background 0.3s, border-color 0.3s;
}

.main-nav-tab {
  background: none;
  border: none;
  border-bottom: 3px solid transparent;
  color: var(--text-secondary);
  padding: 10px 24px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all 0.2s;
  position: relative;
}

.main-nav-tab:hover {
  color: var(--text-primary);
  background: rgba(68, 138, 255, 0.04);
}

.main-nav-tab.active {
  color: var(--accent-blue);
  border-bottom-color: var(--accent-blue);
}

/* ── Exchange Referral Banner ── */
.referral-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 12px;
  padding: 8px 24px;
  background: var(--bg-secondary);
  border-bottom: 1px solid var(--border);
  transition: background 0.3s, border-color 0.3s;
}

.referral-buttons {
  display: flex;
  align-items: center;
  gap: 10px;
}

.referral-note {
  width: 100%;
  text-align: center;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.referral-note strong {
  color: var(--text-primary);
}

.referral-note a {
  color: var(--accent-blue);
  text-decoration: underline;
}

.referral-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  letter-spacing: 0.5px;
  text-transform: uppercase;
}

.referral-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 18px;
  border-radius: 6px;
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
  transition: all 0.2s;
  border: 1px solid transparent;
}

.referral-name {
  letter-spacing: 0.3px;
}

.referral-bonus {
  font-size: 10px;
  font-weight: 600;
  opacity: 0.8;
  padding: 1px 6px;
  border-radius: 3px;
  background: rgba(255,255,255,0.15);
}

.referral-binance {
  background: linear-gradient(135deg, #F0B90B 0%, #e0a800 100%);
  color: #1a1a1a;
}

.referral-binance:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(240, 185, 11, 0.35);
}

.referral-binance .referral-bonus {
  background: rgba(0,0,0,0.12);
}

.referral-bybit {
  background: linear-gradient(135deg, #f7a600 0%, #e69500 100%);
  color: #1a1a1a;
}

.referral-bybit:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(247, 166, 0, 0.35);
}

.referral-bybit .referral-bonus {
  background: rgba(0,0,0,0.12);
}

.referral-okx {
  background: linear-gradient(135deg, #ffffff 0%, #e8e8e8 100%);
  color: #1a1a1a;
}

.referral-okx:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.2);
}

.referral-okx .referral-bonus {
  background: rgba(0,0,0,0.08);
}

.referral-htx {
  background: linear-gradient(135deg, #2b6aff 0%, #1a5ae0 100%);
  color: #fff;
}

.referral-htx:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(43, 106, 255, 0.35);
}

.referral-htx .referral-bonus {
  background: rgba(255,255,255,0.15);
}

.referral-bitget {
  background: linear-gradient(135deg, #00b897 0%, #009a7e 100%);
  color: #fff;
}

.referral-bitget:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(0, 184, 151, 0.35);
}

.referral-bitget .referral-bonus {
  background: rgba(255,255,255,0.15);
}

/* ── Main with Side Ads ── */
.main-with-sides {
  display: flex;
  justify-content: center;
  gap: 20px;
  max-width: 1920px;
  margin: 0 auto;
  padding: 0 20px;
}

/* ── Side Ad Slots ── */
.ad-side {
  width: 160px;
  flex-shrink: 0;
  position: sticky;
  top: 20px;
  align-self: flex-start;
  height: fit-content;
}


/* ── Dashboard ── */
.dashboard {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  padding: 20px 0;
  max-width: 1600px;
  flex: 1;
  min-width: 0;
}

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

/* ── Alert Toggle ── */
.alert-toggle {
  display: inline-flex;
  align-items: center;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 3px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
}

.alert-toggle:hover {
  border-color: var(--accent-yellow);
  color: var(--accent-yellow);
}

.alert-toggle.active {
  background: rgba(255, 214, 0, 0.12);
  border-color: var(--accent-yellow);
  color: var(--accent-yellow);
}

/* ── 15m Premium Button ── */
.tf-premium {
  color: var(--accent-yellow) !important;
  position: relative;
}

/* ── Admin Panel ── */
.admin-panel {
  max-width: 900px;
  margin: 20px auto;
  padding: 0 20px;
}

.admin-table {
  width: 100%;
}

.admin-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 6px;
}

.admin-email {
  font-size: 11px;
  color: var(--text-secondary);
}

.admin-ref-btn {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  color: var(--accent-red);
  padding: 3px 14px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
}

.admin-ref-btn.active {
  background: rgba(0, 230, 118, 0.12);
  border-color: var(--accent-green);
  color: var(--accent-green);
}

/* ── Admin Stats Cards ── */
.admin-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 16px;
}

.admin-stat-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  text-align: center;
  transition: background 0.3s, border-color 0.3s;
}

.admin-stat-value {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.2;
}

.admin-stat-label {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 4px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.admin-stat-blue .admin-stat-value { color: var(--accent-blue); }
.admin-stat-green .admin-stat-value { color: var(--accent-green); }
.admin-stat-purple .admin-stat-value { color: var(--accent-purple); }
.admin-stat-yellow .admin-stat-value { color: var(--accent-yellow); }
.admin-stat-orange .admin-stat-value { color: var(--accent-orange); }
.admin-stat-red .admin-stat-value { color: var(--accent-red); }

@media (max-width: 480px) {
  .admin-stats { grid-template-columns: repeat(2, 1fr); }
  .admin-stat-value { font-size: 22px; }
}

/* ── Panel ── */
.panel {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  transition: background 0.3s, border-color 0.3s;
}

.panel-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}

.panel-header h2 {
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.5px;
}

.panel-desc {
  font-size: 11px;
  color: var(--text-secondary);
}

/* ── Table Refresh Bar ── */
.table-refresh-bar {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 12px;
  padding: 6px 18px;
  background: var(--bg-panel);
  border-bottom: 1px solid var(--border);
}

.refresh-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 4px 12px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
}

.refresh-btn:hover {
  border-color: var(--accent-blue);
  color: var(--accent-blue);
  background: rgba(68, 138, 255, 0.08);
}

.refresh-btn:active .refresh-icon {
  animation: spin 0.6s ease;
}

.refresh-btn.refreshing .refresh-icon {
  animation: spin 0.8s linear infinite;
}

@keyframes spin {
  from { transform: rotate(0deg); }
  to { transform: rotate(360deg); }
}

.refresh-icon {
  flex-shrink: 0;
}

.refresh-time {
  font-size: 11px;
  color: var(--text-secondary);
  white-space: nowrap;
}

/* ── Timeframe Toggle ── */
.tf-toggle {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}

.tf-btn {
  background: var(--bg-primary);
  border: none;
  color: var(--text-secondary);
  padding: 3px 12px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  letter-spacing: 0.3px;
}

.tf-btn:not(:last-child) {
  border-right: 1px solid var(--border);
}

.tf-btn:hover {
  color: var(--text-primary);
  background: var(--bg-secondary);
}

.tf-btn.active {
  background: var(--accent-blue);
  color: var(--bg-primary);
}

/* ── Table ── */
.table-wrap {
  overflow-x: hidden;
}

table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  table-layout: fixed;
}

thead th {
  text-align: left;
  padding: 7px 6px;
  font-size: 10px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

tbody td {
  padding: 6px 6px;
  border-bottom: 1px solid rgba(42, 48, 66, 0.4);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

tbody tr {
  transition: background 0.3s ease;
}

tbody tr:hover {
  background: rgba(68, 138, 255, 0.08);
}

.empty-msg {
  text-align: center;
  padding: 40px 12px !important;
  color: var(--text-secondary);
  font-style: italic;
}

/* ── Value Colors ── */
.val-positive { color: var(--accent-green); font-weight: 600; }
.val-negative { color: var(--accent-red); font-weight: 600; }
.val-neutral  { color: var(--text-secondary); }

.dir-oversold {
  color: var(--accent-green);
  font-weight: 700;
  font-size: 11px;
  padding: 2px 6px;
  background: rgba(0, 230, 118, 0.12);
  border-radius: 3px;
}

.dir-overbought {
  color: var(--accent-red);
  font-weight: 700;
  font-size: 11px;
  padding: 2px 6px;
  background: rgba(255, 23, 68, 0.12);
  border-radius: 3px;
}

.dir-long {
  color: var(--accent-green);
  font-weight: 700;
  font-size: 11px;
  padding: 2px 8px;
  background: rgba(0, 230, 118, 0.12);
  border-radius: 3px;
  letter-spacing: 0.5px;
}

.dir-short {
  color: var(--accent-red);
  font-weight: 700;
  font-size: 11px;
  padding: 2px 8px;
  background: rgba(255, 23, 68, 0.12);
  border-radius: 3px;
  letter-spacing: 0.5px;
}

/* ── Indicator Tags ── */
.ind-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 2px;
}

.ind-tag {
  display: inline-block;
  padding: 1px 4px;
  font-size: 9px;
  font-weight: 700;
  border-radius: 2px;
  letter-spacing: 0.2px;
  white-space: nowrap;
  line-height: 1.4;
}

.ind-tag sup {
  font-size: 7px;
  margin-left: 1px;
  opacity: 0.8;
}

.ind-long {
  background: rgba(0, 230, 118, 0.15);
  color: var(--accent-green);
  border: 1px solid rgba(0, 230, 118, 0.25);
}

.ind-short {
  background: rgba(255, 23, 68, 0.15);
  color: var(--accent-red);
  border: 1px solid rgba(255, 23, 68, 0.25);
}

.ind-neutral {
  background: rgba(136, 146, 166, 0.12);
  color: var(--text-secondary);
  border: 1px solid rgba(136, 146, 166, 0.2);
}

.ind-vol {
  border-style: dashed !important;
  font-style: italic;
}

.ind-long.ind-vol {
  background: rgba(0, 230, 118, 0.22);
  border-color: rgba(0, 230, 118, 0.4);
}

.ind-short.ind-vol {
  background: rgba(255, 23, 68, 0.22);
  border-color: rgba(255, 23, 68, 0.4);
}

.panel-header-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.vol-spike {
  color: var(--accent-yellow);
  font-weight: 700;
}

.symbol-name {
  font-weight: 700;
  color: var(--accent-blue);
  cursor: pointer;
}

.symbol-name:hover {
  text-decoration: underline;
}


.rank-cell {
  color: var(--text-secondary);
  font-weight: 600;
}

.pair-tag {
  display: inline-block;
  padding: 2px 6px;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  background: rgba(68, 138, 255, 0.12);
  color: var(--accent-blue);
  letter-spacing: 0.5px;
}

/* ── Row Flash Animation ── */
@keyframes rowFlash {
  0%   { background: rgba(68, 138, 255, 0.25); }
  100% { background: transparent; }
}

.row-flash {
  animation: rowFlash 1s ease-out;
}

@keyframes pulse {
  0%, 100% { opacity: 1; }
  50% { opacity: 0.3; }
}

/* ── Score Bar ── */
.score-bar {
  display: inline-block;
  min-width: 36px;
  text-align: center;
  padding: 2px 5px;
  border-radius: 3px;
  font-weight: 700;
  font-size: 11px;
}

.score-high {
  background: rgba(0, 230, 118, 0.2);
  color: var(--accent-green);
}

.score-mid {
  background: rgba(255, 214, 0, 0.2);
  color: var(--accent-yellow);
}

.score-low {
  background: rgba(136, 146, 166, 0.15);
  color: var(--text-secondary);
}

/* ── Signal Accuracy Banner ── */
.accuracy-banner {
  display: flex;
  align-items: center;
  gap: 24px;
  padding: 10px 16px;
  background: linear-gradient(135deg, rgba(0, 230, 118, 0.06), rgba(68, 138, 255, 0.06));
  border-bottom: 1px solid var(--border);
  font-size: 12px;
}

.accuracy-headline {
  display: flex;
  align-items: baseline;
  gap: 6px;
  flex-shrink: 0;
}

.accuracy-pct {
  font-size: 22px;
  font-weight: 800;
  color: var(--accent-green);
  letter-spacing: -0.5px;
}

.accuracy-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.accuracy-samples {
  font-size: 10px;
  color: var(--text-secondary);
  margin-left: 4px;
}

.accuracy-collecting {
  font-size: 11px;
  color: var(--text-secondary);
  font-style: italic;
}

.accuracy-ranges {
  display: flex;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.accuracy-range-item {
  display: flex;
  align-items: center;
  gap: 6px;
  flex: 1;
  min-width: 0;
}

.accuracy-range-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.3px;
  flex-shrink: 0;
  width: 30px;
}

.accuracy-bar {
  flex: 1;
  height: 6px;
  background: rgba(136, 146, 166, 0.15);
  border-radius: 3px;
  overflow: hidden;
  min-width: 40px;
}

.accuracy-bar-fill {
  height: 100%;
  border-radius: 3px;
  transition: width 0.6s ease;
}

.accuracy-bar-fill.bar-high {
  background: var(--accent-green);
}

.accuracy-bar-fill.bar-mid {
  background: var(--accent-yellow);
}

.accuracy-bar-fill.bar-low {
  background: var(--text-secondary);
}

.accuracy-range-pct {
  font-size: 11px;
  font-weight: 700;
  flex-shrink: 0;
  width: 36px;
  text-align: right;
}

.accuracy-range-pct.pct-high { color: var(--accent-green); }
.accuracy-range-pct.pct-mid { color: var(--accent-yellow); }
.accuracy-range-pct.pct-low { color: var(--text-secondary); }

@media (max-width: 768px) {
  .accuracy-banner {
    flex-direction: column;
    gap: 8px;
    padding: 8px 12px;
  }
  .accuracy-ranges {
    width: 100%;
  }
}

/* ── Fear & Greed Index Widget ── */
.fng-widget {
  grid-column: 1 / -1;
  display: flex;
  gap: 0;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 12px;
  overflow: hidden;
}
.fng-left {
  width: 240px;
  flex-shrink: 0;
  padding: 16px;
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.fng-header {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}
.fng-gauge { position: relative; text-align: center; }
.fng-svg { width: 140px; height: 77px; }
.fng-value {
  font-size: 32px;
  font-weight: 800;
  color: var(--text-primary);
  margin-top: -6px;
  line-height: 1;
}
.fng-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
}
.fng-label[data-level="extreme-fear"] { color: #ff1744; }
.fng-label[data-level="fear"] { color: #ff9100; }
.fng-label[data-level="neutral"] { color: #ffd600; }
.fng-label[data-level="greed"] { color: #a0d911; }
.fng-label[data-level="extreme-greed"] { color: #00e676; }
.fng-history {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.fng-history-title {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 2px;
}
.fng-history-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 12px;
  color: var(--text-secondary);
}
.fng-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  background: #666;
  min-width: 60px;
  text-align: center;
}
.fng-badge[data-level="extreme-fear"] { background: #ff1744; }
.fng-badge[data-level="fear"] { background: #ff9100; }
.fng-badge[data-level="neutral"] { background: #c8a600; }
.fng-badge[data-level="greed"] { background: #7cb305; }
.fng-badge[data-level="extreme-greed"] { background: #00c853; }
.fng-updated {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: auto;
}
.fng-right {
  flex: 1;
  min-width: 0;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
}
.fng-chart-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}
.fng-chart-legend {
  display: flex;
  gap: 14px;
  align-items: center;
}
.fng-legend-item {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
}
.fng-legend-dot {
  width: 10px;
  height: 3px;
  border-radius: 2px;
  display: inline-block;
}
.fng-chart-range {
  display: flex;
  gap: 4px;
}
.fng-range-btn {
  padding: 3px 10px;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: transparent;
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.15s;
}
.fng-range-btn:hover { color: var(--text-primary); border-color: var(--text-secondary); }
.fng-range-btn.active {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
}
#fngChart {
  width: 100%;
  flex: 1;
  min-height: 200px;
}
@media (max-width: 768px) {
  .fng-widget { flex-direction: column; }
  .fng-left {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--border);
    flex-direction: row;
    flex-wrap: wrap;
    gap: 10px;
    padding: 12px;
  }
  .fng-header { width: 100%; }
  .fng-gauge { width: 140px; }
  .fng-history { flex: 1; min-width: 120px; }
  .fng-updated { width: 100%; }
  .fng-right { padding: 10px 12px; }
  #fngChart { min-height: 180px; }
}

/* ── Full-Width Panel ── */
.panel-full {
  grid-column: 1 / -1;
}

/* ── Widget Settings ── */
.widget-settings-wrap {
  position: relative;
}

.widget-settings-btn {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all 0.2s;
}

.widget-settings-btn:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
}

.widget-dropdown {
  display: none;
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 0;
  min-width: 200px;
  z-index: 50;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
}

.widget-dropdown.open {
  display: block;
}

.widget-dropdown label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
  cursor: pointer;
  transition: background 0.15s;
}

.widget-dropdown label:hover {
  background: rgba(68, 138, 255, 0.08);
}

.widget-dropdown input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 2px solid var(--border);
  border-radius: 3px;
  background: var(--bg-primary);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}

.widget-dropdown input[type="checkbox"]:checked {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
}

.widget-dropdown input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

/* ── Indicator Settings Dropdown ── */
.ind-settings-wrap {
  position: relative;
  display: flex;
  align-items: center;
  gap: 0;
}

.ind-settings-btn {
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.15), rgba(124, 77, 255, 0.15));
  border: 1px solid rgba(68, 138, 255, 0.4);
  color: var(--accent-blue);
  padding: 4px 10px;
  border-radius: 5px;
  font-size: 10px;
  font-weight: 800;
  cursor: pointer;
  letter-spacing: 0.8px;
  transition: all 0.25s;
  text-shadow: 0 0 8px rgba(68, 138, 255, 0.3);
  position: relative;
  overflow: hidden;
}

.ind-settings-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.05), rgba(124, 77, 255, 0.1));
  opacity: 0;
  transition: opacity 0.25s;
}

.ind-settings-btn:hover {
  border-color: var(--accent-blue);
  color: #fff;
  box-shadow: 0 0 12px rgba(68, 138, 255, 0.3), inset 0 0 8px rgba(68, 138, 255, 0.1);
  transform: translateY(-1px);
}

.ind-settings-btn:hover::before {
  opacity: 1;
}

.ind-settings-btn.has-custom {
  background: linear-gradient(135deg, rgba(255, 145, 0, 0.2), rgba(255, 214, 0, 0.1));
  border-color: var(--accent-orange);
  color: var(--accent-orange);
  text-shadow: 0 0 8px rgba(255, 145, 0, 0.3);
  animation: indPulseCustom 2s ease-in-out infinite;
}

.ind-settings-btn.has-custom:hover {
  box-shadow: 0 0 12px rgba(255, 145, 0, 0.35);
}

@keyframes indPulseCustom {
  0%, 100% { box-shadow: 0 0 4px rgba(255, 145, 0, 0.15); }
  50% { box-shadow: 0 0 10px rgba(255, 145, 0, 0.3); }
}

.ind-count-badge {
  display: inline-block;
  background: var(--accent-blue);
  color: #fff;
  font-size: 8px;
  font-weight: 800;
  min-width: 14px;
  height: 14px;
  line-height: 14px;
  text-align: center;
  border-radius: 7px;
  margin-left: 4px;
  vertical-align: middle;
}

.has-custom .ind-count-badge {
  background: var(--accent-orange);
}

/* ── Indicator Customize CTA Badge (attached to INDICATORS btn) ── */
.ind-customize-cta {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  position: relative;
  padding: 4px 6px 4px 12px;
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.12), rgba(124, 77, 255, 0.12));
  border: 1px solid rgba(68, 138, 255, 0.35);
  border-right: none;
  border-radius: 20px 0 0 20px;
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-blue);
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.25s ease;
  animation: ctaGlow 2.5s ease-in-out infinite;
  overflow: hidden;
}

.ind-customize-cta:hover {
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.25), rgba(124, 77, 255, 0.25));
}

.ind-customize-cta:hover + .ind-settings-btn {
  border-color: var(--accent-blue);
  color: #fff;
  box-shadow: 0 0 12px rgba(68, 138, 255, 0.3), inset 0 0 8px rgba(68, 138, 255, 0.1);
}

.ind-customize-cta .cta-arrow {
  display: inline-block;
  font-size: 11px;
  animation: ctaArrowBounce 1s ease-in-out infinite;
}

.ind-customize-cta .cta-pulse {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100%;
  height: 100%;
  transform: translate(-50%, -50%);
  border-radius: 20px;
  background: rgba(68, 138, 255, 0.08);
  animation: ctaPulseRing 3s ease-out infinite;
  pointer-events: none;
}

/* Connected: INDICATORS button left side rounds off */
.ind-settings-wrap > .ind-customize-cta + .ind-settings-btn {
  border-radius: 0 5px 5px 0;
  border-left: none;
}

@keyframes ctaGlow {
  0%, 100% { box-shadow: 0 0 4px rgba(68, 138, 255, 0.1); }
  50% { box-shadow: 0 0 10px rgba(68, 138, 255, 0.22), 0 0 20px rgba(124, 77, 255, 0.08); }
}

@keyframes ctaArrowBounce {
  0%, 100% { transform: translateX(0); }
  50% { transform: translateX(4px); }
}

@keyframes ctaPulseRing {
  0% { transform: translate(-50%, -50%) scale(1); opacity: 0.4; }
  70% { transform: translate(-50%, -50%) scale(1.1); opacity: 0; }
  100% { transform: translate(-50%, -50%) scale(1.1); opacity: 0; }
}

[data-theme="light"] .ind-customize-cta {
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.08), rgba(124, 77, 255, 0.08));
  color: #2962ff;
}

[data-theme="light"] .ind-customize-cta:hover {
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.18), rgba(124, 77, 255, 0.18));
}

@media (max-width: 768px) {
  .ind-customize-cta {
    font-size: 10px;
    padding: 3px 5px 3px 10px;
  }
}

@media (max-width: 480px) {
  .ind-customize-cta {
    display: none;
  }
  .ind-settings-wrap > .ind-settings-btn {
    border-radius: 5px;
    border-left: 1px solid rgba(68, 138, 255, 0.4);
  }
}

.ind-dropdown {
  display: none;
  position: fixed;
  background: var(--bg-secondary);
  border: 1px solid rgba(68, 138, 255, 0.25);
  border-radius: 10px;
  width: 300px;
  z-index: 9999;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6), 0 0 20px rgba(68, 138, 255, 0.08);
  overflow: hidden;
  animation: indDropIn 0.15s ease-out;
}

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

.ind-dropdown.open {
  display: block;
}

.ind-dropdown-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 14px;
  background: linear-gradient(135deg, rgba(68, 138, 255, 0.08), rgba(124, 77, 255, 0.06));
  border-bottom: 1px solid var(--border);
  font-size: 11px;
  font-weight: 700;
  color: var(--accent-blue);
  text-transform: uppercase;
  letter-spacing: 0.8px;
}

.ind-header-actions {
  display: flex;
  gap: 4px;
}

.ind-select-btn {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 3px 10px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  letter-spacing: 0.3px;
}

.ind-select-btn:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
  background: rgba(68, 138, 255, 0.1);
}

.ind-dropdown-list {
  max-height: 380px;
  overflow-y: auto;
  padding: 4px 0;
}

.ind-dropdown-list::-webkit-scrollbar {
  width: 4px;
}

.ind-dropdown-list::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 2px;
}

.ind-dropdown label {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 14px;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-primary);
  cursor: pointer;
  transition: background 0.15s;
  border-left: 3px solid transparent;
}

.ind-dropdown label:hover {
  background: rgba(68, 138, 255, 0.06);
}

.ind-dropdown label.ind-enabled {
  border-left-color: var(--accent-blue);
  background: rgba(68, 138, 255, 0.04);
}

.ind-dropdown input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 2px solid var(--border);
  border-radius: 4px;
  background: var(--bg-primary);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
  transition: all 0.15s;
}

.ind-dropdown input[type="checkbox"]:checked {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
  box-shadow: 0 0 6px rgba(68, 138, 255, 0.3);
}

.ind-dropdown input[type="checkbox"]:checked::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.ind-item-info {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
}

.ind-item-name {
  font-weight: 700;
  font-size: 11px;
  letter-spacing: 0.2px;
}

.ind-item-desc {
  font-size: 9px;
  color: var(--text-secondary);
  font-weight: 400;
}

.ind-item-weight-wrap {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

/* ── Range Slider ── */
.ind-weight-range {
  --pct: 50%;
  -webkit-appearance: none;
  appearance: none;
  width: 72px;
  height: 6px;
  border-radius: 3px;
  outline: none;
  cursor: pointer;
  background: linear-gradient(to right, var(--accent-blue) var(--pct), rgba(136, 146, 166, 0.2) var(--pct));
  transition: box-shadow 0.2s;
}

.ind-weight-range.wt-high {
  background: linear-gradient(to right, var(--accent-green) var(--pct), rgba(136, 146, 166, 0.2) var(--pct));
}
.ind-weight-range.wt-mid {
  background: linear-gradient(to right, var(--accent-blue) var(--pct), rgba(136, 146, 166, 0.2) var(--pct));
}
.ind-weight-range.wt-low {
  background: linear-gradient(to right, var(--text-secondary) var(--pct), rgba(136, 146, 166, 0.2) var(--pct));
}
.ind-weight-range.wt-modified {
  background: linear-gradient(to right, var(--accent-orange) var(--pct), rgba(136, 146, 166, 0.2) var(--pct));
}

/* Thumb — Webkit */
.ind-weight-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--accent-blue);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
  cursor: grab;
  transition: transform 0.15s, box-shadow 0.15s;
}
.ind-weight-range::-webkit-slider-thumb:active {
  cursor: grabbing;
  transform: scale(1.2);
  box-shadow: 0 0 8px rgba(68, 138, 255, 0.5);
}
.ind-weight-range.wt-high::-webkit-slider-thumb { border-color: var(--accent-green); }
.ind-weight-range.wt-low::-webkit-slider-thumb  { border-color: var(--text-secondary); }
.ind-weight-range.wt-modified::-webkit-slider-thumb { border-color: var(--accent-orange); }

/* Thumb — Firefox */
.ind-weight-range::-moz-range-thumb {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  border: 2px solid var(--accent-blue);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3);
  cursor: grab;
  transition: transform 0.15s, box-shadow 0.15s;
}
.ind-weight-range::-moz-range-thumb:active {
  cursor: grabbing;
  transform: scale(1.2);
}
.ind-weight-range.wt-high::-moz-range-thumb { border-color: var(--accent-green); }
.ind-weight-range.wt-low::-moz-range-thumb  { border-color: var(--text-secondary); }
.ind-weight-range.wt-modified::-moz-range-thumb { border-color: var(--accent-orange); }

/* Firefox track */
.ind-weight-range::-moz-range-track {
  height: 6px;
  border-radius: 3px;
  background: transparent;
}

/* Value label */
.ind-weight-val {
  min-width: 22px;
  font-size: 11px;
  font-weight: 800;
  text-align: center;
  color: var(--text-primary);
  line-height: 1;
}
.ind-weight-val.wt-high { color: var(--accent-green); }
.ind-weight-val.wt-mid  { color: var(--accent-blue); }
.ind-weight-val.wt-low  { color: var(--text-secondary); }
.ind-weight-val.wt-modified { color: var(--accent-orange); }

.ind-reset-btn {
  color: var(--accent-orange) !important;
  border-color: rgba(255, 145, 0, 0.3) !important;
}

.ind-reset-btn:hover {
  border-color: var(--accent-orange) !important;
  background: rgba(255, 145, 0, 0.1) !important;
  color: var(--accent-orange) !important;
}

.ind-dropdown-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 14px;
  border-top: 1px solid var(--border);
  background: rgba(10, 14, 23, 0.4);
}

.ind-footer-score {
  font-size: 11px;
  font-weight: 800;
  color: var(--accent-blue);
  letter-spacing: 0.5px;
}

.ind-footer-count {
  font-size: 10px;
  color: var(--text-secondary);
  font-weight: 600;
}

/* ── Sound Toggle Button ── */
.sound-toggle {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all 0.2s;
}

.sound-toggle:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
}

.sound-toggle.active {
  background: rgba(68, 138, 255, 0.15);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
}

/* ── Chart Modal ── */
.modal {
    display: none; 
    position: fixed; 
    z-index: 100;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto; 
    background-color: rgba(10, 14, 23, 0.85);
    -webkit-backdrop-filter: blur(5px);
    backdrop-filter: blur(5px);
}

.modal-content {
    background-color: var(--bg-secondary);
    margin: 4% auto; 
    border: 1px solid var(--border);
    width: 90%;
    max-width: 1400px;
    height: 85%;
    border-radius: 8px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 10px 30px rgba(0,0,0,0.5);
}

.modal-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 12px 20px;
    border-bottom: 1px solid var(--border);
    flex-shrink: 0;
}

.modal-header h2 {
  color: var(--accent-blue);
  font-size: 18px;
}

.close {
    color: var(--text-secondary);
    font-size: 32px;
    font-weight: bold;
    transition: color 0.2s;
}

.close:hover,
.close:focus {
    color: var(--text-primary);
    text-decoration: none;
    cursor: pointer;
}

.modal-body{
    flex-grow: 1;
    padding: 10px;
    min-height: 0;
}

#tv-chart-container {
    width: 100%;
    height: 100%;
}


.loading-spinner {
    border: 4px solid rgba(255, 255, 255, 0.1);
    border-left-color: var(--accent-blue);
    border-radius: 50%;
    width: 40px;
    height: 40px;
    animation: spin 1s linear infinite;
    margin: auto;
}

.error-msg {
    margin: auto;
    color: var(--accent-red);
    padding: 20px;
    text-align: center;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

/* ── Trade Link Buttons ── */
.trade-links {
  display: flex;
  gap: 3px;
  flex-wrap: nowrap;
}

.trade-btn {
  display: inline-block;
  padding: 2px 5px;
  font-size: 9px;
  font-weight: 700;
  border-radius: 3px;
  text-decoration: none;
  color: #fff;
  letter-spacing: 0.3px;
  transition: opacity 0.15s;
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
}

.trade-btn:hover {
  opacity: 0.75;
}

.trade-bn  { background: #f0b90b; color: #000; }
.trade-bb  { background: #f7a600; color: #000; }
.trade-okx { background: var(--accent-purple); }
.trade-htx { background: #2d6ff7; }
.trade-bg  { background: #00b897; }

/* ── Column Width Tuning ── */
#arbTable th:nth-child(1), #arbTable td:nth-child(1) { width: 4%; }
#arbTable th:nth-child(2), #arbTable td:nth-child(2) { width: 8%; }
#arbTable th:nth-child(3), #arbTable td:nth-child(3) { width: 8%; }
#arbTable th:nth-child(4), #arbTable td:nth-child(4) { width: 11%; }
#arbTable th:nth-child(5), #arbTable td:nth-child(5) { width: 11%; }
#arbTable th:nth-child(6), #arbTable td:nth-child(6) { width: 8%; }
#arbTable th:nth-child(7), #arbTable td:nth-child(7) { width: 10%; }
#arbTable th:nth-child(8), #arbTable td:nth-child(8) { width: 10%; }
#arbTable th:nth-child(9), #arbTable td:nth-child(9) { width: 10%; }
#arbTable th:nth-child(10), #arbTable td:nth-child(10) { width: 20%; }

#sigTable th:nth-child(1), #sigTable td:nth-child(1) { width: 3%; }
#sigTable th:nth-child(2), #sigTable td:nth-child(2) { width: 7%; }
#sigTable th:nth-child(3), #sigTable td:nth-child(3) { width: 9%; }
#sigTable th:nth-child(4), #sigTable td:nth-child(4) { width: 7%; }
#sigTable th:nth-child(5), #sigTable td:nth-child(5) { width: 8%; }
#sigTable th:nth-child(6), #sigTable td:nth-child(6) { width: 40%; }
#sigTable th:nth-child(7), #sigTable td:nth-child(7) { width: 6%; }
#sigTable th:nth-child(8), #sigTable td:nth-child(8) { width: 20%; }

/* ── Card Grid Layout ── */
.card-grid {
  display: none;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 10px;
  padding: 12px;
}

.card-grid:not([style*="display: none"]):not([style*="display:none"]) {
  display: grid;
}

.wcard {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s;
}

.wcard:hover {
  border-color: rgba(68, 138, 255, 0.3);
}

.wcard-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.wcard-gap {
  margin-left: auto;
  font-weight: 800;
  font-size: 13px;
}

.wcard-body {
  padding: 8px 12px;
}

.wcard-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 0;
  font-size: 12px;
}

.wcard-label {
  color: var(--text-secondary);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.wcard-indicators {
  padding: 6px 12px;
  border-top: 1px solid rgba(42, 48, 66, 0.4);
}

.wcard-foot {
  padding: 8px 12px;
  border-top: 1px solid var(--border);
}

.wcard-foot .trade-links {
  justify-content: flex-start;
}

/* ── Widget Dropdown (Reorder + Layout) ── */
.wd-list {
  padding: 6px 0;
}

.wd-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  transition: background 0.15s;
}

.wd-item:hover {
  background: rgba(68, 138, 255, 0.06);
}

.wd-check {
  appearance: none;
  -webkit-appearance: none;
  width: 16px;
  height: 16px;
  border: 2px solid var(--border);
  border-radius: 3px;
  background: var(--bg-primary);
  cursor: pointer;
  position: relative;
  flex-shrink: 0;
}

.wd-check:checked {
  background: var(--accent-blue);
  border-color: var(--accent-blue);
}

.wd-check:checked::after {
  content: '';
  position: absolute;
  left: 4px;
  top: 1px;
  width: 4px;
  height: 8px;
  border: solid #fff;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}

.wd-label {
  flex: 1;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-primary);
}

.wd-actions {
  display: flex;
  align-items: center;
  gap: 3px;
}

.wd-arrow {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  width: 22px;
  height: 22px;
  border-radius: 3px;
  font-size: 8px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  padding: 0;
  line-height: 1;
}

.wd-arrow:hover:not(:disabled) {
  border-color: var(--accent-blue);
  color: var(--text-primary);
}

.wd-arrow:disabled {
  opacity: 0.25;
  cursor: default;
}

.wd-layout-btn {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 2px 8px;
  border-radius: 3px;
  font-size: 9px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  letter-spacing: 0.3px;
}

.wd-layout-btn:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
}

.wd-layout-btn.active {
  background: rgba(68, 138, 255, 0.15);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
}

/* ── Ad Slots ── */
.ad-slot {
  text-align: center;
  padding: 8px 24px;
}

.ad-slot.ad-native {
  padding: 0;
}


@media (max-width: 1400px) {
  .ad-side {
    display: none;
  }

  .dashboard {
    padding: 20px 24px;
  }
}

/* ── Static Content Section (Guide) ── */
.static-content {
  max-width: 1200px;
  margin: 0 auto;
  padding: 40px 24px;
}

.static-content h2 {
  font-size: 22px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 20px;
  padding: 10px 16px;
  background: linear-gradient(135deg, var(--bg-panel), var(--bg-secondary));
  border-left: 4px solid var(--accent-blue);
  border-radius: 0 8px 8px 0;
  display: block;
  box-shadow: 0 2px 8px var(--shadow-color);
}

.static-content h3 {
  font-size: 16px;
  font-weight: 700;
  color: var(--accent-green);
  margin: 20px 0 8px;
  padding-left: 10px;
  border-left: 3px solid var(--accent-green);
}

.static-content p {
  font-size: 14px;
  line-height: 1.8;
  color: var(--text-secondary);
  margin-bottom: 14px;
}

.static-content ul, .static-content ol {
  padding-left: 20px;
  margin-bottom: 16px;
}

.static-content li {
  font-size: 14px;
  line-height: 1.7;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.static-content li strong {
  color: var(--text-primary);
}

.static-section {
  margin-bottom: 32px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 28px 24px;
  box-shadow: 0 2px 12px var(--shadow-color);
  transition: box-shadow 0.2s;
}

.static-section:hover {
  box-shadow: 0 4px 20px var(--shadow-color);
}

.static-section:last-child {
  margin-bottom: 0;
}

.feature-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin: 20px 0;
}

.feature-item {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 22px 20px;
  border-top: 3px solid var(--accent-blue);
  box-shadow: 0 2px 8px var(--shadow-color);
  transition: transform 0.2s, box-shadow 0.2s;
}

.feature-item:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px var(--shadow-color);
}

.feature-item h3 {
  margin-top: 0;
  border-left: none;
  padding-left: 0;
  color: var(--accent-blue);
  font-size: 16px;
}

.feature-item p {
  margin-bottom: 0;
}

.indicator-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin: 16px 0;
}

.indicator-card {
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-left: 3px solid var(--accent-blue);
  border-radius: 8px;
  padding: 16px 18px;
  box-shadow: 0 1px 6px var(--shadow-color);
  transition: transform 0.2s, box-shadow 0.2s;
}

.indicator-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px var(--shadow-color);
}

.indicator-card .ind-name {
  font-size: 14px;
  font-weight: 700;
  color: var(--accent-blue);
  margin-bottom: 4px;
}

.indicator-card .ind-weight {
  font-size: 11px;
  font-weight: 600;
  color: var(--accent-yellow);
  background: rgba(255, 214, 0, 0.1);
  display: inline-block;
  padding: 2px 8px;
  border-radius: 10px;
  margin-bottom: 8px;
}

.indicator-card p {
  font-size: 13px;
  margin-bottom: 0;
}

.faq-item {
  margin-bottom: 12px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 18px 22px;
  box-shadow: 0 1px 6px var(--shadow-color);
  transition: transform 0.2s, box-shadow 0.2s;
}

.faq-item:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 14px var(--shadow-color);
}

.faq-item h3 {
  font-size: 15px;
  color: var(--text-primary);
  margin: 0 0 8px;
  padding-left: 24px;
  position: relative;
  border-left: none;
}

.faq-item h3::before {
  content: "Q";
  position: absolute;
  left: 0;
  top: 0;
  font-size: 13px;
  font-weight: 800;
  color: var(--accent-blue);
  background: rgba(68, 138, 255, 0.12);
  width: 18px;
  height: 18px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.faq-item p {
  margin-bottom: 0;
  font-size: 13px;
  padding-left: 24px;
}

.steps-list {
  counter-reset: step;
  list-style: none;
  padding-left: 0;
}

.steps-list li {
  counter-increment: step;
  padding: 14px 18px 14px 52px;
  position: relative;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 10px;
  box-shadow: 0 1px 6px var(--shadow-color);
  transition: transform 0.2s, box-shadow 0.2s;
}

.steps-list li:hover {
  transform: translateX(4px);
  box-shadow: 0 3px 12px var(--shadow-color);
}

.steps-list li::before {
  content: counter(step);
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  background: linear-gradient(135deg, var(--accent-blue), var(--accent-purple));
  color: #fff;
  border-radius: 50%;
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 6px rgba(68, 138, 255, 0.3);
}

@media (max-width: 768px) {
  .feature-row {
    grid-template-columns: 1fr;
  }
  .indicator-grid {
    grid-template-columns: 1fr;
  }
  .static-content {
    padding: 24px 14px;
  }
  .static-content h2 {
    font-size: 18px;
  }
  .static-section {
    padding: 20px 16px;
    border-radius: 8px;
  }
}

/* ── Blog Card Grid ── */
.blog-card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 20px;
}

.blog-card {
  display: block;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s, box-shadow 0.2s, border-color 0.2s;
}

.blog-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 6px 20px var(--shadow-color);
  border-color: var(--accent-blue);
  text-decoration: none;
}

.blog-card-cat {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.blog-card-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 8px 0;
  line-height: 1.4;
}

.blog-card-excerpt {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  margin: 0;
}

@media (max-width: 900px) {
  .blog-card-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

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

/* ── Footer ── */
.footer {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 16px;
  text-align: center;
  padding: 16px;
  font-size: 12px;
  color: var(--text-secondary);
  border-top: 1px solid var(--border);
  margin-top: 20px;
}

.footer-link {
  color: var(--text-secondary);
  text-decoration: none;
  font-size: 12px;
  transition: color 0.2s;
}

.footer-link:hover {
  color: var(--accent-blue);
}

/* ── Cookie Consent Banner ── */
.cookie-banner {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 99998;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 14px 24px;
  background: var(--bg-secondary);
  border-top: 1px solid var(--border);
  box-shadow: 0 -4px 20px rgba(0, 0, 0, 0.3);
}

.cookie-banner p {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 0;
  line-height: 1.5;
}

.cookie-banner a {
  color: var(--accent-blue);
  text-decoration: none;
}

.cookie-banner a:hover {
  text-decoration: underline;
}

.cookie-accept {
  flex-shrink: 0;
  padding: 10px 24px;
  background: var(--accent-blue);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s;
  min-height: 40px;
}

.cookie-accept:hover {
  background: #5a9aff;
}

@media (max-width: 480px) {
  .cookie-banner {
    flex-direction: column;
    gap: 10px;
    padding: 12px 16px;
    text-align: center;
  }
}

/* ══════════════════════════════════════════════
   MARKETPLACE STYLES
   ══════════════════════════════════════════════ */

/* ── Marketplace View (full page) ── */
.mp-view {
  max-width: 1600px;
  margin: 0 auto;
  padding: 20px 24px;
}

.mp-page {
  width: 100%;
}

/* ── Filter Buttons ── */
.mp-filters {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 4px;
  overflow: hidden;
}

.mp-filter-btn {
  background: var(--bg-primary);
  border: none;
  color: var(--text-secondary);
  padding: 3px 12px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  letter-spacing: 0.3px;
}

.mp-filter-btn:not(:last-child) {
  border-right: 1px solid var(--border);
}

.mp-filter-btn:hover {
  color: var(--text-primary);
  background: var(--bg-secondary);
}

.mp-filter-btn.active {
  background: var(--accent-blue);
  color: var(--bg-primary);
}

/* ── Action Buttons ── */
.mp-action-btn {
  padding: 4px 12px;
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.5px;
  transition: all 0.2s;
  border: 1px solid var(--border);
  background: var(--bg-panel);
  color: var(--text-secondary);
}

.mp-action-btn:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
}

.mp-sell-btn {
  background: rgba(0, 230, 118, 0.12);
  border-color: rgba(0, 230, 118, 0.4);
  color: var(--accent-green);
}

.mp-sell-btn:hover {
  background: rgba(0, 230, 118, 0.25);
  border-color: var(--accent-green);
  color: var(--accent-green);
}

.mp-my-btn {
  background: rgba(68, 138, 255, 0.12);
  border-color: rgba(68, 138, 255, 0.4);
  color: var(--accent-blue);
}

.mp-my-btn:hover {
  background: rgba(68, 138, 255, 0.25);
  border-color: var(--accent-blue);
}

/* ── Table Column Widths ── */
#mpTable th:nth-child(1), #mpTable td:nth-child(1) { width: 4%; }
#mpTable th:nth-child(2), #mpTable td:nth-child(2) { width: 22%; }
#mpTable th:nth-child(3), #mpTable td:nth-child(3) { width: 14%; }
#mpTable th:nth-child(4), #mpTable td:nth-child(4) { width: 10%; }
#mpTable th:nth-child(5), #mpTable td:nth-child(5) { width: 10%; }
#mpTable th:nth-child(6), #mpTable td:nth-child(6) { width: 10%; }
#mpTable th:nth-child(7), #mpTable td:nth-child(7) { width: 12%; }
#mpTable th:nth-child(8), #mpTable td:nth-child(8) { width: 18%; }

/* ── Category Tag ── */
.mp-cat-tag {
  display: inline-block;
  padding: 2px 8px;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.mp-cat-strategy {
  background: rgba(68, 138, 255, 0.15);
  color: var(--accent-blue);
  border: 1px solid rgba(68, 138, 255, 0.3);
}

.mp-cat-indicator {
  background: rgba(124, 77, 255, 0.15);
  color: var(--accent-purple);
  border: 1px solid rgba(124, 77, 255, 0.3);
}

/* ── Price Tag ── */
.mp-price {
  font-weight: 800;
  color: var(--accent-green);
  font-size: 12px;
  white-space: nowrap;
}

.mp-price-free {
  color: var(--text-secondary);
}

.mp-price-wrap {
  display: flex;
  flex-direction: column;
  gap: 2px;
  line-height: 1.3;
}

.mp-price-wrap .mp-price-monthly {
  font-weight: 800;
  color: var(--accent-green);
  font-size: 12px;
  white-space: nowrap;
}

.mp-price-wrap .mp-price-lifetime {
  font-weight: 600;
  color: var(--accent-blue);
  font-size: 10px;
  white-space: nowrap;
  opacity: 0.85;
}

/* ── Entry Method & Direction Tags ── */
.mp-tag {
  display: inline-block;
  padding: 2px 6px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.mp-tag-dca {
  background: rgba(255, 167, 38, 0.15);
  color: #ffa726;
  border: 1px solid rgba(255, 167, 38, 0.3);
}

.mp-tag-coin {
  background: rgba(124, 77, 255, 0.15);
  color: var(--accent-purple);
  border: 1px solid rgba(124, 77, 255, 0.3);
}

.mp-coin-tf {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
}

.mp-tf-tag {
  display: inline-block;
  margin-left: 4px;
  padding: 1px 4px;
  border-radius: 2px;
  font-size: 9px;
  font-weight: 700;
  background: rgba(124, 77, 255, 0.2);
  color: var(--accent-purple);
  letter-spacing: 0.3px;
}

.mp-form-hint {
  display: inline;
  font-size: 10px;
  color: var(--text-secondary);
}

.mp-coin-selector {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

.mp-coin-tag {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  padding: 6px 14px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.15s;
  letter-spacing: 0.5px;
}

.mp-coin-tag:hover {
  border-color: var(--accent-blue);
  color: var(--text-primary);
}

.mp-coin-tag.selected {
  background: rgba(68, 138, 255, 0.2);
  border-color: var(--accent-blue);
  color: var(--accent-blue);
}

.mp-tag-single {
  background: rgba(68, 138, 255, 0.15);
  color: var(--accent-blue);
  border: 1px solid rgba(68, 138, 255, 0.3);
}

.mp-tag-long {
  background: rgba(0, 230, 118, 0.12);
  color: var(--accent-green);
  border: 1px solid rgba(0, 230, 118, 0.25);
}

.mp-tag-short {
  background: rgba(255, 82, 82, 0.12);
  color: var(--accent-red);
  border: 1px solid rgba(255, 82, 82, 0.25);
}

.mp-tag-both {
  background: rgba(124, 77, 255, 0.12);
  color: var(--accent-purple);
  border: 1px solid rgba(124, 77, 255, 0.25);
}

/* ── Seller Info ── */
.mp-seller {
  display: flex;
  align-items: center;
  gap: 6px;
}

.mp-seller-avatar {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--border);
}

.mp-seller-name {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-primary);
  max-width: 100px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Detail Button ── */
.mp-detail-btn {
  padding: 3px 10px;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  border: 1px solid var(--accent-blue);
  background: rgba(68, 138, 255, 0.12);
  color: var(--accent-blue);
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
}

.mp-detail-btn:hover {
  background: var(--accent-blue);
  color: #fff;
}

.mp-request-btn {
  padding: 3px 10px;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  border: 1px solid var(--accent-green);
  background: rgba(0, 230, 118, 0.12);
  color: var(--accent-green);
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
  margin-left: 4px;
}

.mp-request-btn:hover {
  background: var(--accent-green);
  color: #000;
}

/* ── Stat Values ── */
.mp-stat {
  font-weight: 700;
  font-size: 11px;
}

.mp-stat-good { color: var(--accent-green); }
.mp-stat-warn { color: var(--accent-yellow); }
.mp-stat-bad  { color: var(--accent-red); }
.mp-stat-na   { color: var(--text-secondary); }

/* ── Card Layout ── */
.mp-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  transition: border-color 0.2s;
}

.mp-card:hover {
  border-color: rgba(68, 138, 255, 0.3);
}

/* ── Table thumbnail & script cell ── */
.mp-script-cell {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mp-table-thumb {
  width: 36px;
  height: 36px;
  border-radius: 4px;
  object-fit: cover;
  border: 1px solid var(--border);
  flex-shrink: 0;
}

/* ── Card banner image ── */
.mp-card-banner {
  width: 100%;
  height: 120px;
  overflow: hidden;
  border-bottom: 1px solid var(--border);
  background: var(--bg-primary);
}

.mp-card-banner img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mp-card-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  flex-wrap: wrap;
}

.mp-card-title {
  font-weight: 700;
  font-size: 13px;
  color: var(--text-primary);
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.mp-card-body {
  padding: 8px 12px;
}

.mp-card-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 3px 0;
  font-size: 12px;
}

.mp-card-label {
  color: var(--text-secondary);
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.3px;
}

.mp-card-foot {
  padding: 8px 12px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 6px;
}

/* ── Modals ── */
.mp-modal-detail .modal-content,
.mp-modal-form .modal-content,
.mp-modal-request .modal-content {
  height: auto;
  max-height: 90vh;
}

.mp-modal-detail {
  max-width: 780px;
  width: 90vw;
  height: auto;
  max-height: 90vh;
}

.mp-modal-detail .mp-detail-body,
.mp-detail-body {
  padding: 20px 24px;
}

.mp-modal-form {
  max-width: 860px;
  width: 90vw;
  height: auto;
  max-height: 90vh;
}

.mp-modal-request {
  max-width: 480px;
  height: auto;
  max-height: 90vh;
}

.mp-detail-body {
  padding: 16px 20px;
  overflow-y: auto;
}

.mp-detail-section {
  margin-bottom: 20px;
}

.mp-detail-section h3 {
  font-size: 12px;
  font-weight: 700;
  color: var(--accent-blue);
  margin-bottom: 10px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border);
}

.mp-detail-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  white-space: pre-wrap;
}

.mp-detail-stats {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  gap: 8px;
}

.mp-detail-stat {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px 14px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.mp-detail-stat-label {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}

.mp-detail-stat-value {
  font-size: 18px;
  font-weight: 800;
}

.mp-detail-images {
  display: flex;
  gap: 10px;
  overflow-x: auto;
  padding: 6px 0;
  flex-wrap: wrap;
}

.mp-detail-images img {
  max-width: 100%;
  max-height: 360px;
  border-radius: 8px;
  border: 1px solid var(--border);
  object-fit: contain;
  cursor: zoom-in;
  transition: opacity 0.15s;
}

.mp-detail-images img:hover {
  opacity: 0.85;
}

.mp-detail-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 16px;
  flex-wrap: wrap;
}

.mp-detail-header .mp-seller {
  margin-left: auto;
}

/* ── Detail Modal Top Section ── */
.mp-detail-top {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.mp-detail-top-left {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.mp-detail-top-right {
  flex-shrink: 0;
}

.mp-detail-seller {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mp-detail-seller .mp-seller-name {
  font-size: 13px;
  font-weight: 600;
}

.mp-detail-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
}

.mp-detail-price {
  font-size: 18px;
  font-weight: 800;
}

.mp-detail-tag {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.3px;
  white-space: nowrap;
}

.mp-detail-tag-icon {
  font-size: 10px;
  opacity: 0.7;
}

.mp-detail-tag-cat {
  background: rgba(68, 138, 255, 0.15);
  color: var(--accent-blue);
  border: 1px solid rgba(68, 138, 255, 0.3);
  font-size: 12px;
  letter-spacing: 1px;
}

.mp-detail-tag-coin {
  background: rgba(124, 77, 255, 0.15);
  color: var(--accent-purple);
  border: 1px solid rgba(124, 77, 255, 0.3);
}

.mp-detail-tag-entry {
  background: rgba(255, 167, 38, 0.12);
  color: #ffa726;
  border: 1px solid rgba(255, 167, 38, 0.25);
}

.mp-detail-tag-dir {
  background: rgba(0, 230, 118, 0.12);
  color: var(--accent-green);
  border: 1px solid rgba(0, 230, 118, 0.25);
}

/* ── Detail Action Buttons ── */
.mp-detail-actions {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
  flex-wrap: wrap;
}

.mp-btn-tv {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 20px;
  background: linear-gradient(135deg, #2962ff 0%, #448aff 100%);
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 700;
  text-decoration: none;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.1s;
}

.mp-btn-tv:hover {
  opacity: 0.9;
  transform: translateY(-1px);
}

.mp-btn-action {
  padding: 10px 20px !important;
  font-size: 13px !important;
  border-radius: 6px !important;
}

/* ── Clickable Rows & Cards ── */
.mp-row-clickable {
  cursor: pointer;
  transition: background 0.12s;
}

.mp-row-clickable:hover {
  background: rgba(255, 255, 255, 0.03);
}

.mp-card-clickable {
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
}

.mp-card-clickable:hover {
  transform: translateY(-2px);
  box-shadow: 0 6px 20px rgba(0, 0, 0, 0.3);
}

.mp-action-cell {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* ── TradingView Link (table) ── */
.mp-tv-link {
  display: inline-block;
  padding: 4px 10px;
  background: rgba(41, 98, 255, 0.15);
  color: var(--accent-blue);
  border: 1px solid rgba(41, 98, 255, 0.3);
  border-radius: 4px;
  font-size: 10px;
  font-weight: 700;
  text-decoration: none;
  letter-spacing: 0.3px;
  transition: background 0.15s;
}

.mp-tv-link:hover {
  background: rgba(41, 98, 255, 0.3);
}

/* ── Lightbox ── */
.mp-lightbox {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  align-items: center;
  justify-content: center;
}

.mp-lightbox-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.85);
  cursor: pointer;
}

.mp-lightbox-img {
  position: relative;
  max-width: 90vw;
  max-height: 90vh;
  object-fit: contain;
  border-radius: 8px;
  z-index: 1;
}

.mp-lightbox-close {
  position: absolute;
  top: 16px;
  right: 24px;
  z-index: 2;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 36px;
  height: 36px;
  font-size: 20px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
}

.mp-lightbox-close:hover {
  background: rgba(255, 82, 82, 0.8);
}

/* ── Form Styles ── */
.mp-form {
  padding: 16px 20px;
}

.mp-form-group {
  margin-bottom: 12px;
}

.mp-form-group label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 4px;
  letter-spacing: 0.3px;
}

.mp-form-group input,
.mp-form-group select,
.mp-form-group textarea {
  width: 100%;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-primary);
  font-size: 13px;
  padding: 8px 10px;
  outline: none;
  transition: border-color 0.2s;
  font-family: inherit;
}

.mp-form-group input:focus,
.mp-form-group select:focus,
.mp-form-group textarea:focus {
  border-color: var(--accent-blue);
  box-shadow: 0 0 6px rgba(68, 138, 255, 0.2);
}

.mp-form-group select {
  cursor: pointer;
}

.mp-form-row {
  display: flex;
  gap: 12px;
}

.mp-form-row .mp-form-group {
  flex: 1;
}

/* ── Image Upload Zone ── */
.mp-upload-zone {
  border: 2px dashed var(--border);
  border-radius: 8px;
  padding: 20px;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  background: var(--bg-primary);
}

.mp-upload-zone:hover,
.mp-upload-zone.mp-drag-over {
  border-color: var(--accent-blue);
  background: rgba(68, 138, 255, 0.06);
}

.mp-upload-placeholder {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  color: var(--text-secondary);
}

.mp-upload-placeholder svg {
  opacity: 0.5;
}

.mp-upload-placeholder span {
  font-size: 12px;
}

.mp-upload-hint {
  font-size: 10px !important;
  opacity: 0.6;
}

.mp-upload-previews {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 8px;
}

.mp-upload-previews:empty {
  display: none;
}

.mp-upload-thumb {
  position: relative;
  width: 72px;
  height: 72px;
  border-radius: 6px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-primary);
}

.mp-upload-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.mp-upload-thumb .mp-thumb-remove {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: none;
  background: rgba(0,0,0,0.7);
  color: #fff;
  font-size: 12px;
  line-height: 18px;
  text-align: center;
  cursor: pointer;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}

.mp-upload-thumb .mp-thumb-remove:hover {
  background: var(--accent-red);
}

.mp-upload-thumb .mp-thumb-loading {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.5);
  color: #fff;
  font-size: 10px;
}

/* ── Period Picker ── */
.mp-period-picker {
  display: flex;
  align-items: center;
  gap: 8px;
}

.mp-period-picker input[type="month"] {
  flex: 1;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 4px;
  color: var(--text-primary);
  padding: 10px 12px;
  font-size: 14px;
  font-family: inherit;
  transition: border-color 0.2s;
  min-height: 40px;
}

.mp-period-picker input[type="month"]:focus {
  border-color: var(--accent-blue);
  box-shadow: 0 0 6px rgba(68, 138, 255, 0.2);
  outline: none;
}

.mp-period-picker input[type="month"]::-webkit-calendar-picker-indicator {
  filter: invert(1);
  cursor: pointer;
  width: 20px;
  height: 20px;
  opacity: 0.8;
}

.mp-period-picker input[type="month"]::-webkit-calendar-picker-indicator:hover {
  opacity: 1;
}

.mp-period-separator {
  color: var(--text-secondary);
  font-weight: 600;
  font-size: 14px;
  user-select: none;
}

.mp-form-fieldset {
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 12px;
  margin-bottom: 12px;
}

.mp-form-fieldset legend {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent-blue);
  padding: 0 6px;
  letter-spacing: 0.3px;
}

.mp-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
}

.mp-btn-cancel {
  padding: 8px 16px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border);
  background: var(--bg-panel);
  color: var(--text-secondary);
  transition: all 0.2s;
}

.mp-btn-cancel:hover {
  border-color: var(--accent-red);
  color: var(--accent-red);
}

.mp-btn-submit {
  padding: 8px 20px;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  background: var(--accent-blue);
  color: #fff;
  letter-spacing: 0.3px;
  transition: all 0.2s;
}

.mp-btn-submit:hover {
  background: #5a9aff;
}

.mp-btn-submit:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.mp-req-info {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: 12px;
  padding: 10px;
  background: var(--bg-primary);
  border-radius: 4px;
  border: 1px solid var(--border);
}

/* ── Seller Dashboard ── */
.mp-dashboard {
  border-top: 1px solid var(--border);
}

.mp-dash-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
}

.mp-dash-tab {
  flex: 1;
  background: none;
  border: none;
  padding: 10px 16px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
  border-bottom: 2px solid transparent;
}

.mp-dash-tab:hover {
  color: var(--text-primary);
  background: rgba(68, 138, 255, 0.04);
}

.mp-dash-tab.active {
  color: var(--accent-blue);
  border-bottom-color: var(--accent-blue);
}

.mp-dash-content {
  padding: 12px 16px;
  max-height: 400px;
  overflow-y: auto;
}

.mp-dash-content::-webkit-scrollbar {
  width: 4px;
}

.mp-dash-content::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 2px;
}

/* ── Dashboard Listing Item ── */
.mp-dash-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(42, 48, 66, 0.4);
}

.mp-dash-item:last-child {
  border-bottom: none;
}

.mp-dash-item-info {
  flex: 1;
  min-width: 0;
}

.mp-dash-item-name {
  font-weight: 700;
  font-size: 13px;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.mp-dash-item-meta {
  font-size: 10px;
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

.mp-dash-item-actions {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.mp-dash-edit-btn,
.mp-dash-del-btn {
  padding: 3px 8px;
  font-size: 9px;
  font-weight: 700;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
}

.mp-dash-edit-btn {
  border: 1px solid var(--accent-blue);
  background: rgba(68, 138, 255, 0.1);
  color: var(--accent-blue);
}

.mp-dash-edit-btn:hover {
  background: var(--accent-blue);
  color: #fff;
}

.mp-dash-del-btn {
  border: 1px solid var(--accent-red);
  background: rgba(255, 23, 68, 0.1);
  color: var(--accent-red);
}

.mp-dash-del-btn:hover {
  background: var(--accent-red);
  color: #fff;
}

/* ── Request Item ── */
.mp-req-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(42, 48, 66, 0.4);
}

.mp-req-item:last-child {
  border-bottom: none;
}

.mp-req-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  object-fit: cover;
  border: 1px solid var(--border);
  flex-shrink: 0;
}

.mp-req-info-block {
  flex: 1;
  min-width: 0;
}

.mp-req-buyer {
  font-weight: 700;
  font-size: 12px;
  color: var(--text-primary);
}

.mp-req-tv {
  font-size: 11px;
  color: var(--accent-blue);
}

.mp-req-msg {
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 2px;
  font-style: italic;
}

.mp-req-script {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: 2px;
}

.mp-req-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.mp-approve-btn,
.mp-reject-btn {
  padding: 4px 10px;
  font-size: 9px;
  font-weight: 700;
  border-radius: 3px;
  cursor: pointer;
  transition: all 0.2s;
  letter-spacing: 0.3px;
}

.mp-approve-btn {
  border: 1px solid var(--accent-green);
  background: rgba(0, 230, 118, 0.12);
  color: var(--accent-green);
}

.mp-approve-btn:hover {
  background: var(--accent-green);
  color: #000;
}

.mp-reject-btn {
  border: 1px solid var(--accent-red);
  background: rgba(255, 23, 68, 0.1);
  color: var(--accent-red);
}

.mp-reject-btn:hover {
  background: var(--accent-red);
  color: #fff;
}

/* ── Status Badge ── */
.mp-status-badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 9px;
  font-weight: 700;
  border-radius: 3px;
  letter-spacing: 0.3px;
  text-transform: uppercase;
}

.mp-status-pending {
  background: rgba(255, 214, 0, 0.15);
  color: var(--accent-yellow);
  border: 1px solid rgba(255, 214, 0, 0.3);
}

.mp-status-approved {
  background: rgba(0, 230, 118, 0.15);
  color: var(--accent-green);
  border: 1px solid rgba(0, 230, 118, 0.3);
}

.mp-status-rejected {
  background: rgba(255, 23, 68, 0.15);
  color: var(--accent-red);
  border: 1px solid rgba(255, 23, 68, 0.3);
}

.mp-status-active {
  background: rgba(0, 230, 118, 0.15);
  color: var(--accent-green);
  border: 1px solid rgba(0, 230, 118, 0.3);
}

.mp-status-paused {
  background: rgba(136, 146, 166, 0.15);
  color: var(--text-secondary);
  border: 1px solid rgba(136, 146, 166, 0.3);
}

.mp-empty {
  text-align: center;
  padding: 30px 12px;
  color: var(--text-secondary);
  font-style: italic;
  font-size: 13px;
}

/* ══════════════════════════════════════════════
   AI VERIFICATION BADGE & FORM STYLES
   ══════════════════════════════════════════════ */

/* ── Verified Badge (inline, next to title) ── */
.mp-verified-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--accent-green);
  background: rgba(0, 230, 118, 0.12);
  border: 1px solid rgba(0, 230, 118, 0.35);
  border-radius: 4px;
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  animation: mpBadgeGlow 2.5s ease-in-out infinite;
}

.mp-verified-badge svg {
  flex-shrink: 0;
}

@keyframes mpBadgeGlow {
  0%, 100% { box-shadow: 0 0 4px rgba(0, 230, 118, 0.15); }
  50% { box-shadow: 0 0 12px rgba(0, 230, 118, 0.35); }
}

/* Shimmer effect */
.mp-verified-badge::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(0, 230, 118, 0.15), transparent);
  animation: mpBadgeShimmer 3s ease-in-out infinite;
}

@keyframes mpBadgeShimmer {
  0% { left: -100%; }
  50% { left: 100%; }
  100% { left: 100%; }
}

/* ── Large Badge (detail modal) ── */
.mp-verified-badge-lg {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  color: var(--accent-green);
  background: rgba(0, 230, 118, 0.12);
  border: 1px solid rgba(0, 230, 118, 0.35);
  border-radius: 6px;
  white-space: nowrap;
  position: relative;
  overflow: hidden;
  animation: mpBadgeGlow 2.5s ease-in-out infinite;
}

.mp-verified-badge-lg svg {
  flex-shrink: 0;
}

.mp-verified-badge-lg::after {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(0, 230, 118, 0.15), transparent);
  animation: mpBadgeShimmer 3s ease-in-out infinite;
}

/* ── Pine Script Textarea ── */
.mp-pine-textarea {
  font-family: 'Fira Code', 'Cascadia Code', 'JetBrains Mono', 'SF Mono', 'Consolas', monospace !important;
  font-size: 12px !important;
  line-height: 1.5 !important;
  background: var(--code-bg) !important;
  color: var(--code-text) !important;
  border: 1px solid rgba(0, 230, 118, 0.2) !important;
  border-radius: 6px !important;
  padding: 12px !important;
  resize: vertical;
  tab-size: 4;
  width: 100% !important;
  min-height: 200px;
}

.mp-pine-textarea:focus {
  border-color: rgba(0, 230, 118, 0.5) !important;
  box-shadow: 0 0 8px rgba(0, 230, 118, 0.15) !important;
}

.mp-pine-textarea::placeholder {
  color: #484f58;
}

/* ── Verify Notice ── */
.mp-verify-notice {
  font-size: 11px;
  color: var(--text-secondary);
  margin-bottom: 10px;
  line-height: 1.5;
}

.mp-verify-notice strong {
  color: var(--accent-green);
}

/* ── Verify Actions Row ── */
.mp-verify-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

/* ── Verify Button ── */
.mp-btn-verify {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.3px;
  color: var(--accent-green);
  background: transparent;
  border: 1px solid rgba(0, 230, 118, 0.4);
  border-radius: 5px;
  cursor: pointer;
  transition: all 0.25s;
  position: relative;
  overflow: hidden;
}

.mp-btn-verify:hover:not(:disabled) {
  background: rgba(0, 230, 118, 0.12);
  border-color: var(--accent-green);
  box-shadow: 0 0 10px rgba(0, 230, 118, 0.2);
}

.mp-btn-verify:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.mp-btn-verify.mp-verifying {
  pointer-events: none;
  color: var(--text-secondary);
  border-color: var(--border);
}

.mp-btn-verify.mp-verifying .mp-verify-icon {
  animation: spin 1s linear infinite;
}

/* ── Verify Status Text ── */
.mp-verify-status {
  font-size: 11px;
  color: var(--text-secondary);
  font-weight: 600;
}

.mp-verify-status.mp-status-ok {
  color: var(--accent-green);
}

.mp-verify-status.mp-status-err {
  color: var(--accent-red);
}

/* ── Verification Result Grid ── */
.mp-verify-result {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 10px;
}

.mp-vr-card {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 14px 16px;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}

.mp-vr-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 6px;
}

.mp-vr-value {
  font-size: 18px;
  font-weight: 800;
}

.mp-vr-pass {
  color: var(--accent-green);
}

.mp-vr-fail {
  color: var(--accent-red);
}

.mp-vr-detail {
  font-size: 10px;
  color: var(--text-secondary);
  margin-top: 6px;
  line-height: 1.4;
}

.mp-vr-score {
  font-size: 22px;
  font-weight: 800;
}

/* ── Summary & Issues (full-width below grid) ── */
.mp-vr-summary {
  grid-column: 1 / -1;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 10px 12px;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}

.mp-vr-summary strong {
  color: var(--text-primary);
}

.mp-vr-issues {
  grid-column: 1 / -1;
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.mp-vr-issue {
  font-size: 11px;
  padding: 4px 8px;
  border-radius: 3px;
  border-left: 3px solid var(--border);
}

.mp-vr-issue-critical {
  color: var(--accent-red);
  background: rgba(255, 23, 68, 0.08);
  border-left-color: var(--accent-red);
}

.mp-vr-issue-warning {
  color: var(--accent-yellow);
  background: rgba(255, 214, 0, 0.08);
  border-left-color: var(--accent-yellow);
}

.mp-vr-issue-minor {
  color: var(--text-secondary);
  background: rgba(136, 146, 166, 0.08);
  border-left-color: var(--text-secondary);
}

/* ── Detail Modal: Verification Section ── */
.mp-detail-verify {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
  margin-top: 10px;
}

@media (max-width: 600px) {
  .mp-verify-result {
    grid-template-columns: repeat(2, 1fr);
  }
  .mp-detail-verify {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* ══════════════════════════════════════════════
   LIGHT THEME OVERRIDES
   ══════════════════════════════════════════════ */
[data-theme="light"] .header {
  box-shadow: 0 1px 3px var(--shadow-color);
}

[data-theme="light"] .panel {
  box-shadow: 0 1px 4px var(--shadow-color);
}

[data-theme="light"] .modal-content {
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.2);
}

[data-theme="light"] .toast {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12), 0 1px 4px rgba(0, 0, 0, 0.08);
}

[data-theme="light"] .mp-lightbox-backdrop {
  background: rgba(0, 0, 0, 0.6);
}

[data-theme="light"] .logo {
  background: linear-gradient(135deg, #1e40af, #059669);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

[data-theme="light"] thead th {
  background: #e5e7eb;
  color: #374151;
}

[data-theme="light"] tbody tr:hover {
  background: rgba(37, 99, 235, 0.04);
}

[data-theme="light"] .mp-pine-textarea::placeholder {
  color: #9ca3af;
}

[data-theme="light"] .ad-slot {
  background: transparent;
}

[data-theme="light"] .ind-dropdown,
[data-theme="light"] .widget-dropdown {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

/* ══════════════════════════════════════════════
   TOAST NOTIFICATIONS
   ══════════════════════════════════════════════ */
.toast-container {
  position: fixed;
  top: 20px;
  right: 20px;
  z-index: 99999;
  display: flex;
  flex-direction: column;
  gap: 10px;
  pointer-events: none;
}

.toast {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-width: 300px;
  max-width: 440px;
  padding: 14px 16px;
  border-radius: 8px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5), 0 2px 8px rgba(0, 0, 0, 0.3);
  pointer-events: auto;
  transform: translateX(120%);
  opacity: 0;
  animation: toastSlideIn 0.35s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  backdrop-filter: blur(12px);
}

.toast.toast-hiding {
  animation: toastSlideOut 0.3s cubic-bezier(0.55, 0, 1, 0.45) forwards;
}

@keyframes toastSlideIn {
  from { transform: translateX(120%); opacity: 0; }
  to   { transform: translateX(0); opacity: 1; }
}

@keyframes toastSlideOut {
  from { transform: translateX(0); opacity: 1; }
  to   { transform: translateX(120%); opacity: 0; }
}

.toast-icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 800;
  margin-top: 1px;
}

.toast-body {
  flex: 1;
  min-width: 0;
}

.toast-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 3px;
}

.toast-message {
  font-size: 13px;
  color: var(--text-primary);
  line-height: 1.45;
  word-break: break-word;
}

.toast-close {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  font-size: 16px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 4px;
  transition: background 0.15s, color 0.15s;
  padding: 0;
  line-height: 1;
}

.toast-close:hover {
  background: rgba(255, 255, 255, 0.08);
  color: var(--text-primary);
}

.toast-progress {
  position: absolute;
  bottom: 0;
  left: 0;
  height: 3px;
  border-radius: 0 0 8px 8px;
  animation: toastProgress linear forwards;
}

@keyframes toastProgress {
  from { width: 100%; }
  to   { width: 0%; }
}

/* Toast Types */
.toast-error {
  border-left: 3px solid var(--accent-red);
}
.toast-error .toast-icon {
  background: rgba(255, 23, 68, 0.2);
  color: var(--accent-red);
}
.toast-error .toast-title {
  color: var(--accent-red);
}
.toast-error .toast-progress {
  background: var(--accent-red);
}

.toast-warning {
  border-left: 3px solid var(--accent-yellow);
}
.toast-warning .toast-icon {
  background: rgba(255, 214, 0, 0.2);
  color: var(--accent-yellow);
}
.toast-warning .toast-title {
  color: var(--accent-yellow);
}
.toast-warning .toast-progress {
  background: var(--accent-yellow);
}

.toast-success {
  border-left: 3px solid var(--accent-green);
}
.toast-success .toast-icon {
  background: rgba(0, 230, 118, 0.2);
  color: var(--accent-green);
}
.toast-success .toast-title {
  color: var(--accent-green);
}
.toast-success .toast-progress {
  background: var(--accent-green);
}

.toast-info {
  border-left: 3px solid var(--accent-blue);
}
.toast-info .toast-icon {
  background: rgba(68, 138, 255, 0.2);
  color: var(--accent-blue);
}
.toast-info .toast-title {
  color: var(--accent-blue);
}
.toast-info .toast-progress {
  background: var(--accent-blue);
}

@media (max-width: 480px) {
  .toast-container {
    top: 10px;
    right: 10px;
    left: 10px;
  }
  .toast {
    min-width: unset;
    max-width: 100%;
  }
}

/* ══════════════════════════════════════════════
   RESPONSIVE: Tablet (max-width: 768px)
   ══════════════════════════════════════════════ */
@media (max-width: 768px) {
  /* ── Referral Banner ── */
  .referral-bar {
    gap: 6px;
    padding: 6px 12px;
  }

  .referral-label {
    display: none;
  }

  .referral-buttons {
    flex: 1;
    width: 100%;
    flex-wrap: wrap;
    justify-content: center;
    gap: 6px;
  }

  .referral-btn {
    flex: 0 1 auto;
    justify-content: center;
    padding: 5px 10px;
    font-size: 11px;
  }

  .referral-bonus {
    display: none;
  }

  .referral-note {
    font-size: 10px;
    line-height: 1.4;
  }

  /* ── Hide Widget Settings on mobile (force card layout) ── */
  .widget-settings-wrap {
    display: none !important;
  }

  /* ── Force Card layout on mobile: hide tables, show card grids ── */
  .panel[data-widget] .table-wrap {
    display: none !important;
  }

  .panel[data-widget] .card-grid {
    display: grid !important;
  }

  /* ── Header: stack two rows ── */
  .header {
    flex-wrap: wrap;
    padding: 10px 12px;
    gap: 8px;
  }

  .header-left {
    gap: 8px;
  }

  .logo {
    font-size: 18px;
  }

  .badge {
    font-size: 11px;
    padding: 4px 10px;
  }

  .header-right {
    gap: 8px;
    flex-wrap: wrap;
    justify-content: flex-end;
  }

  .last-updated {
    font-size: 11px;
  }

  /* ── Panel Header: wrap controls neatly ── */
  .panel-header-right {
    flex-wrap: wrap;
    gap: 8px;
    width: 100%;
  }

  /* ── Dashboard Grid ── */
  .dashboard {
    padding: 10px 8px;
    gap: 10px;
    grid-template-columns: 1fr;
  }

  /* ── Panels ── */
  .panel-header {
    flex-direction: column;
    align-items: flex-start;
    padding: 10px 12px;
    gap: 4px;
  }

  .panel-header h2 {
    font-size: 13px;
  }

  .panel-desc {
    font-size: 12px;
  }

  .table-refresh-bar {
    padding: 5px 12px;
    gap: 8px;
  }

  .refresh-btn {
    padding: 4px 10px;
    font-size: 10px;
  }

  .refresh-time {
    font-size: 10px;
  }

  /* ── Tables: allow horizontal scroll on mobile ── */
  .table-wrap {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }

  table {
    font-size: 11px;
    min-width: 560px;
  }

  thead th {
    padding: 8px 6px;
    font-size: 12px;
  }

  tbody td {
    padding: 7px 6px;
  }

  /* ── Chart Modal: full screen on mobile ── */
  .modal-content {
    margin: 0;
    width: 100%;
    height: 100%;
    border-radius: 0;
    border: none;
  }

  .modal-header h2 {
    font-size: 15px;
  }

  /* ── Ad Slots ── */
  .ad-slot {
    padding: 6px 8px;
  }


  /* ── Column widths: override for mobile scroll ── */
  #arbTable, #sigTable, #mpTable {
    table-layout: auto;
  }

  /* ── Nav responsive ── */
  .main-nav {
    padding: 0 12px;
  }

  .main-nav-tab {
    padding: 10px 18px;
    font-size: 13px;
  }

  .mp-view {
    padding: 10px 8px;
  }

  /* ── Marketplace responsive ── */
  .mp-filters {
    order: 3;
    width: 100%;
  }

  .mp-form-row {
    flex-direction: column;
    gap: 0;
  }

  .mp-modal-detail,
  .mp-modal-form,
  .mp-modal-request {
    width: 100%;
    max-width: 100%;
    margin: 0;
    border-radius: 0;
    border: none;
    height: 100%;
    max-height: 100%;
  }

  .mp-detail-stats {
    grid-template-columns: repeat(2, 1fr);
  }

  .mp-dash-item {
    flex-wrap: wrap;
  }

  .mp-dash-item-actions {
    width: 100%;
    justify-content: flex-end;
  }
}

/* ══════════════════════════════════════════════
   RESPONSIVE: Small Phone (max-width: 480px)
   ══════════════════════════════════════════════ */
@media (max-width: 480px) {
  .header {
    padding: 8px 12px;
    gap: 6px;
  }

  .header-left {
    flex-shrink: 0;
    gap: 6px;
  }

  .logo {
    font-size: 16px;
    letter-spacing: 1px;
  }

  .logo-icon {
    width: 24px;
    height: 24px;
  }

  .header-right {
    flex: 1;
    gap: 5px;
    row-gap: 8px;
    justify-content: flex-end;
    flex-wrap: wrap;
  }

  /* Order: action buttons row 1, info items row 2 */
  .theme-toggle { order: 1; }
  .sound-toggle { order: 2; }
  .user-auth { order: 3; }
  .status { order: 10; }

  .last-updated {
    display: none;
  }

  /* Compact buttons */
  .theme-toggle,
  .sound-toggle,
  .widget-settings-btn {
    padding: 3px 8px;
    font-size: 10px;
    min-height: unset;
    letter-spacing: 0.3px;
  }

  .status {
    font-size: 11px;
    gap: 4px;
  }

  .status-dot {
    width: 6px;
    height: 6px;
  }

  /* Panel header: desc full width, buttons row below */
  .panel-header-right {
    gap: 6px;
  }

  .panel-desc {
    width: 100%;
    font-size: 10px;
  }

  .dashboard {
    padding: 6px 4px;
    gap: 8px;
  }

  .panel-header {
    padding: 8px 10px;
  }

  .panel-header h2 {
    font-size: 12px;
  }

  table {
    font-size: 12px;
    min-width: 520px;
  }

  thead th {
    font-size: 11px;
    padding: 7px 5px;
  }

  tbody td {
    padding: 6px 5px;
    font-size: 12px;
  }

  .widget-dropdown {
    min-width: 160px;
  }

  .widget-dropdown label {
    font-size: 12px;
    padding: 10px 14px;
  }

  .ind-dropdown {
    width: 260px;
  }

  .ind-settings-btn {
    padding: 3px 8px;
    font-size: 10px;
    min-height: unset;
  }

  .ind-weight-range {
    width: 56px;
  }

  .user-name {
    display: none;
  }

  .login-btn {
    padding: 3px 8px;
    font-size: 10px;
    min-height: unset;
  }

  .login-btn svg {
    width: 14px;
    height: 14px;
  }

  .logout-btn {
    padding: 3px 7px;
    font-size: 10px;
    min-height: unset;
  }

  .user-avatar {
    width: 24px;
    height: 24px;
  }

  .main-nav-tab {
    padding: 10px 14px;
    font-size: 11px;
    flex: 1;
    text-align: center;
  }

  .main-nav {
    padding: 0;
  }

  /* ── Referral bar: compact for small phones ── */
  .referral-btn {
    padding: 4px 8px;
    font-size: 10px;
    border-radius: 4px;
    gap: 4px;
  }

  .referral-note {
    font-size: 9px;
  }

  /* ── Card grid: single column on small phones ── */
  .card-grid {
    grid-template-columns: 1fr !important;
    gap: 8px;
    padding: 8px;
  }

  .mp-view {
    padding: 6px 4px;
  }

  /* ── Marketplace 480px ── */
  .mp-action-btn {
    padding: 8px 14px;
    font-size: 12px;
    min-height: 36px;
  }

  .mp-filter-btn {
    padding: 8px 14px;
    font-size: 12px;
    min-height: 36px;
  }

  .mp-detail-stats {
    grid-template-columns: 1fr 1fr;
  }

  .mp-card-head {
    padding: 8px 10px;
  }

  .mp-card-body {
    padding: 6px 10px;
  }
}

/* ═══════════════════════════════════════════════ */
/* STRIPE CHECKOUT MODAL                          */
/* ═══════════════════════════════════════════════ */

.mp-modal-checkout {
  max-width: 460px;
}

.mp-checkout-info {
  text-align: center;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}

.mp-checkout-script {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary);
  margin-bottom: 4px;
}

.mp-checkout-seller {
  font-size: 13px;
  color: var(--text-secondary);
}

.mp-checkout-tv-group {
  margin-bottom: 18px;
}

.mp-checkout-tv-group label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  margin-bottom: 6px;
}

.mp-checkout-input {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 14px;
  outline: none;
  transition: border-color 0.2s;
}

.mp-checkout-input:focus {
  border-color: var(--accent-blue);
}

.mp-checkout-hint {
  display: block;
  font-size: 11px;
  color: var(--text-secondary);
  margin-top: 4px;
}

.mp-checkout-prices {
  display: flex;
  gap: 10px;
  margin-bottom: 20px;
}

.mp-price-option {
  flex: 1;
  position: relative;
  cursor: pointer;
}

.mp-price-option input[type="radio"] {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.mp-price-option-body {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 14px 12px;
  border: 2px solid var(--border);
  border-radius: 8px;
  transition: border-color 0.2s, background 0.2s;
}

.mp-price-option input:checked + .mp-price-option-body {
  border-color: #635bff;
  background: rgba(99, 91, 255, 0.08);
}

.mp-price-option-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 4px;
}

.mp-price-option-amount {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
}

.mp-price-only {
  max-width: 200px;
  margin: 0 auto;
}

.mp-stripe-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 14px;
  background: #635bff;
  color: #fff;
  border: none;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.2s, opacity 0.2s;
}

.mp-stripe-btn:hover {
  background: #5147e5;
}

.mp-stripe-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.mp-checkout-footer {
  text-align: center;
  margin-top: 12px;
  font-size: 11px;
  color: var(--text-secondary);
}

/* ── Buy Now button (green) in detail modal ── */
.mp-buy-btn {
  background: linear-gradient(135deg, #059669 0%, #10b981 100%) !important;
  color: #fff !important;
  border: none !important;
}

.mp-buy-btn:hover {
  opacity: 0.9;
}

/* ═══════════════════════════════════════════════ */
/* ORDER ITEMS                                    */
/* ═══════════════════════════════════════════════ */

.mp-order-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 8px;
  gap: 12px;
}

.mp-order-info {
  flex: 1;
  min-width: 0;
}

.mp-order-script {
  font-weight: 700;
  font-size: 14px;
  color: var(--text-primary);
  margin-bottom: 2px;
}

.mp-order-meta {
  font-size: 12px;
  color: var(--text-secondary);
}

.mp-order-amount {
  font-size: 13px;
  font-weight: 600;
  color: var(--accent-green);
  margin-top: 2px;
}

.mp-order-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

.mp-deliver-btn {
  padding: 6px 14px;
  background: #635bff;
  color: #fff;
  border: none;
  border-radius: 4px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s;
}

.mp-deliver-btn:hover {
  background: #5147e5;
}

/* ═══ Nickname Modal ═══ */
.modal-nickname {
  max-width: 400px;
  margin: 15vh auto;
}

.modal-nickname .modal-header {
  text-align: center;
  border-bottom: 1px solid var(--border);
}

.modal-nickname .modal-body {
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.nickname-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
  text-align: center;
}

#nicknameInput {
  width: 100%;
  padding: 12px 16px;
  background: var(--bg-primary);
  border: 2px solid var(--border);
  border-radius: 8px;
  color: var(--text-primary);
  font-size: 16px;
  font-weight: 600;
  text-align: center;
  letter-spacing: 0.5px;
  outline: none;
  transition: border-color 0.2s;
}

#nicknameInput:focus {
  border-color: var(--accent-blue);
}

.nickname-status {
  font-size: 12px;
  font-weight: 600;
  text-align: center;
  min-height: 18px;
  transition: color 0.2s;
}

.nickname-error {
  color: var(--accent-red);
}

.nickname-ok {
  color: var(--accent-green);
}

.nickname-submit {
  width: 100%;
  padding: 12px;
  background: var(--accent-blue);
  border: none;
  border-radius: 8px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s;
}

.nickname-submit:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.nickname-submit:not(:disabled):hover {
  opacity: 0.9;
}

/* ═══ Private Comments Section ═══ */
.mp-comments-section {
  margin-top: 20px;
  border-top: 1px solid var(--border);
  padding-top: 16px;
}

.mp-comments-title {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 8px;
}

.mp-comment-notice {
  font-size: 11px;
  color: var(--text-secondary);
  background: rgba(68, 138, 255, 0.06);
  border: 1px solid rgba(68, 138, 255, 0.15);
  border-radius: 6px;
  padding: 8px 12px;
  margin-bottom: 12px;
}

.mp-comments-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  max-height: 300px;
  overflow-y: auto;
  margin-bottom: 12px;
}

.mp-comments-empty {
  font-size: 12px;
  color: var(--text-secondary);
  font-style: italic;
  padding: 8px 0;
}

.mp-comment-item {
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 12px;
}

.mp-comment-head {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 6px;
}

.mp-comment-avatar {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  object-fit: cover;
}

.mp-comment-nick {
  font-size: 12px;
  font-weight: 700;
  color: var(--accent-blue);
}

.mp-comment-time {
  font-size: 10px;
  color: var(--text-secondary);
  margin-left: auto;
}

.mp-comment-msg {
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-primary);
  word-break: break-word;
}

.mp-comment-form {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.mp-comment-form textarea {
  width: 100%;
  padding: 10px 12px;
  background: var(--bg-primary);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  font-size: 13px;
  font-family: inherit;
  resize: vertical;
  outline: none;
  transition: border-color 0.2s;
}

.mp-comment-form textarea:focus {
  border-color: var(--accent-blue);
}

.mp-comment-submit {
  align-self: flex-end;
  padding: 8px 20px;
  background: var(--accent-blue);
  border: none;
  border-radius: 6px;
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s;
}

.mp-comment-submit:disabled {
  opacity: 0.4;
  cursor: not-allowed;
}

.mp-comment-submit:hover:not(:disabled) {
  opacity: 0.9;
}

.mp-inquiry-guide {
  font-size: 12px;
  color: var(--text-secondary);
  font-style: italic;
  padding: 8px 0;
}

/* ── News Widget ── */
.news-panel { margin-top: 8px; }
.news-stack { display: flex; flex-direction: column; gap: 0; }
.news-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  animation: newsSlideIn 0.4s ease-out;
  transition: opacity 0.3s, transform 0.3s;
}
.news-item:last-child { border-bottom: none; }
.news-item-img {
  width: 56px;
  height: 56px;
  border-radius: 6px;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--bg-secondary);
}
.news-item-body { flex: 1; min-width: 0; }
.news-item-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  line-height: 1.4;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.news-item-title a {
  color: var(--text-primary);
  text-decoration: none;
}
.news-item-title a:hover { color: var(--accent-blue); }
.news-item-meta {
  display: flex;
  gap: 8px;
  align-items: center;
  margin-top: 4px;
  font-size: 11px;
  color: var(--text-secondary);
}
.news-item-source {
  font-weight: 600;
  color: var(--accent-blue);
}
.news-placeholder {
  padding: 20px;
  text-align: center;
  color: var(--text-secondary);
  font-size: 13px;
}
@keyframes newsSlideIn {
  from { opacity: 0; transform: translateY(-10px); }
  to { opacity: 1; transform: translateY(0); }
}
.news-item-exit {
  opacity: 0;
  transform: translateY(10px);
  max-height: 0;
  padding: 0 16px;
  overflow: hidden;
}

/* ── News Full Page (News Tab) ── */
.news-full .panel-header { margin-bottom: 16px; }
.news-full-list { display: flex; flex-direction: column; gap: 0; }
.news-full-item {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 16px;
  border-bottom: 1px solid var(--border);
  transition: background 0.2s;
}
.news-full-item:hover { background: rgba(68, 138, 255, 0.04); }
.news-full-item:last-child { border-bottom: none; }
.news-full-img {
  width: 80px;
  height: 80px;
  border-radius: 8px;
  object-fit: cover;
  flex-shrink: 0;
  background: var(--bg-primary);
}
.news-full-body { flex: 1; min-width: 0; }
.news-full-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.4;
  margin-bottom: 6px;
}
.news-full-title a {
  color: var(--text-primary);
  text-decoration: none;
  transition: color 0.2s;
}
.news-full-title a:hover { color: var(--accent-blue); }
.news-full-excerpt {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  overflow: hidden;
  margin-bottom: 8px;
}
.news-full-meta {
  display: flex;
  gap: 10px;
  align-items: center;
  font-size: 11px;
  color: var(--text-secondary);
}
.news-full-source {
  font-weight: 600;
  color: var(--accent-blue);
}
.news-load-more {
  display: block;
  width: 100%;
  padding: 14px;
  margin-top: 4px;
  background: var(--bg-panel);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--accent-blue);
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.2s;
}
.news-load-more:hover {
  background: rgba(68, 138, 255, 0.08);
  border-color: var(--accent-blue);
}
.news-load-more:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

@media (max-width: 600px) {
  .news-full-img { width: 60px; height: 60px; }
  .news-full-item { padding: 12px; gap: 12px; }
  .news-full-title { font-size: 14px; }
  .news-full-excerpt { -webkit-line-clamp: 2; font-size: 12px; }
}

/* ── Economic Calendar Widget ── */
.calendar-panel { margin-top: 8px; }
.calendar-table { width: 100%; border-collapse: collapse; }
.calendar-table th {
  text-align: left;
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 8px 12px;
  border-bottom: 1px solid var(--border);
}
.calendar-table td {
  padding: 10px 12px;
  font-size: 13px;
  border-bottom: 1px solid var(--border);
  color: var(--text-primary);
}
.calendar-table tr:last-child td { border-bottom: none; }
.calendar-table tr:hover td { background: rgba(68, 138, 255, 0.04); }
.cal-date { color: var(--text-secondary); white-space: nowrap; font-size: 12px; }
.cal-time { color: var(--text-secondary); white-space: nowrap; font-size: 12px; }
.cal-event { font-weight: 600; }
.cal-actual { font-weight: 600; color: var(--accent-green); font-variant-numeric: tabular-nums; white-space: nowrap; }
.cal-prev, .cal-fcst { font-variant-numeric: tabular-nums; white-space: nowrap; }
.cal-empty { padding: 20px; text-align: center; color: var(--text-secondary); font-size: 13px; }

@media (max-width: 600px) {
  .calendar-table th:nth-child(6),
  .calendar-table td:nth-child(6) { display: none; }
  .calendar-table th, .calendar-table td { padding: 8px 6px; font-size: 12px; }
}

/* ── Premium Strategy Scripts ── */
.strat-panel { border: 1px solid rgba(255, 179, 0, 0.2); }
.strat-badge {
  display: inline-block;
  background: linear-gradient(135deg, #f5a623, #f7931a);
  color: #000;
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 1px;
  padding: 2px 8px;
  border-radius: 4px;
  vertical-align: middle;
  margin-right: 6px;
}
.strat-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: 16px;
  padding: 16px;
}
.strat-card {
  background: var(--bg-secondary);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: border-color 0.2s;
}
.strat-card:hover { border-color: #f5a623; }
.strat-card-head { display: flex; flex-direction: column; gap: 6px; }
.strat-name { font-size: 15px; font-weight: 700; color: var(--text-primary); }
.strat-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.strat-tag {
  font-size: 11px;
  padding: 2px 8px;
  border-radius: 4px;
  background: rgba(79, 195, 247, 0.15);
  color: #4fc3f7;
  font-weight: 600;
}
.strat-tag-tf { background: rgba(245, 166, 35, 0.15); color: #f5a623; }
.strat-desc {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.5;
}
.strat-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.strat-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.strat-stat-label {
  font-size: 10px;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
.strat-stat-val {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.strat-tv-btn {
  display: inline-block;
  text-align: center;
  padding: 8px 12px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #000;
  background: linear-gradient(135deg, #f5a623, #f7931a);
  text-decoration: none;
  transition: opacity 0.2s;
  margin-top: auto;
}
.strat-tv-btn:hover { opacity: 0.85; }

@media (max-width: 600px) {
  .strat-grid { grid-template-columns: 1fr; padding: 12px; }
  .strat-stats { grid-template-columns: repeat(2, 1fr); }
}
