/* ============================================================================
   Market Opportunity Scanner — 样式表（响应式）
   所有选择器以 .ar-page / .anomaly-radar 为前缀，可安全合并进现有网站。
   不含站点 logo / 导航 —— 这些由宿主网站模板提供。
   ============================================================================ */

.ar-page {
  --ar-bg: #070b14; --ar-card: #0e1626; --ar-card2: #111d33;
  --ar-line: rgba(120,160,200,0.12);
  --ar-teal: #2dd4bf; --ar-cyan: #22d3ee;
  --ar-txt: #e8eef6; --ar-dim: #7d8aa0;
  --ar-up: #34d399; --ar-down: #f87171;
  max-width: 1440px; margin: 0 auto; padding: 28px 24px 48px;
  font-family: -apple-system, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
  color: var(--ar-txt); box-sizing: border-box;
}
.ar-page *, .anomaly-radar * { box-sizing: border-box; }

/* ---- breadcrumb ---- */
.ar-crumb { margin-bottom: 18px; }
.ar-crumb ol {
  list-style: none; display: flex; flex-wrap: wrap; align-items: center;
  gap: 8px; padding: 0; margin: 0; font-size: 13px;
}
.ar-crumb a { color: var(--ar-dim); text-decoration: none; }
.ar-crumb a:hover { color: var(--ar-teal); }
.ar-crumb .ar-sep { color: #475569; }
.ar-crumb li[aria-current] { color: var(--ar-txt); }

/* ---- page header (SEO-critical, static in HTML) ---- */
.ar-page-head { margin-bottom: 24px; }
.ar-page-head h1 {
  font-size: 28px; font-weight: 700; letter-spacing: 0.4px; margin: 0 0 10px;
  background: linear-gradient(120deg, #fff 25%, var(--ar-teal));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.ar-page-head .ar-intro {
  font-size: 14px; line-height: 1.7; color: var(--ar-dim); max-width: 760px; margin: 0;
}
.ar-page-actions {
  display: flex; flex-wrap: wrap; gap: 10px; margin-top: 18px;
}
.ar-guide-cta {
  display: inline-grid;
  grid-template-columns: minmax(0, auto) auto;
  align-items: center;
  gap: 4px 14px;
  max-width: min(100%, 520px);
  padding: 13px 16px;
  border: 1px solid rgba(45, 212, 191, 0.45);
  border-radius: 10px;
  background:
    linear-gradient(135deg, rgba(45, 212, 191, 0.16), rgba(34, 211, 238, 0.07)),
    rgba(14, 22, 38, 0.82);
  color: #effffb;
  text-decoration: none;
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.24), inset 0 1px 0 rgba(255, 255, 255, 0.08);
  transition: border-color 0.15s, background-color 0.15s, transform 0.15s, box-shadow 0.15s;
}
.ar-guide-cta::after {
  content: "→";
  grid-row: 1 / span 2;
  grid-column: 2;
  display: grid;
  width: 30px;
  height: 30px;
  place-items: center;
  border-radius: 999px;
  background: linear-gradient(135deg, var(--ar-teal), var(--ar-cyan));
  color: #03121a;
  font-size: 18px;
  font-weight: 900;
}
.ar-guide-cta span {
  color: #ffffff;
  font-size: 14px;
  font-weight: 800;
  line-height: 1.2;
}
.ar-guide-cta small {
  color: #a7b7c8;
  font-size: 12px;
  line-height: 1.35;
}
.ar-guide-cta:hover,
.ar-guide-cta:focus-visible {
  border-color: rgba(45, 212, 191, 0.8);
  background-color: rgba(45, 212, 191, 0.08);
  box-shadow: 0 14px 34px rgba(0, 0, 0, 0.3), 0 0 0 3px rgba(45, 212, 191, 0.12);
  transform: translateY(-1px);
  outline: none;
}

/* ---- widget shell ---- */
.anomaly-radar {
  position: relative; overflow: hidden;
  background: var(--ar-bg); border: 1px solid var(--ar-line); border-radius: 18px;
}
.anomaly-radar .ar-glow {
  position: absolute; border-radius: 50%; filter: blur(120px);
  z-index: 0; pointer-events: none; opacity: 0.5;
}
.anomaly-radar .ar-glow-1 { width: 420px; height: 420px; top: -160px; left: -100px;
  background: radial-gradient(circle, #0d9488, transparent 70%); }
.anomaly-radar .ar-glow-2 { width: 480px; height: 480px; bottom: -220px; right: -120px;
  background: radial-gradient(circle, #1e3a8a, transparent 70%); }
.anomaly-radar .ar-inner { position: relative; z-index: 1; padding: 24px 22px; }

/* ---- widget toolbar ---- */
.anomaly-radar .ar-toolbar {
  display: flex; justify-content: space-between; align-items: center;
  flex-wrap: wrap; gap: 12px; margin-bottom: 20px;
}
.anomaly-radar .ar-generated { font-size: 12px; color: var(--ar-txt); font-weight: 600; }
.anomaly-radar .ar-cadence {
  font-size: 12px; color: var(--ar-teal);
  display: inline-flex; align-items: center; gap: 6px;
}
.anomaly-radar .ar-cadence::before {
  content: ""; width: 7px; height: 7px; border-radius: 50%;
  background: var(--ar-teal); box-shadow: 0 0 8px var(--ar-teal);
}

/* ---- stat cards ---- */
.anomaly-radar .ar-stats {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(160px, 1fr)); gap: 14px; margin-bottom: 24px;
}
.anomaly-radar .ar-stat {
  background: linear-gradient(160deg, var(--ar-card2), var(--ar-card));
  border: 1px solid var(--ar-line); border-radius: 14px;
  padding: 16px 18px; position: relative; overflow: hidden;
}
.anomaly-radar .ar-stat::before {
  content: ""; position: absolute; top: 14px; left: 0;
  width: 24px; height: 3px; border-radius: 0 3px 3px 0;
  background: linear-gradient(90deg, var(--ar-teal), var(--ar-cyan));
}
.anomaly-radar .ar-stat .ar-v {
  font-size: 26px; font-weight: 700; margin-top: 6px;
  background: linear-gradient(120deg, #fff, #9fe8df);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.anomaly-radar .ar-stat .ar-l { font-size: 12px; color: var(--ar-dim); margin-top: 4px; }

/* ---- featured section (Top 6 highlights) ---- */
.anomaly-radar .ar-featured { margin-bottom: 24px; }
.anomaly-radar .ar-featured-head {
  display: flex; flex-wrap: wrap; align-items: baseline;
  gap: 12px; padding: 0 4px 14px;
}
.anomaly-radar .ar-featured-title {
  font-size: 18px; font-weight: 700; margin: 0;
  background: linear-gradient(120deg, #fbbf24 0%, #2dd4bf 60%, #22d3ee);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.anomaly-radar .ar-featured-sub { font-size: 12px; color: var(--ar-dim); margin: 0; }
.anomaly-radar .ar-featured-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 14px;
}
.anomaly-radar .ar-card-featured {
  border-color: rgba(45, 212, 191, 0.35);
  background: linear-gradient(160deg, rgba(45,212,191,0.05), var(--ar-bg));
  box-shadow: 0 0 0 1px rgba(45,212,191,0.15), 0 6px 22px rgba(0,0,0,0.32);
}
.anomaly-radar .ar-card-featured:hover {
  border-color: rgba(45,212,191,0.55);
  box-shadow: 0 0 0 1px rgba(45,212,191,0.35), 0 10px 28px rgba(0,0,0,0.4);
}
.anomaly-radar .ar-card-rank-featured {
  background: linear-gradient(135deg, #fbbf24, #f87171);
  color: #1a1208; padding: 2px 8px; border-radius: 5px;
  font-size: 10px; letter-spacing: 0.5px;
}

/* ---- card detail rows ---- */
.anomaly-radar .ar-card-details {
  display: grid; grid-template-columns: 1fr; gap: 5px;
  padding: 10px; border: 1px dashed rgba(120,160,200,0.18); border-radius: 8px;
  background: rgba(255,255,255,0.025);
  font-size: 11.5px; line-height: 1.55; color: var(--ar-txt);
}
.anomaly-radar .ar-detail {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 8px;
  min-width: 0;
}
.anomaly-radar .ar-detail .ar-detail-k {
  color: var(--ar-dim); font-weight: 600;
}
.anomaly-radar .ar-detail .ar-detail-v {
  min-width: 0;
  overflow-wrap: anywhere;
}

/* ---- panel ---- */
.anomaly-radar .ar-panel {
  background: linear-gradient(160deg, var(--ar-card2), var(--ar-card));
  border: 1px solid var(--ar-line); border-radius: 16px; overflow: hidden;
}
.anomaly-radar .ar-panel-head {
  display: flex; justify-content: space-between; align-items: flex-end;
  flex-wrap: wrap; gap: 14px; padding: 20px 22px 14px;
  border-bottom: 1px solid var(--ar-line);
}
.anomaly-radar .ar-panel-title {
  font-size: 16px; font-weight: 700; margin: 0;
  background: linear-gradient(120deg, var(--ar-teal), var(--ar-cyan));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.anomaly-radar .ar-panel-sub { font-size: 12px; color: var(--ar-dim); margin: 4px 0 0; }
.anomaly-radar .ar-controls { display: flex; gap: 8px; flex-wrap: wrap; }
.anomaly-radar select, .anomaly-radar input[type=search] {
  background: var(--ar-bg); color: var(--ar-txt);
  border: 1px solid var(--ar-line); border-radius: 9px;
  padding: 8px 11px; font-size: 13px; outline: none; max-width: 100%;
}
.anomaly-radar select:focus, .anomaly-radar input[type=search]:focus { border-color: var(--ar-teal); }
.anomaly-radar input[type=search] { min-width: 140px; }

/* ---- card list ---- */
.anomaly-radar .ar-cards {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(330px, 1fr));
  gap: 14px; padding: 18px 22px 22px;
}
.anomaly-radar .ar-card {
  background: var(--ar-bg); border: 1px solid var(--ar-line);
  border-radius: 14px; padding: 15px 16px; cursor: pointer;
  display: flex; flex-direction: column; gap: 9px;
  transition: border-color 0.12s, transform 0.12s, box-shadow 0.12s;
}
.anomaly-radar .ar-card:hover {
  border-color: rgba(45,212,191,0.4); transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
}
.anomaly-radar .ar-card-top { display: flex; align-items: center; gap: 8px; }
.anomaly-radar .ar-card-rank { font-size: 12px; font-weight: 700; color: var(--ar-dim); }
.anomaly-radar .ar-sym { font-weight: 700; color: #fff; font-size: 15px; }
.anomaly-radar .ar-up { color: var(--ar-up); font-weight: 600; }
.anomaly-radar .ar-down { color: var(--ar-down); font-weight: 600; }
.anomaly-radar .ar-card-chg { margin-left: auto; font-size: 14px; }
.anomaly-radar .ar-card-name {
  font-size: 12px; color: var(--ar-dim); margin-top: -4px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.anomaly-radar .ar-card-score { display: flex; align-items: center; gap: 9px; }
.anomaly-radar .ar-card-score .ar-bar { width: 92px; }
.anomaly-radar .ar-card-score .ar-pill { margin-left: auto; }
.anomaly-radar .ar-card-sources { display: flex; flex-wrap: wrap; }
.anomaly-radar .ar-card-narrative {
  font-size: 12.5px; line-height: 1.65; color: var(--ar-txt);
  background: rgba(45,212,191,0.06);
  border-left: 2px solid var(--ar-teal); border-radius: 6px;
  padding: 8px 10px;
}
.anomaly-radar .ar-card-stats {
  font-size: 11px; color: var(--ar-dim); font-variant-numeric: tabular-nums;
}

.anomaly-radar .ar-bar {
  display: inline-block; width: 70px; height: 7px;
  background: rgba(255,255,255,0.07); border-radius: 4px;
  overflow: hidden; vertical-align: middle; margin-right: 8px;
}
.anomaly-radar .ar-bar > span { display: block; height: 100%; border-radius: 4px; }
.anomaly-radar .ar-score-num { font-variant-numeric: tabular-nums; font-weight: 600; }

.anomaly-radar .ar-pill {
  padding: 3px 10px; border-radius: 20px; font-size: 11px; font-weight: 700;
  border: 1px solid transparent;
}
.anomaly-radar .ar-risk-high { background: rgba(248,113,113,0.14); color: #fca5a5; border-color: rgba(248,113,113,0.3); }
.anomaly-radar .ar-risk-medium { background: rgba(251,191,36,0.14); color: #fcd34d; border-color: rgba(251,191,36,0.3); }
.anomaly-radar .ar-risk-low { background: rgba(34,211,238,0.14); color: #67e8f9; border-color: rgba(34,211,238,0.3); }

.anomaly-radar .ar-chip {
  display: inline-block; margin: 1px 3px 1px 0;
  padding: 2px 8px; border-radius: 6px; font-size: 11px; font-weight: 600;
  border: 1px solid transparent;
}
.anomaly-radar .ar-c-volume { background: rgba(45,212,191,0.14); color: #5eead4; border-color: rgba(45,212,191,0.3); }
.anomaly-radar .ar-c-price { background: rgba(34,211,238,0.14); color: #67e8f9; border-color: rgba(34,211,238,0.3); }
.anomaly-radar .ar-c-gap { background: rgba(96,165,250,0.14); color: #93c5fd; border-color: rgba(96,165,250,0.3); }
.anomaly-radar .ar-c-volatility { background: rgba(167,139,250,0.14); color: #c4b5fd; border-color: rgba(167,139,250,0.3); }
.anomaly-radar .ar-c-pattern { background: rgba(240,171,252,0.14); color: #f0abfc; border-color: rgba(240,171,252,0.3); }
.anomaly-radar .ar-c-options { background: rgba(251,191,36,0.14); color: #fcd34d; border-color: rgba(251,191,36,0.3); }
.anomaly-radar .ar-c-sentiment { background: rgba(52,211,153,0.14); color: #6ee7b7; border-color: rgba(52,211,153,0.3); }
.anomaly-radar .ar-c-none { background: rgba(255,255,255,0.05); color: var(--ar-dim); }

.anomaly-radar .ar-empty { padding: 38px; text-align: center; color: var(--ar-dim); }
.anomaly-radar .ar-disclaimer {
  text-align: center; color: var(--ar-dim); font-size: 11px; margin-top: 18px;
}

/* ---- modal ---- */
.anomaly-radar .ar-modal { display: none; }
.anomaly-radar .ar-modal:not([hidden]) {
  display: flex; position: fixed; inset: 0; z-index: 9999;
  align-items: center; justify-content: center; padding: 16px;
  background: rgba(4,8,16,0.78); -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px);
}
.anomaly-radar .ar-modal-box {
  background: linear-gradient(160deg, var(--ar-card2), var(--ar-card));
  border: 1px solid rgba(45,212,191,0.25); border-radius: 16px;
  padding: 24px 26px; max-width: 580px; width: 100%;
  max-height: 84vh; overflow: auto; position: relative;
  box-shadow: 0 24px 60px rgba(0,0,0,0.6);
}
.anomaly-radar .ar-close {
  position: absolute; top: 12px; right: 14px; background: none; border: 0;
  color: var(--ar-dim); font-size: 22px; cursor: pointer;
  width: 30px; height: 30px; line-height: 1;
}
.anomaly-radar .ar-close:hover { color: #fff; }
.anomaly-radar .ar-modal-box h2 { font-size: 18px; margin: 0 0 12px; color: #fff; }
.anomaly-radar .ar-narrative {
  background: rgba(45,212,191,0.08);
  border: 1px solid rgba(45,212,191,0.22); border-left-width: 3px;
  border-radius: 10px; padding: 12px 14px; margin-bottom: 14px;
  font-size: 13px; line-height: 1.7; color: var(--ar-txt);
}
.anomaly-radar .ar-narrative-tag {
  display: block; font-size: 10px; font-weight: 700; letter-spacing: 0.6px;
  text-transform: uppercase; color: var(--ar-teal); margin-bottom: 5px;
}
.anomaly-radar .ar-etf {
  display: inline-block; vertical-align: middle;
  font-size: 9px; font-weight: 700; letter-spacing: 0.5px;
  padding: 1px 5px; border-radius: 4px;
  background: rgba(96,165,250,0.16); color: #93c5fd;
  border: 1px solid rgba(96,165,250,0.32);
}
.anomaly-radar .ar-modal-sources { margin-bottom: 14px; }
.anomaly-radar .ar-kv {
  display: flex; justify-content: space-between; gap: 12px;
  padding: 7px 0; border-bottom: 1px solid var(--ar-line); font-size: 13px;
}
.anomaly-radar .ar-kv .ar-k { color: var(--ar-dim); }
.anomaly-radar .ar-modal-box h3 {
  font-size: 12px; text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--ar-teal); margin: 18px 0 6px;
}
.anomaly-radar .ar-modal-box ul { list-style: none; padding: 0; margin: 0; }
.anomaly-radar .ar-modal-box li { font-size: 12px; padding: 5px 0; border-bottom: 1px solid var(--ar-line); }
.anomaly-radar .ar-modal-box a { color: var(--ar-cyan); text-decoration: none; }
.anomaly-radar .ar-modal-box a:hover { text-decoration: underline; }

/* ---- responsive ---- */
@media (max-width: 900px) {
  .anomaly-radar .ar-stats { grid-template-columns: repeat(2, 1fr); }
  .anomaly-radar .ar-panel-head { flex-direction: column; align-items: stretch; }
  .anomaly-radar .ar-controls { width: 100%; }
  .anomaly-radar .ar-controls select,
  .anomaly-radar .ar-controls input[type=search] { flex: 1 1 44%; }
}
@media (max-width: 600px) {
  .ar-page { padding: 18px 14px 36px; }
  .ar-page-head h1 { font-size: 22px; }
  .ar-page-head .ar-intro { font-size: 13px; }
  .ar-guide-cta {
    width: 100%;
    grid-template-columns: minmax(0, 1fr) auto;
    padding: 12px 14px;
  }
  .anomaly-radar .ar-inner { padding: 18px 14px; }
  .anomaly-radar .ar-stats { gap: 10px; }
  .anomaly-radar .ar-stat { padding: 13px 14px; }
  .anomaly-radar .ar-stat .ar-v { font-size: 22px; }
  .anomaly-radar .ar-cards { grid-template-columns: 1fr; padding: 14px; gap: 12px; }
  .anomaly-radar .ar-featured-grid { grid-template-columns: 1fr; gap: 12px; }
  .anomaly-radar .ar-modal-box { padding: 20px 18px; }
  .anomaly-radar .ar-detail { grid-template-columns: 1fr; gap: 2px; }
}
