:root {
  color-scheme: dark;
  --bg: #090d1a;
  --panel: #111a31;
  --panel-2: #151f3a;
  --text: #eef4ff;
  --muted: #9aa8c7;
  --line: rgba(255,255,255,.10);
  --accent: #8eb8ff;
  --good: #5ef0ad;
  --warn: #ffd166;
  --bad: #ff6b86;
  --blue: #76d7ff;
  --shadow: 0 18px 55px rgba(0,0,0,.32);
  --radius: 22px;
  --font: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  min-height: 100vh;
  background:
    radial-gradient(circle at top left, rgba(73,112,255,.20), transparent 34%),
    radial-gradient(circle at top right, rgba(80,217,172,.12), transparent 30%),
    var(--bg);
  color: var(--text);
  font-family: var(--font);
}
button, input, select { font-family: inherit; }
.app-shell { width: min(1120px, 100%); margin: 0 auto; padding: 22px 14px 36px; }
.topbar { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin: 8px 0 16px; }
h1,h2,p { margin-top: 0; }
h1 { font-size: clamp(28px, 7vw, 48px); margin: 0 0 4px; letter-spacing: -.04em; }
h2 { font-size: clamp(20px, 5vw, 30px); margin-bottom: 10px; letter-spacing: -.03em; }
.subline { color: var(--muted); margin: 0; max-width: 740px; }
.eyebrow { color: var(--accent); font-size: 12px; font-weight: 850; text-transform: uppercase; letter-spacing: .11em; margin-bottom: 7px; }
.card { background: linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02)), var(--panel); border: 1px solid var(--line); border-radius: var(--radius); padding: 18px; box-shadow: var(--shadow); margin-bottom: 14px; }
.grid { display: grid; gap: 12px; }
.controls-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.cards-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
label span, .metric-grid span { display: block; color: var(--muted); font-size: 12px; font-weight: 750; margin-bottom: 7px; }
input, select, button { width: 100%; border: 1px solid var(--line); border-radius: 15px; background: rgba(255,255,255,.06); color: var(--text); padding: 12px 13px; outline: none; font-size: 15px; }
select option { color: #111; }
input:focus, select:focus { border-color: rgba(142,184,255,.7); box-shadow: 0 0 0 3px rgba(142,184,255,.12); }
button { cursor: pointer; font-weight: 800; }
button:disabled { opacity: .65; cursor: wait; }
.primary { background: linear-gradient(135deg, #c7f9ff, #d8ffe7); color: #162033; border: 0; }
.secondary { background: rgba(255,255,255,.08); }
.help { display: inline-grid; place-items: center; width: 18px; height: 18px; min-width: 18px; border-radius: 999px; border: 1px solid rgba(142,184,255,.45); background: rgba(142,184,255,.13); color: #cfe0ff; font-size: 12px; padding: 0; margin-left: 5px; vertical-align: 1px; cursor: help; }
.toggles-row, .action-row, .legend-row, .chip-row, .section-head, .score-row { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.section-head { justify-content: space-between; }
.switch-line { width: auto; display: flex; align-items: center; gap: 8px; color: var(--text); font-weight: 700; }
.switch-line input { width: 18px; height: 18px; accent-color: #5ed8ff; }
.switch-line span { margin: 0; color: var(--text); font-size: 14px; }
.strong-switch { margin-bottom: 10px; }
.range-line { display: block; margin: 10px 0 13px; }
.range-line input { padding: 0; accent-color: #5ed8ff; }
.action-row { margin-top: 12px; }
.action-row button { width: auto; min-width: 165px; }
.status-pill, .mini-note, .chip, .score-pill, .legend { border: 1px solid var(--line); background: rgba(255,255,255,.06); color: var(--muted); border-radius: 999px; padding: 8px 11px; font-size: 12px; font-weight: 800; }
.status-pill.ok { color: var(--good); border-color: rgba(94,240,173,.25); }
.status-pill.bad { color: var(--bad); border-color: rgba(255,107,134,.25); }
.style-panel { margin-top: 13px; padding: 13px; border: 1px dashed rgba(255,255,255,.13); border-radius: 18px; background: rgba(255,255,255,.025); }
.tf-box { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.tf-box label { width: auto; display: inline-flex; align-items: center; gap: 6px; border: 1px solid var(--line); border-radius: 999px; padding: 8px 10px; background: rgba(255,255,255,.05); font-weight: 800; color: var(--text); }
.tf-box input { width: 16px; height: 16px; accent-color: #5ed8ff; padding: 0; }
.tf-box.disabled { opacity: .5; }
.chart-card { padding-bottom: 13px; }
.chart { height: 430px; width: 100%; border-radius: 19px; overflow: hidden; border: 1px solid rgba(255,255,255,.07); background: #080d18; }
.legend { color: var(--text); }
.legend.entry { color: var(--good); }
.legend.exit { color: var(--warn); }
.legend.risk { color: var(--bad); }
.legend.target { color: var(--blue); }
.highlight-card { background: linear-gradient(145deg, rgba(93,170,255,.16), rgba(94,240,173,.06)), var(--panel); }
.metric-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; margin: 12px 0; }
.metric-grid.two { margin-top: 8px; }
.metric-grid div { background: rgba(255,255,255,.05); border: 1px solid var(--line); border-radius: 16px; padding: 13px; min-height: 76px; }
.metric-grid strong { font-size: clamp(20px, 5vw, 28px); letter-spacing: -.03em; }
.score-row { margin: 8px 0; }
.score-pill { color: #d9e6ff; }
.interpretation { color: var(--muted); line-height: 1.55; margin: 8px 0 4px; }
.prob-bars { display: grid; gap: 12px; margin: 10px 0 12px; }
.prob-line { display: grid; grid-template-columns: 80px 70px 1fr; align-items: center; gap: 10px; color: var(--muted); font-weight: 850; }
.prob-line div { height: 10px; background: rgba(255,255,255,.07); border-radius: 999px; overflow: hidden; }
.prob-line i { display: block; height: 100%; width: 0%; background: linear-gradient(90deg, var(--accent), var(--good)); border-radius: inherit; transition: width .25s ease; }
#downBar { background: linear-gradient(90deg, var(--warn), var(--bad)); }
.why-list { padding-left: 20px; margin-bottom: 0; color: var(--text); }
.why-list li { margin: 0 0 10px; line-height: 1.5; }
.text-box { color: var(--text); line-height: 1.5; }
.item { padding: 10px 0; border-bottom: 1px solid var(--line); }
.item:last-child { border-bottom: 0; }
.item span, .tiny { color: var(--muted); font-size: 12px; line-height: 1.45; }
.legal-footer { color: var(--muted); border: 1px solid var(--line); background: rgba(255,255,255,.035); border-radius: 18px; padding: 14px; line-height: 1.55; font-size: 12px; }
.toast { position: fixed; left: 50%; bottom: 22px; transform: translateX(-50%) translateY(20px); opacity: 0; pointer-events: none; background: #eef4ff; color: #111827; padding: 12px 15px; border-radius: 999px; font-weight: 850; box-shadow: 0 12px 38px rgba(0,0,0,.28); transition: .22s ease; z-index: 50; }
.toast.show { opacity: 1; transform: translateX(-50%) translateY(0); }
@media (max-width: 780px) {
  .topbar { flex-direction: column; }
  .controls-grid, .cards-grid, .metric-grid { grid-template-columns: 1fr; }
  .action-row button { width: 100%; }
  .chart { height: 360px; }
  .prob-line { grid-template-columns: 74px 64px 1fr; }
}

.insight-strip { display:flex; gap:8px; flex-wrap:wrap; margin-top: 12px; }
.insight-strip span { width:auto; display:inline-flex; margin:0; padding:7px 10px; border-radius:999px; border:1px solid rgba(142,184,255,.18); background:rgba(142,184,255,.08); color:#dce8ff; font-size:12px; font-weight:850; }
.edge-panel { display:grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap:10px; margin: 12px 0; }
.edge-panel div { border:1px solid var(--line); background:rgba(255,255,255,.045); border-radius:15px; padding:11px; }
.edge-panel span { display:block; color:var(--muted); font-size:11px; font-weight:850; text-transform:uppercase; letter-spacing:.06em; margin-bottom:5px; }
.edge-panel strong { font-size:15px; }
.alert-card { border-color: rgba(255,209,102,.20); background: linear-gradient(145deg, rgba(255,209,102,.08), rgba(255,255,255,.02)), var(--panel); }
.alert-item { border-radius:14px; border:1px solid var(--line); padding:11px; margin:0 0 9px; background:rgba(255,255,255,.035); }
.alert-item.sev-high { border-color: rgba(255,107,134,.35); background:rgba(255,107,134,.08); }
.alert-item.sev-med { border-color: rgba(255,209,102,.30); background:rgba(255,209,102,.07); }
.alert-item.sev-low { border-color: rgba(118,215,255,.25); background:rgba(118,215,255,.06); }
.muted { color: var(--muted); }
.help-tooltip { position: fixed; z-index: 1000; display:none; padding:12px 13px; border-radius:14px; border:1px solid rgba(142,184,255,.35); background:rgba(11,18,34,.96); color:#eef4ff; box-shadow:0 18px 55px rgba(0,0,0,.45); font-size:13px; line-height:1.45; }
.help-tooltip.show { display:block; }
.help { user-select:none; }
@media (max-width: 780px) { .edge-panel { grid-template-columns: 1fr; } .help-tooltip { left:12px !important; right:12px !important; max-width: calc(100vw - 24px) !important; } }

.smart-auto-card { border-color: rgba(94,240,173,.20); background: linear-gradient(145deg, rgba(94,240,173,.08), rgba(142,184,255,.07)), var(--panel); }
.candidate-row { display:grid; grid-template-columns: repeat(5, minmax(0,1fr)); gap:8px; margin-top:12px; }
.candidate { border:1px solid var(--line); background: rgba(255,255,255,.045); border-radius:16px; padding:10px; min-height:82px; }
.candidate.selected { border-color: rgba(94,240,173,.45); background: rgba(94,240,173,.09); }
.candidate strong, .candidate span, .candidate small { display:block; }
.candidate span { color: var(--text); font-size:13px; margin-top:4px; }
.candidate small { color: var(--muted); margin-top:5px; line-height:1.35; }
body.beginner-mode .pro-only { display:none; }
body.beginner-mode .why-list li:nth-child(n+4) { display:none; }
body.beginner-mode .fundamentalBox-extra { display:none; }
body.beginner-mode .cards-grid.pro-only { display:none; }
body.beginner-mode .edge-panel { grid-template-columns: 1fr; }
body.beginner-mode .edge-panel div:nth-child(2), body.beginner-mode .edge-panel div:nth-child(3) { display:none; }
@media (max-width: 900px) { .candidate-row { grid-template-columns: repeat(2, minmax(0,1fr)); } }
@media (max-width: 520px) { .candidate-row { grid-template-columns: 1fr; } }

.conviction-panel {
  margin-top: 16px;
  padding: 14px;
  border: 1px solid rgba(126, 220, 255, .18);
  border-radius: 18px;
  background: rgba(9, 16, 34, .58);
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.conviction-panel div { display: flex; flex-direction: column; gap: 5px; }
.conviction-panel span { color: var(--muted); font-size: .78rem; }
.conviction-panel strong { color: #f7fbff; font-size: 1.05rem; }
.conviction-panel .tiny { grid-column: 1 / -1; margin: 4px 0 0; }
.key-levels-card .item, .key-level { border-left: 3px solid rgba(94, 240, 173, .55); }
.key-level:nth-child(2) { border-left-color: rgba(255, 209, 102, .7); }
.pro-mode .key-levels-card { min-height: 100%; }
.text-box small { color: #9fb2d8; }
@media (max-width: 720px) {
  .conviction-panel { grid-template-columns: 1fr; }
}

.top-actions { display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }
.guide-btn { width:auto; min-width:112px; border-radius:999px; padding:9px 13px; background:rgba(94,240,173,.10); border-color:rgba(94,240,173,.28); color:#dffff0; }
.top-summary-card { border-color:rgba(94,240,173,.28); background:linear-gradient(145deg, rgba(94,240,173,.12), rgba(142,184,255,.09)), var(--panel); }
.summary-grid { display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:10px; margin-top:12px; }
.summary-grid div { border:1px solid var(--line); border-radius:16px; padding:13px; background:rgba(255,255,255,.05); min-height:82px; }
.summary-grid span { display:block; color:var(--muted); font-size:11px; text-transform:uppercase; letter-spacing:.07em; font-weight:850; margin-bottom:7px; }
.summary-grid strong { font-size: clamp(18px, 4vw, 24px); letter-spacing:-.03em; }
.detail-section { margin:0 0 14px; }
.detail-section > summary { cursor:pointer; user-select:none; border:1px solid var(--line); border-radius:18px; padding:14px 16px; margin-bottom:12px; background:rgba(255,255,255,.055); color:#dce8ff; font-weight:900; letter-spacing:.02em; }
.detail-section[open] > summary { border-color:rgba(142,184,255,.25); background:rgba(142,184,255,.09); }
body.beginner-mode .detail-section:not(.proof-details) { opacity:.96; }
body.beginner-mode .detail-section > summary::after { content:"  · tap to expand/collapse"; color:var(--muted); font-weight:700; font-size:12px; }
body.beginner-mode .smart-auto-card .candidate-row { display:none; }
body.beginner-mode .smart-auto-card { padding:14px 16px; }
body.beginner-mode .smart-auto-card h2 { font-size:20px; }
body.beginner-mode .primary-details { grid-template-columns:1fr; }
body.beginner-mode .primary-details article:nth-child(3) { display:none; }
body.beginner-mode .trust-grid article:nth-child(n+2) { display:none; }
.guide-modal { position:fixed; inset:0; display:none; z-index:2000; }
.guide-modal.show { display:block; }
.guide-backdrop { position:absolute; inset:0; background:rgba(2,6,18,.72); backdrop-filter: blur(4px); }
.guide-panel { position:relative; width:min(860px, calc(100vw - 24px)); max-height:calc(100vh - 32px); overflow:auto; margin:16px auto; padding:20px; border-radius:24px; border:1px solid rgba(142,184,255,.28); background:linear-gradient(180deg,rgba(18,28,54,.98),rgba(9,14,28,.98)); box-shadow:0 28px 90px rgba(0,0,0,.58); }
.icon-btn { width:42px; height:42px; min-width:42px; padding:0; border-radius:999px; font-size:24px; line-height:1; background:rgba(255,255,255,.08); }
.guide-content { display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px; }
.guide-block, .guide-warning { border:1px solid var(--line); background:rgba(255,255,255,.05); border-radius:17px; padding:13px; line-height:1.5; }
.guide-block p { color:var(--muted); margin:.35rem 0 0; }
.guide-warning { grid-column:1/-1; border-color:rgba(255,209,102,.35); background:rgba(255,209,102,.08); color:#fff7d8; }
@media (max-width: 780px) { .top-actions { justify-content:flex-start; } .summary-grid, .guide-content { grid-template-columns:1fr; } .summary-grid div { min-height:70px; } }

.analyst-brief-card { border-color: rgba(0, 209, 255, .28); background: linear-gradient(145deg, rgba(0,209,255,.10), rgba(94,240,173,.08)), var(--panel); }

/* Scenario tone: subtle visual cue for bullish / bearish / neutral context. */
body.scenario-bullish .top-summary-card,
body.scenario-bullish .analyst-brief-card {
  border-color: rgba(94, 240, 173, .42);
  box-shadow: 0 0 0 1px rgba(94,240,173,.08), 0 20px 70px rgba(94,240,173,.10);
}
body.scenario-bearish .top-summary-card,
body.scenario-bearish .analyst-brief-card {
  border-color: rgba(255, 111, 133, .42);
  box-shadow: 0 0 0 1px rgba(255,111,133,.08), 0 20px 70px rgba(255,111,133,.10);
}
body.scenario-neutral .top-summary-card,
body.scenario-neutral .analyst-brief-card {
  border-color: rgba(255, 209, 102, .34);
  box-shadow: 0 0 0 1px rgba(255,209,102,.06), 0 20px 70px rgba(255,209,102,.07);
}
body.scenario-bullish #summaryScenario,
body.scenario-bullish #marketBias { color: #88ffd0; }
body.scenario-bearish #summaryScenario,
body.scenario-bearish #marketBias { color: #ff9aad; }
body.scenario-neutral #summaryScenario,
body.scenario-neutral #marketBias { color: #ffe29a; }
.brief-verdict { margin: 10px 0 14px; padding: 13px 14px; border-radius: 16px; background: rgba(255,255,255,.06); border: 1px solid rgba(142,184,255,.18); color: #eff7ff; font-weight: 850; line-height: 1.45; }
.brief-columns { display:grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.brief-columns > div { border:1px solid var(--line); border-radius:16px; padding:13px; background: rgba(255,255,255,.045); }
.brief-columns h3 { margin:0 0 8px; font-size:12px; letter-spacing:.09em; text-transform:uppercase; color:#9fd8ff; }
.brief-columns ul { margin:0; padding-left: 18px; color: var(--muted); line-height:1.45; }
.brief-columns li { margin: 0 0 7px; }
body.beginner-mode .analyst-brief-card .brief-columns { grid-template-columns:1fr; }
body.beginner-mode .analyst-brief-card .brief-columns > div:nth-child(n+2) { display:none; }
@media (max-width: 900px) { .brief-columns { grid-template-columns: 1fr; } }
.what-changed-card { border-left: 4px solid rgba(45, 212, 191, 0.55); }
.compact-list { margin: 8px 0 0; padding-left: 18px; display: grid; gap: 6px; }
.compact-list li { line-height: 1.45; color: var(--text); }
#changedBadge.stable { background: rgba(94, 240, 173, 0.10); color: #189a68; }
#changedBadge.attention { background: rgba(255, 209, 102, 0.16); color: #a36f00; }
.proof-mini-grid { display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 10px; margin: 8px 0; }
.proof-mini-grid .proof-tile { border: 1px solid rgba(120, 140, 180, .18); border-radius: 14px; padding: 10px 12px; background: rgba(255,255,255,.45); }
.proof-tile span { display:block; font-size: .72rem; color: var(--muted); text-transform: uppercase; letter-spacing:.04em; }
.proof-tile strong { font-size: 1.05rem; }
@media (max-width: 760px) { .proof-mini-grid { grid-template-columns: 1fr; } }

/* v3.0 RC — mobile polish, contrast and Smart Analyst layout */
:root {
  --text: #f8fbff;
  --muted: #c4d1ea;
  --line: rgba(255,255,255,.16);
  --panel: #10192f;
  --panel-2: #172343;
}
.card { padding: 16px; }
.card h2 { color: var(--text); line-height: 1.12; }
.item strong, .text-box strong, .summary-grid strong, .metric-grid strong { color: #ffffff; }
.item span, .tiny, .mini-note, .interpretation, .subline, .brief-columns ul { color: var(--muted); }
label span, .metric-grid span, .summary-grid span, .proof-tile span { color: #b8c8e6; }
.hero-analyst-card { border-color: rgba(94,240,173,.34); box-shadow: 0 22px 70px rgba(0,0,0,.38); }
.hero-note { margin: 4px 0 0; max-width: 740px; }
.brief-snapshot { margin: 12px 0; }
.brief-snapshot div { min-height: 70px; background: rgba(4,10,22,.42); }
.compact-brief-columns > div { background: rgba(4,10,22,.36); }
.what-changed-card { background: linear-gradient(145deg, rgba(45,212,191,.10), rgba(142,184,255,.06)), var(--panel); }
.what-changed-card .compact-list li { font-weight: 750; }
.score-pill.stable { border-color: rgba(94,240,173,.28); color: #d8ffed; background: rgba(94,240,173,.12); }
.score-pill.attention { border-color: rgba(255,209,102,.38); color: #fff2c8; background: rgba(255,209,102,.14); }
.proof-header { display:flex; justify-content:space-between; gap:12px; align-items:flex-start; padding: 10px 0 12px; border-bottom:1px solid var(--line); }
.proof-header span { color: var(--muted); }
.maturity-badge { border-radius:999px; padding:7px 10px; font-weight:900; font-size:12px; white-space:nowrap; border:1px solid var(--line); }
.maturity-badge.good { color:#d8ffed; background:rgba(94,240,173,.12); border-color:rgba(94,240,173,.28); }
.maturity-badge.warn { color:#fff3c8; background:rgba(255,209,102,.14); border-color:rgba(255,209,102,.28); }
.maturity-badge.bad { color:#ffd7df; background:rgba(255,107,134,.12); border-color:rgba(255,107,134,.28); }
.proof-table { display:grid; gap:8px; margin-top:10px; }
.proof-row { display:grid; grid-template-columns: 1.15fr .75fr .5fr .65fr .65fr; gap:8px; align-items:center; padding:10px 12px; border:1px solid var(--line); border-radius:14px; background:rgba(255,255,255,.045); }
.proof-row span { color: var(--muted); font-size: 12px; }
.watch-grid { display:grid; grid-template-columns: repeat(2, minmax(0,1fr)); gap:10px; }
.watch-card { border:1px solid var(--line); border-radius:16px; padding:12px; background:rgba(255,255,255,.045); display:grid; gap:6px; }
.watch-card > div { display:flex; justify-content:space-between; gap:8px; }
.watch-card span, .watch-card small { color: var(--muted); }
.watch-card b { color:#fff; }
.watch-card.bull { border-color:rgba(94,240,173,.34); }
.watch-card.bear { border-color:rgba(255,107,134,.34); }
.watch-card.range { border-color:rgba(142,184,255,.22); }
.sr-only { position:absolute !important; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }
body.beginner-mode .analyst-brief-card .brief-verdict { font-size: 15px; }
body.beginner-mode .analyst-brief-card .brief-snapshot { grid-template-columns: repeat(2, minmax(0,1fr)); }
body.beginner-mode .analyst-brief-card .brief-columns > div:first-child { border-color: rgba(94,240,173,.22); }
body.beginner-mode .smart-auto-card { display:block; }
body.beginner-mode .smart-auto-card .candidate-row { display:none; }
body.beginner-mode .primary-details article:nth-child(3) { display:none; }
body.pro-mode .analyst-brief-card { position: relative; }

@media (max-width: 780px) {
  .app-shell { padding: 16px 10px 28px; }
  .card { padding: 14px; border-radius: 18px; }
  .controls-card { padding: 13px; }
  .summary-grid, body.beginner-mode .analyst-brief-card .brief-snapshot { grid-template-columns: 1fr; }
  .brief-columns { grid-template-columns: 1fr; }
  .proof-row { grid-template-columns: 1fr 1fr; }
  .watch-grid { grid-template-columns: 1fr; }
  .action-row { display:grid; grid-template-columns: 1fr 1fr; }
  .action-row .primary { grid-column: 1 / -1; }
  .chart { height: 320px; }
}

@media print {
  :root { --text:#101827; --muted:#374151; --panel:#ffffff; --line:rgba(17,24,39,.16); }
  body { background:#fff !important; color:#101827 !important; -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .card, .guide-block, .item, .proof-tile, .watch-card { background:#fff !important; color:#101827 !important; box-shadow:none !important; border-color:rgba(17,24,39,.14) !important; }
  .text-box, .item span, .tiny, .mini-note, .interpretation, label span, .summary-grid span, .brief-columns ul { color:#374151 !important; }
  h1,h2,strong,.metric-grid strong,.summary-grid strong { color:#111827 !important; }
  .chart { border-color:#d1d5db !important; }
  .status-pill, .score-pill, .chip, .legend { color:#111827 !important; background:#f9fafb !important; border-color:#d1d5db !important; }
}

.lang-select {
  border: 1px solid var(--line);
  background: rgba(255,255,255,.08);
  color: var(--text);
  border-radius: 999px;
  padding: 9px 12px;
  font-weight: 850;
  min-width: 72px;
}
.scenario-trigger-panel {
  margin-top: 12px;
  border: 1px solid rgba(94,240,173,.20);
  border-radius: 18px;
  padding: 14px;
  background: linear-gradient(135deg, rgba(94,240,173,.10), rgba(99,179,237,.07));
}
.scenario-trigger-panel h3 {
  margin: 0 0 10px;
  font-size: 12px;
  letter-spacing: .09em;
  text-transform: uppercase;
  color: #b9f5d3;
}
.scenario-trigger-panel ul { margin: 0; padding-left: 18px; color: var(--muted); line-height: 1.48; }
.scenario-trigger-panel li { margin-bottom: 8px; }
.scenario-trigger-panel .trigger-note { opacity: .82; font-size: 12px; }
body.rtl { direction: rtl; text-align: right; }
body.rtl .brief-columns ul,
body.rtl .scenario-trigger-panel ul,
body.rtl .compact-list,
body.rtl ul { padding-right: 18px; padding-left: 0; }
body.rtl .top-actions { justify-content: flex-start; }
body.rtl .score-row, body.rtl .legend-row, body.rtl .action-row { direction: rtl; }
body.rtl input, body.rtl select { text-align: right; }
@media print {
  .scenario-trigger-panel { background: #f8fff9 !important; border-color: #c9e8d2 !important; }
  .scenario-trigger-panel h3 { color: #111827 !important; }
}
@media (max-width: 780px) {
  .lang-select { min-width: 64px; }
  .scenario-trigger-panel { padding: 12px; }
}

/* Nexlore chart polish: compact controls and lightweight overlays */
.chart-tf-switch {
  display: flex;
  align-items: center;
  gap: 6px;
  overflow-x: auto;
  overflow-y: hidden;
  padding: 6px 2px 10px;
  margin: 8px 0 10px;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}
.chart-tf-switch button {
  width: auto !important;
  flex: 0 0 auto;
  min-width: 48px;
  padding: 7px 11px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
  color: var(--text);
}
.chart-tf-switch button.active {
  background: linear-gradient(135deg, rgba(94,240,173,.22), rgba(94,216,255,.18));
  border-color: rgba(94,240,173,.45);
  box-shadow: 0 0 0 2px rgba(94,240,173,.08) inset;
}
.chart-tf-switch button:hover,
.chart-tf-switch button:focus {
  border-color: rgba(142,184,255,.55);
}

.chart-tool-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: nowrap;
  overflow-x: auto;
  padding: 0 2px 10px;
  margin-top: -2px;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
}
.chart-tool, .chart-tool-btn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.045);
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
  padding: 7px 10px;
  white-space: nowrap;
}
.chart-tool input { width: 14px; height: 14px; accent-color: var(--good); }
.chart-tool-btn { cursor: pointer; color: var(--text); }
.chart-tool:hover, .chart-tool-btn:hover { border-color: rgba(142,184,255,.55); color: var(--text); }
body.chart-expanded .chart-card { position: fixed; inset: 12px; z-index: 50; overflow: auto; }
body.chart-expanded .chart { height: min(72vh, 760px); }
body.chart-expanded::after { content: ""; position: fixed; inset: 0; background: rgba(0,0,0,.72); z-index: 49; }
body.beginner-mode .chart-tool-row .pro-only { display: none !important; }

body.beginner-mode .key-levels-card .pro-only { display: none !important; }
body.beginner-mode #levelEvidenceBox,
body.beginner-mode #proDiagnosticsBox,
body.beginner-mode #dataSignalsBox,
body.beginner-mode #depthMapBox { display: none; }
@media print {
  .chart-tf-switch { display: flex !important; flex-wrap: nowrap !important; gap: 6px !important; }
  .chart-tf-switch button { width: auto !important; min-width: 42px !important; padding: 5px 9px !important; }
}

/* Chart clarity polish */
.chart-card .section-head { align-items: flex-start; }
.chart-help-text { max-width: 620px; }
.chart-tf-switch {
  width: 100%;
  max-width: 100%;
  border: 1px solid rgba(142,184,255,.13);
  background: rgba(255,255,255,.035);
  border-radius: 18px;
  padding: 7px;
  margin: 10px 0 8px;
  gap: 7px;
}
.chart-tf-switch button {
  min-width: 46px;
  height: 34px;
  padding: 0 12px;
  box-shadow: none;
}
.chart-tf-switch button.active {
  color: #08111f;
  background: linear-gradient(135deg, #9df8cf, #7edcff);
  border-color: transparent;
}
.chart-tool-row {
  width: 100%;
  max-width: 100%;
  border: 1px solid rgba(142,184,255,.10);
  background: rgba(255,255,255,.025);
  border-radius: 18px;
  padding: 7px;
  margin: 0 0 10px;
  display: flex;
  flex-wrap: wrap;
  overflow: visible;
  gap: 7px;
}
.chart-tool, .chart-tool-btn {
  min-height: 34px;
  padding: 7px 11px;
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  border-color: rgba(142,184,255,.16);
  color: #d8e4ff;
}
.chart-tool input { margin: 0; }
.chart-tool-btn { width: auto !important; min-width: 92px; justify-content: center; }
#chartResetBtn::before { content: "↺"; font-weight: 900; margin-right: 2px; }
#chartExpandBtn::before { content: "⤢"; font-weight: 900; margin-right: 2px; }
@media (max-width: 780px) {
  .chart-tf-switch { flex-wrap: nowrap; overflow-x: auto; }
  .chart-tf-switch button { min-width: 50px; }
  .chart-tool-row { overflow-x: visible; }
  .chart-tool, .chart-tool-btn { flex: 1 1 calc(50% - 8px); justify-content: center; min-width: 128px; }
  .chart-tool-row .pro-only { flex-basis: calc(50% - 8px); }
  .chart-help-text { font-size: 11px; }
}
@media (max-width: 430px) {
  .chart-tool, .chart-tool-btn { min-width: 100%; }
}
@media print {
  .chart-tf-switch, .chart-tool-row { border: 1px solid #e5e7eb !important; background: #fff !important; }
  .chart-tool, .chart-tool-btn { border-color: #d1d5db !important; color: #111827 !important; background: #fff !important; }
}

.bias-scale-note{margin-top:.35rem;color:var(--muted);font-size:.78rem;line-height:1.35}
.hero-analyst-card .bias-scale-note{margin:.35rem 0 .55rem}

.events-scroll {
  max-height: 340px;
  overflow-y: auto;
  overscroll-behavior: contain;
  padding-right: 6px;
  margin-top: 4px;
  border-radius: 14px;
}
.events-scroll.mini { max-height: 260px; }
.events-scroll::-webkit-scrollbar { width: 7px; }
.events-scroll::-webkit-scrollbar-track { background: rgba(255,255,255,.04); border-radius: 999px; }
.events-scroll::-webkit-scrollbar-thumb { background: rgba(142,184,255,.35); border-radius: 999px; }
.event-item { scroll-margin-top: 8px; }
.event-matrix {
  margin-top: 10px;
  border: 1px solid rgba(142,184,255,.16);
  border-radius: 16px;
  background: rgba(255,255,255,.035);
  overflow: hidden;
}
.event-matrix > summary {
  cursor: pointer;
  user-select: none;
  padding: 11px 12px;
  color: #dce8ff;
  font-weight: 900;
}
.event-matrix[open] > summary { border-bottom: 1px solid var(--line); }
.calendar-meta { margin-top: 8px; }
body.beginner-mode .events-scroll { max-height: 260px; }
@media (max-width: 520px) {
  .events-scroll { max-height: 300px; }
  body.beginner-mode .events-scroll { max-height: 230px; }
}


.chart { position: relative; min-height: 300px; }
.chart-lite-note {
  position: absolute; z-index: 2; top: 10px; left: 10px; right: 10px;
  width: auto; display: inline-flex; max-width: calc(100% - 20px);
  padding: 7px 10px; border-radius: 999px;
  border: 1px solid rgba(142,184,255,.16);
  background: rgba(8,13,24,.72); backdrop-filter: blur(8px);
  color: #9aa8c7; font-size: 11px; font-weight: 800;
}
.simple-chart-canvas { display: block; width: 100%; height: 100%; border-radius: inherit; }
@media (max-width: 780px) {
  .chart-card { padding: 14px; }
  .chart-card .section-head { gap: 8px; }
  .chart-card h2 { font-size: 22px; margin-bottom: 6px; }
  .chart-help-text { line-height: 1.35; }
  .chart { height: 310px; border-radius: 18px; }
  .chart-tf-switch { gap: 6px; padding: 6px; border-radius: 16px; }
  .chart-tf-switch button { min-width: 48px; height: 32px; font-size: 12px; padding: 0 10px; }
  .chart-tool-row { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 7px; padding: 7px; border-radius: 16px; }
  .chart-tool, .chart-tool-btn, .chart-tool-row .pro-only { width: 100% !important; min-width: 0 !important; flex: unset !important; justify-content: center; padding: 8px 9px; font-size: 12px; }
  body.beginner-mode .chart-tool-row { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 430px) {
  .chart-tool, .chart-tool-btn { min-width: 0 !important; }
  .chart { height: 300px; }
}


@media (max-width: 780px) {
  .chart-card { padding: 13px; }
  .chart-card .section-head { align-items: flex-start; }
  .chart-card h2 { font-size: 21px; line-height: 1.12; }
  .chart-help-text { font-size: 11px; line-height: 1.35; }
  .chart-tf-switch {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    gap: 6px !important;
    padding: 6px !important;
    margin: 8px 0 !important;
    border-radius: 16px !important;
    scroll-snap-type: x proximity;
  }
  .chart-tf-switch button {
    flex: 0 0 auto !important;
    min-width: 48px !important;
    width: auto !important;
    height: 32px !important;
    padding: 0 10px !important;
    font-size: 12px !important;
    scroll-snap-align: start;
  }
  .chart-tool-row {
    display: flex !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    gap: 6px !important;
    padding: 6px !important;
    margin: 0 0 8px !important;
    border-radius: 16px !important;
    -webkit-overflow-scrolling: touch;
  }
  .chart-tool, .chart-tool-btn, .chart-tool-row .pro-only {
    flex: 0 0 auto !important;
    width: auto !important;
    min-width: auto !important;
    min-height: 32px !important;
    padding: 7px 10px !important;
    font-size: 12px !important;
    white-space: nowrap !important;
    justify-content: center !important;
  }
  .chart-tool input { width: 13px !important; height: 13px !important; }
  .chart { height: 300px !important; border-radius: 18px; }
  .legend-row { gap: 6px; overflow-x: auto; flex-wrap: nowrap; padding-bottom: 2px; }
  .legend { flex: 0 0 auto; font-size: 11px; padding: 7px 9px; }
}
@media (max-width: 430px) {
  .chart-tool, .chart-tool-btn { min-width: auto !important; }
  .chart { height: 285px !important; }
}

body.pre-analysis #whatChangedCard,
body.pre-analysis #smartAutoCard,
body.pre-analysis .chart-card,
body.pre-analysis .cards-grid,
body.pre-analysis .primary-details,
body.pre-analysis .detail-section {
  display: none !important;
}
body.pre-analysis .hero-analyst-card {
  margin-bottom: 18px;
}
body.pre-analysis .brief-snapshot,
body.pre-analysis .brief-columns,
body.pre-analysis #briefTriggerPanel,
body.pre-analysis #briefBiasScale,
body.pre-analysis #briefDataQuality {
  display: none !important;
}
body.pre-analysis #summaryReason::after {
  content: " Pick a market, then tap Analyze market to load the scenario, chart, event risk and key levels.";
}
.chart-options {
  border: 1px solid rgba(142,184,255,.12);
  background: rgba(255,255,255,.025);
  border-radius: 18px;
  margin: 0 0 10px;
  overflow: hidden;
}
.chart-options > summary {
  cursor: pointer;
  user-select: none;
  list-style: none;
  padding: 10px 12px;
  color: #d8e4ff;
  font-size: 13px;
  font-weight: 900;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.chart-options > summary::-webkit-details-marker { display:none; }
.chart-options > summary::after { content: "▾"; opacity: .75; transition: transform .18s ease; }
.chart-options[open] > summary::after { transform: rotate(180deg); }
.chart-options .chart-tool-row { border: 0 !important; border-top: 1px solid rgba(142,184,255,.10); margin: 0 !important; border-radius: 0 !important; background: transparent !important; }
.chart.chart-empty {
  height: auto !important;
  min-height: 168px !important;
  display: grid;
  place-items: center;
  padding: 18px;
}
.chart-empty-state {
  width: 100%;
  border: 1px solid rgba(142,184,255,.18);
  background: linear-gradient(145deg, rgba(142,184,255,.08), rgba(94,240,173,.04));
  border-radius: 18px;
  padding: 16px;
  color: var(--muted);
  line-height: 1.45;
}
.chart-empty-state strong { display:block; color: var(--text); font-size: 1.02rem; margin-bottom: 6px; }
.chart-empty-state span { display:block; }
.chart-empty-state small { display:block; margin-top: 10px; color: rgba(196,209,234,.78); }
.analysis-warning-card {
  border: 1px solid rgba(255,209,102,.22);
  background: rgba(255,209,102,.08);
  border-radius: 16px;
  padding: 12px 13px;
  color: #fff0c2;
  line-height: 1.45;
  margin-top: 10px;
  font-weight: 800;
}
@media (max-width: 780px) {
  .controls-card { padding-bottom: 14px; }
  .action-row { gap: 8px; }
  .action-row .secondary { min-height: 46px; }
  .chart-tf-switch { margin-bottom: 8px !important; }
  .chart-options > summary { min-height: 42px; }
  .chart-options:not([open]) { margin-bottom: 8px; }
  .chart-options .chart-tool-row { max-height: 124px; overflow-x: auto !important; }
}

/* --------------------------------------------------------------------------
   Feedback panel and secondary help actions
   -------------------------------------------------------------------------- */
.feedback-btn {
  width: auto;
  min-width: 92px;
  border-radius: 999px;
  padding: 9px 13px;
  background: rgba(94, 216, 255, .08);
  border-color: rgba(94, 216, 255, .28);
  color: #d9f8ff;
}

.feedback-panel {
  position: relative;
  display: none;
  max-width: 980px;
  margin: 0 auto 18px;
  padding: 18px;
  border: 1px solid rgba(94, 216, 255, .20);
  border-radius: 24px;
  background: linear-gradient(180deg, rgba(17, 31, 59, .86), rgba(10, 18, 36, .88));
  box-shadow: 0 18px 60px rgba(0, 0, 0, .28);
}

.feedback-panel.show {
  display: block;
}

.feedback-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  min-width: 36px;
  padding: 0;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: #eef4ff;
  font-size: 20px;
  line-height: 1;
}

.feedback-close:hover,
.feedback-close:focus {
  border-color: rgba(110, 231, 255, .44);
  background: rgba(110, 231, 255, .075);
}

.feedback-head {
  margin-bottom: 8px;
  padding-right: 46px;
}

.feedback-grid {
  display: grid;
  grid-template-columns: 1fr 160px;
  gap: 12px;
  margin: 12px 0;
}

.feedback-grid label,
.feedback-text-label {
  display: flex;
  flex-direction: column;
  gap: 7px;
  color: var(--muted);
  font-weight: 800;
  letter-spacing: .02em;
}

.feedback-panel select,
.feedback-panel textarea {
  width: 100%;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(255,255,255,.06);
  color: var(--text);
  padding: 12px 14px;
  outline: none;
}

.feedback-panel textarea {
  min-height: 104px;
  resize: vertical;
  line-height: 1.45;
}

.feedback-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 12px;
  flex-wrap: wrap;
}

.feedback-footer-btn,
.text-link {
  margin-top: 10px;
  border: 0;
  background: transparent;
  color: #8ee8ff;
  text-decoration: underline;
  cursor: pointer;
  font-weight: 800;
}

body.rtl .feedback-close {
  right: auto;
  left: 12px;
}

body.rtl .feedback-head {
  padding-right: 0;
  padding-left: 46px;
}

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

  .feedback-panel {
    padding: 16px;
  }

  .feedback-close {
    top: 10px;
    right: 10px;
    width: 34px;
    height: 34px;
    min-width: 34px;
  }

  body.rtl .feedback-close {
    right: auto;
    left: 10px;
  }
}

/* --------------------------------------------------------------------------
   Nexlore v1.2 — Final corrected premium hero/header
   Goal: compact utility chips in top corners, NX as visual focus,
   Feedback/Guide below safety badges, balanced navy + subtle teal background.
   -------------------------------------------------------------------------- */
:root {
  --nx-cyan: #78dceb;
  --nx-mint: #6be0bb;
  --nx-ice: #eaf9ff;
  --nx-navy-0: #060b18;
  --nx-navy-1: #07152a;
  --nx-navy-2: #0b1b34;
  --nx-glass: rgba(10, 20, 39, .56);
  --nx-glass-strong: rgba(12, 24, 45, .76);
  --nx-glass-line: rgba(178, 218, 255, .125);
}

body {
  background:
    radial-gradient(circle at 50% -6%, rgba(89, 183, 211, .205), transparent 35%),
    radial-gradient(circle at 13% 6%, rgba(86, 171, 245, .115), transparent 34%),
    radial-gradient(circle at 88% 2%, rgba(103, 216, 179, .095), transparent 32%),
    radial-gradient(circle at 50% 268px, rgba(86, 199, 191, .082), transparent 39%),
    linear-gradient(180deg, #0a1a31 0%, #08162c 44%, #060b19 100%) !important;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -2;
  background-image:
    linear-gradient(rgba(140, 220, 238, .038) 1px, transparent 1px),
    linear-gradient(90deg, rgba(140, 220, 238, .034) 1px, transparent 1px);
  background-size: 36px 36px;
  mask-image: radial-gradient(circle at top, rgba(0,0,0,.76), transparent 72%);
  -webkit-mask-image: radial-gradient(circle at top, rgba(0,0,0,.76), transparent 72%);
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;
  background:
    radial-gradient(circle at 50% 124px, rgba(123, 223, 240, .105), transparent 25%),
    radial-gradient(circle at 50% 350px, rgba(103, 216, 179, .050), transparent 36%),
    linear-gradient(180deg, rgba(255,255,255,.018), transparent 35%);
}

.app-shell {
  padding-top: max(12px, env(safe-area-inset-top)) !important;
}

.brand-hero {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  margin: 0 0 14px !important;
  padding: 50px 0 10px !important;
  text-align: center !important;
  overflow: visible !important;
}

.brand-hero .top-actions {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  transform: none !important;
  width: auto !important;
  max-width: none !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 8px !important;
  padding: 0 2px !important;
  margin: 0 !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  z-index: 20 !important;
}

.brand-hero .top-actions-right {
  display: flex !important;
  align-items: center !important;
  justify-content: flex-end !important;
  min-width: 0 !important;
}

/* Safety net: if an older index.html still has Feedback/Guide inside top-actions,
   do not let them appear above the logo. Replace index.html too so they appear below. */
.brand-hero .top-actions > #feedbackBtn,
.brand-hero .top-actions > #guideBtn {
  display: none !important;
}

.brand-hero .lang-select-wrap {
  position: relative !important;
  display: inline-flex !important;
  align-items: center !important;
  width: 88px !important;
  min-width: 88px !important;
  max-width: 88px !important;
  height: 30px !important;
  min-height: 30px !important;
  border-radius: 999px !important;
  border: 1px solid rgba(145, 184, 245, .17) !important;
  background: linear-gradient(180deg, rgba(20, 37, 68, .58), rgba(9, 19, 39, .42)) !important;
  box-shadow: 0 8px 19px rgba(0, 0, 0, .14), inset 0 1px 0 rgba(255,255,255,.055) !important;
  overflow: hidden !important;
}

.brand-hero .lang-icon {
  position: absolute !important;
  left: 10px !important;
  top: 50% !important;
  transform: translateY(-50%) !important;
  width: 13px !important;
  height: 13px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  color: rgba(181, 226, 237, .78) !important;
  opacity: .92 !important;
  pointer-events: none !important;
}

.brand-hero .lang-icon svg {
  width: 100% !important;
  height: 100% !important;
  stroke: currentColor !important;
  fill: none !important;
  stroke-width: 1.7 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.brand-hero .lang-select-wrap::after {
  content: "" !important;
  position: absolute !important;
  right: 12px !important;
  top: 50% !important;
  width: 7px !important;
  height: 7px !important;
  border-right: 1.8px solid rgba(236, 245, 255, .88) !important;
  border-bottom: 1.8px solid rgba(236, 245, 255, .88) !important;
  transform: translateY(-62%) rotate(45deg) !important;
  pointer-events: none !important;
  opacity: .95 !important;
}

.brand-hero .lang-select,
.brand-hero .status-pill {
  height: 30px !important;
  min-height: 30px !important;
  margin: 0 !important;
  border-radius: 999px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  line-height: 1 !important;
  font-size: 10.7px !important;
  font-weight: 900 !important;
  letter-spacing: .01em !important;
  box-shadow: 0 8px 19px rgba(0, 0, 0, .14), inset 0 1px 0 rgba(255,255,255,.055) !important;
}

.brand-hero .lang-select {
  appearance: none !important;
  -webkit-appearance: none !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;
  padding: 0 28px 0 28px !important;
  justify-content: flex-start !important;
  color: rgba(246, 250, 255, .94) !important;
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
  position: relative !important;
  z-index: 1 !important;
}

.brand-hero .status-pill {
  width: auto !important;
  min-width: 108px !important;
  max-width: 138px !important;
  padding: 0 12px !important;
  color: #94edcb !important;
  border: 1px solid rgba(103, 216, 179, .24) !important;
  background: linear-gradient(180deg, rgba(24, 68, 72, .28), rgba(8, 30, 45, .28)) !important;
  box-shadow: 0 8px 19px rgba(0,0,0,.13), 0 0 14px rgba(103,216,179,.045), inset 0 1px 0 rgba(255,255,255,.055) !important;
}

.brand-hero .status-pill.ok {
  color: #95f3ce !important;
  border-color: rgba(103, 216, 179, .32) !important;
}

.brand-hero .status-pill.bad {
  color: rgba(255, 214, 130, .92) !important;
  border-color: rgba(255, 209, 102, .22) !important;
  background: linear-gradient(180deg, rgba(80, 56, 20, .24), rgba(29, 26, 24, .25)) !important;
}

.brand-hero .brand-center {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 0 !important;
  max-width: 680px !important;
  margin: 0 auto !important;
  padding: 0 12px !important;
}

.brand-logo {
  position: relative !important;
  width: 88px !important;
  height: 88px !important;
  margin: 0 auto 16px !important;
  border-radius: 30px !important;
  display: grid !important;
  place-items: center !important;
  overflow: hidden !important;
  isolation: isolate !important;
  background:
    radial-gradient(circle at 22% 13%, rgba(255,255,255,.52), transparent 27%),
    radial-gradient(circle at 76% 82%, rgba(128, 190, 255, .32), transparent 39%),
    linear-gradient(145deg, rgba(199, 255, 242, .98) 0%, rgba(108, 228, 181, .92) 53%, rgba(139, 205, 242, .92) 100%) !important;
  border: 1px solid rgba(218, 252, 255, .50) !important;
  box-shadow:
    inset 0 2px 8px rgba(255,255,255,.34),
    inset 0 -14px 22px rgba(22, 99, 137, .13),
    0 0 0 1px rgba(123,223,240,.090),
    0 0 28px rgba(123,223,240,.19),
    0 24px 58px rgba(0,0,0,.38) !important;
  transform: translateZ(0) !important;
}

.brand-logo::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  border-radius: inherit !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,.30), transparent 38%),
    radial-gradient(circle at 50% 48%, transparent 28%, rgba(0, 28, 43, .034) 29%, transparent 51%) !important;
  z-index: 0 !important;
  pointer-events: none !important;
}

.brand-logo::after {
  content: "" !important;
  position: absolute !important;
  inset: 21px !important;
  border-radius: 50% !important;
  border: 1px solid rgba(5, 16, 29, .14) !important;
  box-shadow: inset 0 1px 3px rgba(255,255,255,.22) !important;
  z-index: 1 !important;
  pointer-events: none !important;
}

.brand-logo span {
  position: relative !important;
  z-index: 2 !important;
  display: block !important;
  font-size: 30px !important;
  font-weight: 1000 !important;
  letter-spacing: -.08em !important;
  line-height: 1 !important;
  color: #06111f !important;
  text-shadow: 0 1px 0 rgba(255,255,255,.35), 0 8px 18px rgba(0, 35, 45, .12) !important;
}

.brand-hero .eyebrow {
  margin: 0 0 8px !important;
  color: rgba(177, 225, 237, .82) !important;
  font-size: 10.8px !important;
  font-weight: 950 !important;
  letter-spacing: .22em !important;
}

.brand-hero h1 {
  margin: 0 0 2px !important;
  font-size: clamp(43px, 11.5vw, 62px) !important;
  line-height: .98 !important;
  letter-spacing: -.055em !important;
  color: #f8fbff !important;
  text-shadow: 0 0 31px rgba(123, 223, 240, .095) !important;
}

.brand-safety-row {
  width: min(100%, 520px) !important;
  margin: 16px auto 0 !important;
  padding: 10px !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
  border: 1px solid rgba(178, 218, 255, .135) !important;
  border-radius: 22px !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.052), rgba(255,255,255,.022)),
    rgba(8, 18, 36, .54) !important;
  box-shadow: 0 20px 54px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.047) !important;
  backdrop-filter: blur(16px) saturate(116%) !important;
  -webkit-backdrop-filter: blur(16px) saturate(116%) !important;
}

.brand-safety-row span,
.brand-safety-row .brand-safety-main,
.brand-safety-row .brand-advice-badge {
  width: 100% !important;
  min-width: 0 !important;
  margin: 0 !important;
  padding: 9px 11px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1.28 !important;
  text-align: center !important;
  color: #e8f3fb !important;
  background: rgba(255,255,255,.033) !important;
  border: 1px solid rgba(255,255,255,.068) !important;
  box-shadow: none !important;
}

.brand-safety-row .brand-safety-main::before,
.brand-safety-row .brand-advice-badge::before {
  content: "✓" !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 18px !important;
  height: 18px !important;
  min-width: 18px !important;
  border-radius: 999px !important;
  color: #04131d !important;
  background: linear-gradient(135deg, rgba(123,223,240,.90), rgba(103,216,179,.86)) !important;
  font-size: 12px !important;
  font-weight: 1000 !important;
}

.brand-safety-row .brand-advice-badge {
  color: #f6eccd !important;
  background: rgba(255, 209, 102, .030) !important;
  border-color: rgba(255, 209, 102, .105) !important;
}

.brand-safety-row .brand-advice-badge::before {
  color: #211704 !important;
  background: linear-gradient(135deg, rgba(255, 221, 132, .70), rgba(123, 223, 240, .42)) !important;
}

.hero-secondary-actions {
  margin: 13px auto 0 !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
}

.brand-hero .hero-secondary-actions .feedback-btn,
.brand-hero .hero-secondary-actions .guide-btn {
  position: static !important;
  grid-area: auto !important;
  width: auto !important;
  min-width: 92px !important;
  max-width: none !important;
  height: 33px !important;
  min-height: 33px !important;
  margin: 0 !important;
  padding: 0 14px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 999px !important;
  color: rgba(229, 242, 252, .78) !important;
  background: rgba(255, 255, 255, .026) !important;
  border: 1px solid rgba(178, 218, 255, .110) !important;
  box-shadow: none !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  line-height: 1 !important;
  letter-spacing: .01em !important;
}

.brand-hero .hero-secondary-actions .feedback-btn:hover,
.brand-hero .hero-secondary-actions .feedback-btn:focus,
.brand-hero .hero-secondary-actions .guide-btn:hover,
.brand-hero .hero-secondary-actions .guide-btn:focus,
.brand-hero .lang-select:focus,
.brand-hero .lang-select-wrap:focus-within {
  border-color: rgba(123, 223, 240, .33) !important;
  background: rgba(123, 223, 240, .052) !important;
  box-shadow: 0 0 0 3px rgba(123, 223, 240, .068) !important;
}

.controls-card {
  border-color: rgba(178, 218, 255, .12) !important;
  background:
    linear-gradient(180deg, rgba(255,255,255,.046), rgba(255,255,255,.020)),
    rgba(12, 22, 42, .88) !important;
}

@media (min-width: 760px) {
  .brand-safety-row {
    grid-template-columns: minmax(0, 1.35fr) minmax(178px, .65fr) !important;
    align-items: center !important;
  }
}

@media (max-width: 900px) {
  .brand-hero {
    padding-top: 46px !important;
    margin-bottom: 12px !important;
  }

  .brand-hero .top-actions {
    top: 0 !important;
    padding: 0 0 !important;
  }

  .brand-hero .lang-select,
  .brand-hero .status-pill {
    height: 30px !important;
    min-height: 30px !important;
    font-size: 10.6px !important;
  }

  .brand-hero .lang-select-wrap {
    width: 86px !important;
    min-width: 86px !important;
    max-width: 86px !important;
  }

  .brand-hero .lang-select {
    padding-inline-start: 28px !important;
    padding-inline-end: 26px !important;
  }

  .brand-hero .status-pill {
    min-width: 106px !important;
    max-width: 136px !important;
    padding: 0 11px !important;
  }

  .brand-logo {
    width: 84px !important;
    height: 84px !important;
    border-radius: 28px !important;
    margin-bottom: 13px !important;
  }

  .brand-logo::after {
    inset: 20px !important;
  }

  .brand-logo span {
    font-size: 28px !important;
  }

  .brand-hero .eyebrow {
    font-size: 10px !important;
    letter-spacing: .20em !important;
  }

  .brand-hero h1 {
    font-size: clamp(42px, 13vw, 58px) !important;
  }

  .brand-safety-row {
    width: min(100%, 510px) !important;
    margin-top: 16px !important;
    padding: 10px !important;
    border-radius: 20px !important;
  }

  .brand-safety-row span,
  .brand-safety-row .brand-safety-main,
  .brand-safety-row .brand-advice-badge {
    white-space: normal !important;
    padding: 8px 10px !important;
    font-size: 11.5px !important;
  }

  .brand-hero .hero-secondary-actions .feedback-btn,
  .brand-hero .hero-secondary-actions .guide-btn {
    min-width: 88px !important;
    height: 32px !important;
    min-height: 32px !important;
    padding: 0 13px !important;
    font-size: 11.7px !important;
  }
}

@media (max-width: 390px) {
  .brand-hero .lang-select-wrap {
    width: 82px !important;
    min-width: 82px !important;
    max-width: 82px !important;
  }

  .brand-hero .lang-select {
    padding-inline-start: 27px !important;
    padding-inline-end: 24px !important;
  }

  .brand-hero .status-pill {
    min-width: 102px !important;
    max-width: 132px !important;
    font-size: 10.4px !important;
  }

  .brand-safety-row span,
  .brand-safety-row .brand-safety-main,
  .brand-safety-row .brand-advice-badge {
    font-size: 11px !important;
  }
}

/* Nexlore legal footer: start */
.nexlore-legal-footer {
  width: min(100%, 640px);
  margin: 22px auto 28px;
  padding: 18px 18px 20px;
  border-radius: 22px;
  border: 1px solid rgba(178, 218, 255, .14);
  background:
    linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.020)),
    rgba(10, 19, 37, .70);
  box-shadow: 0 18px 52px rgba(0,0,0,.18), inset 0 1px 0 rgba(255,255,255,.045);
  backdrop-filter: blur(14px) saturate(112%);
  -webkit-backdrop-filter: blur(14px) saturate(112%);
  text-align: left;
}

.nexlore-legal-title {
  margin: 0 0 11px;
  color: rgba(184, 207, 238, .90);
  font-size: 12px;
  font-weight: 950;
  letter-spacing: .18em;
}

.nexlore-legal-links {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 18px;
}

.nexlore-legal-links a,
.nexlore-legal-link-button {
  color: #79dff3;
  text-decoration: none;
  font-size: 14px;
  font-weight: 850;
  line-height: 1.35;
}

.nexlore-legal-link-button {
  appearance: none;
  -webkit-appearance: none;
  width: auto;
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  cursor: pointer;
  font-family: inherit;
}

.nexlore-legal-links a:hover,
.nexlore-legal-links a:focus,
.nexlore-legal-link-button:hover,
.nexlore-legal-link-button:focus {
  color: #a7f3ff;
  text-decoration: underline;
}

.nexlore-legal-note {
  margin: 13px 0 0;
  color: rgba(196, 209, 234, .78);
  font-size: 12px;
  line-height: 1.5;
}

body.rtl .nexlore-legal-footer {
  text-align: right;
}

@media (max-width: 560px) {
  .nexlore-legal-footer {
    margin-top: 18px;
    padding: 16px;
    border-radius: 20px;
  }
}
/* Nexlore legal footer: end */

/* Nexlore in-app legal viewer: start */
.nexlore-legal-viewer {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
  padding: max(14px, env(safe-area-inset-top)) 12px max(14px, env(safe-area-inset-bottom));
  background: rgba(3, 8, 18, .82);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

body.nexlore-legal-viewer-open {
  overflow: hidden;
}

body.nexlore-legal-viewer-open .nexlore-legal-viewer {
  display: flex;
  align-items: stretch;
  justify-content: center;
}

.nexlore-legal-viewer__panel {
  width: min(100%, 860px);
  min-height: 0;
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(178, 218, 255, .20);
  border-radius: 24px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.060), rgba(255,255,255,.020)),
    #0b1324;
  box-shadow: 0 28px 88px rgba(0,0,0,.42);
}

.nexlore-legal-viewer__bar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 14px 12px 18px;
  border-bottom: 1px solid rgba(178, 218, 255, .13);
  background: rgba(12, 23, 44, .92);
}

.nexlore-legal-viewer__eyebrow {
  margin: 0 0 4px;
  color: rgba(129, 219, 236, .82);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: .18em;
}

.nexlore-legal-viewer__bar h2 {
  margin: 0;
  color: rgba(245, 249, 255, .96);
  font-size: 18px;
  line-height: 1.2;
}

.nexlore-legal-viewer__close {
  width: 40px;
  height: 40px;
  min-width: 40px;
  padding: 0;
  border-radius: 999px;
  border: 1px solid rgba(178, 218, 255, .18);
  background: rgba(255,255,255,.040);
  color: rgba(245, 249, 255, .92);
  font-size: 26px;
  line-height: 1;
  box-shadow: none;
}

.nexlore-legal-viewer__close:hover,
.nexlore-legal-viewer__close:focus {
  border-color: rgba(123, 223, 240, .42);
  background: rgba(123, 223, 240, .075);
}

.nexlore-legal-viewer__frame {
  width: 100%;
  flex: 1 1 auto;
  min-height: 0;
  border: 0;
  background: #070d19;
}

@media (max-width: 560px) {
  .nexlore-legal-viewer {
    padding: max(10px, env(safe-area-inset-top)) 8px max(10px, env(safe-area-inset-bottom));
  }

  .nexlore-legal-viewer__panel {
    border-radius: 20px;
  }

  .nexlore-legal-viewer__bar {
    padding: 12px 10px 10px 14px;
  }

  .nexlore-legal-viewer__bar h2 {
    font-size: 16px;
  }

  .nexlore-legal-viewer__close {
    width: 38px;
    height: 38px;
    min-width: 38px;
  }
}
/* Nexlore in-app legal viewer: end */

/* Nexlore final brand icon + ads guard: start */
.brand-hero .brand-logo,
.brand-hero .hero-logo,
.brand-hero .nx-logo,
.brand-hero .nx-mark,
.hero .brand-logo,
.hero .hero-logo,
.hero .nx-logo,
.hero .nx-mark {
  background-image: url("./assets/brand/nexlore-icon.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  color: transparent !important;
  text-shadow: none !important;
  overflow: hidden !important;
}

.brand-hero .brand-logo *,
.brand-hero .hero-logo *,
.brand-hero .nx-logo *,
.brand-hero .nx-mark *,
.hero .brand-logo *,
.hero .hero-logo *,
.hero .nx-logo *,
.hero .nx-mark * {
  opacity: 0 !important;
}

html.nexlore-ads-blocked .ad-container,
html.nexlore-ads-blocked .admob-banner,
html.nexlore-ads-blocked #admobBanner,
html.nexlore-ads-blocked [data-ad],
html.nexlore-ads-blocked .ads-slot {
  display: none !important;
}
/* Nexlore final brand icon + ads guard: end */

/* Nexlore hero logo polish + legal logo sync: start */
.brand-hero .brand-logo,
.brand-hero .hero-logo,
.brand-hero .nx-logo,
.brand-hero .nx-mark,
.hero .brand-logo,
.hero .hero-logo,
.hero .nx-logo,
.hero .nx-mark {
  background-image: url("./assets/brand/nexlore-icon.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  color: transparent !important;
  text-shadow: none !important;
  overflow: hidden !important;
  transform: scale(1.07) !important;
  transform-origin: center center !important;
  box-shadow:
    0 18px 54px rgba(0,0,0,.24),
    0 0 32px rgba(84, 224, 255, .23),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
  filter:
    drop-shadow(0 0 10px rgba(88, 224, 255, .18))
    drop-shadow(0 16px 26px rgba(0, 0, 0, .18)) !important;
}

.brand-hero .brand-logo *,
.brand-hero .hero-logo *,
.brand-hero .nx-logo *,
.brand-hero .nx-mark *,
.hero .brand-logo *,
.hero .hero-logo *,
.hero .nx-logo *,
.hero .nx-mark * {
  opacity: 0 !important;
}

@media (max-width: 560px) {
  .brand-hero .brand-logo,
  .brand-hero .hero-logo,
  .brand-hero .nx-logo,
  .brand-hero .nx-mark,
  .hero .brand-logo,
  .hero .hero-logo,
  .hero .nx-logo,
  .hero .nx-mark {
    transform: scale(1.06) !important;
  }
}
/* Nexlore hero logo polish + legal logo sync: end */

/* Nexlore final brighter logo polish: start */
.brand-hero .brand-logo,
.brand-hero .hero-logo,
.brand-hero .nx-logo,
.brand-hero .nx-mark,
.hero .brand-logo,
.hero .hero-logo,
.hero .nx-logo,
.hero .nx-mark {
  background-image: url("./assets/brand/nexlore-icon.png") !important;
  background-size: cover !important;
  background-position: center !important;
  background-repeat: no-repeat !important;
  color: transparent !important;
  text-shadow: none !important;
  overflow: hidden !important;
  transform: scale(1.075) !important;
  transform-origin: center center !important;
  box-shadow:
    0 18px 56px rgba(0,0,0,.24),
    0 0 34px rgba(84, 228, 255, .26),
    inset 0 1px 0 rgba(255,255,255,.12) !important;
  filter:
    drop-shadow(0 0 12px rgba(88, 230, 255, .20))
    drop-shadow(0 16px 26px rgba(0, 0, 0, .18)) !important;
}

.brand-hero .brand-logo *,
.brand-hero .hero-logo *,
.brand-hero .nx-logo *,
.brand-hero .nx-mark *,
.hero .brand-logo *,
.hero .hero-logo *,
.hero .nx-logo *,
.hero .nx-mark * {
  opacity: 0 !important;
}

@media (max-width: 560px) {
  .brand-hero .brand-logo,
  .brand-hero .hero-logo,
  .brand-hero .nx-logo,
  .brand-hero .nx-mark,
  .hero .brand-logo,
  .hero .hero-logo,
  .hero .nx-logo,
  .hero .nx-mark {
    transform: scale(1.065) !important;
  }
}
/* Nexlore final brighter logo polish: end */

/* Nexlore toast above native AdMob banner: start */
/*
  Native AdMob banners are drawn over the Android WebView at the bottom.
  The app toast/snackbar must therefore sit above the banner, otherwise
  messages such as "Switched to Custom" or "Analysis completed" become hidden.
*/
:root {
  --nexlore-native-ad-banner-reserve: 78px;
  --nexlore-toast-above-ad-bottom: calc(var(--nexlore-native-ad-banner-reserve) + env(safe-area-inset-bottom, 0px) + 28px);
}

#toast,
.toast {
  z-index: 2147483000 !important;
}

@media (max-width: 780px) {
  #toast,
  .toast {
    bottom: var(--nexlore-toast-above-ad-bottom) !important;
    max-width: min(86vw, 420px) !important;
    text-align: center !important;
  }
}
/* Nexlore toast above native AdMob banner: end */
