:root {
  color-scheme: dark;
  --bg-primary: #0d1117;
  --bg-card: #161b22;
  --bg-card-hover: #1f2937;
  --accent: #00c896;
  --accent-warm: #f59e0b;
  --accent-danger: #ef4444;
  --text-primary: #f0f6fc;
  --text-secondary: #8b949e;
  --border: #30363d;
  --positive: #238636;
  --negative: #da3633;
  --neutral: #6e7681;
  --shadow: 0 1px 3px rgba(0,0,0,.3);
}

* { box-sizing: border-box; }
html { min-width: 320px; }
body {
  margin: 0;
  background: var(--bg-primary);
  color: var(--text-primary);
  font-family: "Cairo", Tahoma, Arial, sans-serif;
  line-height: 1.7;
}

button, input, select, textarea { font: inherit; }
button {
  border: 1px solid var(--border);
  background: var(--bg-card-hover);
  color: var(--text-primary);
  border-radius: 6px;
  padding: 10px 14px;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, transform .16s ease;
}
button:hover { border-color: var(--accent); background: #243244; }
button:active { transform: translateY(1px); }
h1, h2, h3, h4, p { margin-top: 0; }
small { color: var(--text-secondary); }

.app-shell {
  width: min(1680px, calc(100vw - 32px));
  margin: 0 auto;
  padding: 24px 0 40px;
}

.app-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 24px;
  align-items: center;
  padding-bottom: 18px;
  border-bottom: 1px solid var(--border);
}
.sia-eyebrow {
  margin: 0 0 4px;
  color: var(--accent);
  font-size: 13px;
  font-weight: 800;
}
h1 { margin-bottom: 4px; font-size: clamp(28px, 3vw, 42px); line-height: 1.25; }
.sia-title-block p:last-child { margin: 0; color: var(--text-secondary); }
.sia-header-actions { display: flex; gap: 10px; align-items: center; }
.status-pill {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 12px;
  border: 1px solid rgba(0,200,150,.4);
  border-radius: 999px;
  color: var(--accent);
  background: rgba(0,200,150,.08);
  font-weight: 800;
  white-space: nowrap;
}

.app-layout {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 24px;
  margin-top: 24px;
}
.app-sidebar {
  display: grid;
  gap: 16px;
  align-content: start;
  position: sticky;
  top: 16px;
}
.side-panel, .analysis-panel, .opportunity-radar, .sia-analysis-dashboard, .sia-section, .sia-sources, .sia-scenarios {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.side-panel { padding: 16px; }
.side-panel h2, .opportunity-radar h2 { margin-bottom: 12px; font-size: 17px; }
.quick-stock-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.quick-stock-grid button { min-height: 38px; padding: 8px; font-weight: 800; }
.quick-more { margin-top: 10px; }
.quick-more summary, .sia-details summary {
  cursor: pointer;
  color: var(--accent);
  font-weight: 900;
}
.quick-more .quick-stock-grid { margin-top: 8px; }
.market-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.market-list span {
  display: inline-flex;
  min-height: 34px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-secondary);
  background: rgba(255,255,255,.02);
  font-size: 13px;
  font-weight: 800;
}

.sia-list { display: grid; gap: 8px; }
.sia-list p { margin: 0; color: var(--text-secondary); }
.sia-list button {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  text-align: right;
}
.sia-side-head { display: flex; justify-content: space-between; gap: 8px; align-items: center; }
.sia-small-btn { padding: 7px 10px; font-size: 13px; }

.app-main { display: grid; gap: 16px; min-width: 0; }
.sia-two-column {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 20px;
  align-items: start;
}
.sia-action-rail {
  order: 2;
  position: sticky;
  top: 16px;
  display: grid;
  gap: 14px;
  min-width: 0;
}
.sia-workspace {
  order: 1;
  min-width: 0;
  display: grid;
  gap: 16px;
}
.analysis-panel { padding: 16px; }
.analysis-form { display: grid; gap: 16px; }
.form-section-title {
  margin: 0;
  font-size: 18px;
}
.form-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
label {
  display: grid;
  gap: 7px;
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 800;
}
input, select, textarea {
  width: 100%;
  min-width: 0;
  direction: rtl;
  text-align: right;
  border: 1px solid var(--border);
  border-radius: 4px;
  background: #0f1622;
  color: var(--text-primary);
  padding: 11px 12px;
  outline: none;
}
textarea { min-height: 96px; resize: vertical; line-height: 1.8; }
.optional-note textarea {
  min-height: 68px;
  background: #0d1320;
}
.optional-note-details {
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255,255,255,.02);
}
.optional-note-details summary {
  padding: 10px 12px;
  color: var(--text-primary);
  cursor: pointer;
  font-weight: 900;
}
.optional-note-details .optional-note {
  padding: 0 12px 12px;
}
.optional-note span {
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 700;
}
input:focus, select:focus, textarea:focus {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(0,200,150,.12);
}
.stock-combobox { position: relative; }
.stock-dropdown {
  position: absolute;
  z-index: 20;
  inset-inline: 0;
  top: calc(100% + 6px);
  max-height: 320px;
  overflow: auto;
  display: grid;
  gap: 4px;
  padding: 8px;
  background: #0f1622;
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: 0 18px 48px rgba(0,0,0,.38);
}
.hidden, [hidden] { display: none !important; }
.stock-option {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr) auto auto auto;
  gap: 10px;
  align-items: center;
  padding: 10px;
  border: 1px solid transparent;
  border-radius: 6px;
  cursor: pointer;
}
.stock-option:hover, .stock-option.active {
  background: var(--bg-card-hover);
  border-color: var(--accent);
}
.s-symbol { color: var(--accent); font-weight: 900; direction: ltr; text-align: left; }
.s-name { font-weight: 800; overflow-wrap: anywhere; }
.s-sector { color: var(--text-secondary); font-size: 13px; }
.risk-badge, .partial-badge {
  padding: 3px 7px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
}
.risk-badge { color: #fecaca; background: rgba(239,68,68,.16); }
.partial-badge { color: #fde68a; background: rgba(245,158,11,.16); }

.form-actions, .quick-questions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
}
.sia-primary {
  min-width: 180px;
  background: var(--accent);
  border-color: var(--accent);
  color: #001b14;
  font-weight: 900;
}
.sia-secondary, .sia-ghost { background: transparent; }
.quick-questions { margin-top: 14px; }
.quick-questions button { min-height: 38px; font-weight: 800; }

.ai-question-panel, .ai-answer-area, .ai-inline-answer-area, .starter-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: 8px;
  box-shadow: var(--shadow);
}
.ai-question-panel {
  display: grid;
  gap: 14px;
  padding: 16px;
  border-color: rgba(0,200,150,.42);
  background:
    linear-gradient(135deg, rgba(0,200,150,.13), rgba(22,27,34,.98) 44%),
    var(--bg-card);
}
.ai-question-head { display: grid; gap: 10px; }
.ai-question-head h2 {
  margin-bottom: 2px;
  font-size: 24px;
}
.ai-question-head p {
  margin: 0;
  color: var(--text-secondary);
}
#aiQuestionContext {
  max-width: 100%;
  padding: 8px 10px;
  border: 1px solid rgba(0,200,150,.32);
  border-radius: 999px;
  color: var(--accent);
  background: rgba(0,200,150,.08);
  font-size: 13px;
  font-weight: 900;
  overflow-wrap: anywhere;
}
.ai-question-box {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
  align-items: stretch;
}
.ai-question-box textarea {
  min-height: 112px;
  background: #0d1320;
}
.ai-question-box button {
  background: var(--accent);
  border-color: var(--accent);
  color: #001b14;
  font-weight: 900;
}
.ai-question-help {
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 800;
}
.ai-question-chips {
  display: grid;
  gap: 10px;
}
.ai-chip-group {
  display: grid;
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}
.ai-chip-group-title {
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 900;
}
.ai-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ai-answer-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ai-question-chips button, .ai-answer-actions button {
  min-height: 36px;
  padding: 8px 11px;
  font-weight: 800;
  color: var(--text-primary);
  background: rgba(255,255,255,.03);
}
.quick-radar-action { width: 100%; font-weight: 900; }
.ai-answer-area, .ai-inline-answer-area {
  padding: 0;
  border: 0;
  background: transparent;
}
.ai-inline-answer-area {
  margin-top: 12px;
  display: grid;
  gap: 12px;
}
.ai-inline-answer-area[hidden] {
  display: none;
}
.ai-answer-card {
  display: grid;
  gap: 14px;
  padding: 14px;
  border: 1px solid rgba(88,166,255,.35);
  border-radius: 10px;
  background: rgba(15,23,42,.96);
  box-shadow: var(--shadow);
}
.ai-answer-card h3 {
  margin: 0 0 8px;
  font-size: 20px;
}
.ai-answer-card p {
  margin-bottom: 0;
}
.ai-answer-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ai-answer-meta span {
  padding: 6px 9px;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-secondary);
  background: rgba(255,255,255,.02);
  font-size: 12px;
  font-weight: 800;
}
.ai-answer-body {
  display: grid;
  gap: 10px;
  color: var(--text-primary);
  overflow-wrap: anywhere;
}
.ai-direct-summary {
  padding: 12px;
  border: 1px solid rgba(0,200,150,.28);
  border-radius: 6px;
  background: rgba(0,200,150,.07);
  font-weight: 800;
}
.ai-answer-note {
  padding: 10px;
  border: 1px solid rgba(245,158,11,.34);
  border-radius: 6px;
  color: #fde68a;
  background: rgba(245,158,11,.08);
}
.deep-answer-section {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.deep-answer-section h4 {
  margin: 0;
  font-size: .98rem;
}
.deep-metric-list,
.deep-source-list {
  display: grid;
  gap: 8px;
  margin: 0;
  padding: 0;
  list-style: none;
}
.deep-metric-list li,
.deep-source-list li {
  display: grid;
  grid-template-columns: minmax(110px, 1fr) minmax(130px, 1.4fr);
  gap: 4px 10px;
  align-items: start;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
}
.deep-metric-list small,
.deep-source-list small {
  grid-column: 1 / -1;
  color: var(--text-secondary);
}
.ai-answer-body ul {
  margin: 10px 0 0;
  padding: 0 22px 0 0;
}
.ai-answer-sources {
  display: grid;
  gap: 8px;
}
.ai-answer-sources a, .ai-answer-sources > span {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-primary);
  text-decoration: none;
  background: rgba(255,255,255,.02);
}
.ai-answer-sources a span, .ai-answer-sources > span span {
  overflow-wrap: anywhere;
}
.ai-extra-sources {
  display: grid;
  gap: 8px;
}
.ai-extra-sources summary {
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--accent);
  cursor: pointer;
  font-weight: 900;
}
.ai-extra-sources[open] summary {
  margin-bottom: 8px;
}
.clarification-card {
  border-color: rgba(245,158,11,.42);
}
.starter-card {
  padding: 18px;
  border-style: dashed;
  color: var(--text-secondary);
}
.starter-card h2 {
  margin-bottom: 10px;
  color: var(--text-primary);
}
.starter-card div {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.starter-card p {
  margin: 0;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: rgba(255,255,255,.02);
}

.opportunity-radar { padding: 16px; }
.section-subtitle {
  margin: -6px 0 12px;
  color: var(--text-secondary);
}
.radar-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.radar-card {
  display: grid;
  gap: 4px;
  min-height: 88px;
  text-align: right;
  align-content: center;
}
.radar-card small { color: var(--accent); font-weight: 900; }
.radar-card b { font-size: 16px; }
.radar-card span { color: var(--text-secondary); font-size: 13px; }

.sia-loading {
  padding: 16px;
  border: 1px solid rgba(0,200,150,.35);
  background: rgba(0,200,150,.08);
  border-radius: 8px;
  color: var(--accent);
}
.sia-loading-title { font-weight: 900; margin-bottom: 8px; }
.sia-loading ol { display: flex; flex-wrap: wrap; gap: 8px 18px; margin: 0; padding: 0 20px 0 0; }
.sia-results { display: grid; gap: 16px; min-width: 0; }
.sia-message { min-width: 0; }

.sia-analysis-dashboard {
  display: grid;
  gap: 16px;
  padding: 16px;
}
.sia-result-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: start;
}
.sia-result-head strong { display: block; font-size: 22px; }
.sia-result-head span { color: var(--accent); direction: ltr; }
.sia-price { text-align: left; font-size: 26px; font-weight: 900; }
.pos { color: #3fb950; }
.neg { color: #ff7b72; }
.sia-decision-card {
  padding: 16px;
  border-radius: 8px;
  border: 1px solid rgba(0,200,150,.38);
  background: linear-gradient(135deg, rgba(0,200,150,.16), rgba(22,27,34,.98));
}
.sia-sniper-historical {
  border-color: rgba(245,158,11,.45);
  background: linear-gradient(135deg, rgba(245,158,11,.14), rgba(22,27,34,.98));
}
.sia-decision-card span { color: var(--accent); font-weight: 900; }
.sia-decision-card b { display: block; margin: 4px 0; font-size: 24px; }
.sia-decision-card p { margin-bottom: 5px; }
.financial-summary-card {
  display: grid;
  gap: 14px;
  padding: 18px;
  border: 1px solid rgba(0,200,150,.42);
  border-radius: 8px;
  background: linear-gradient(135deg, rgba(0,200,150,.18), rgba(15,22,34,.98));
}
.financial-strip-card {
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid rgba(88,166,255,.34);
  border-radius: 8px;
  background: #0f1622;
}
.financial-strip-card h3 {
  margin: 0;
  font-size: 18px;
}
.financial-strip-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 8px;
}
.financial-strip-grid > div {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(148,163,184,.18);
  border-radius: 8px;
  background: rgba(255,255,255,.025);
}
.financial-strip-grid span {
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 900;
}
.financial-strip-grid b {
  font-size: 14px;
  overflow-wrap: anywhere;
}
.financial-strip-grid small {
  color: var(--text-secondary);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.5;
  overflow-wrap: anywhere;
}
.summary-main span {
  color: var(--accent);
  font-size: 13px;
  font-weight: 900;
}
.summary-main h2 {
  margin: 4px 0;
  font-size: clamp(24px, 2.4vw, 34px);
}
.summary-main p {
  margin: 0;
  color: var(--text-primary);
  font-weight: 800;
  line-height: 1.7;
}
.summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.summary-grid > div {
  display: grid;
  gap: 4px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #0f1622;
  min-width: 0;
}
.summary-grid span {
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 900;
}
.summary-grid b {
  font-size: 18px;
  overflow-wrap: anywhere;
}
.summary-grid small {
  color: var(--text-secondary);
  font-weight: 800;
  overflow-wrap: anywhere;
}
.summary-grid.compact b { font-size: 15px; }
.financial-metrics-card summary,
.sia-nested-details summary,
.sia-details summary {
  cursor: pointer;
  color: var(--accent);
  font-weight: 900;
}
.sia-badges { display: flex; flex-wrap: wrap; gap: 8px; }
.sia-badges span {
  padding: 6px 9px;
  border: 1px solid var(--border);
  border-radius: 999px;
  color: var(--text-secondary);
  background: #0f1622;
  font-size: 12px;
  font-weight: 800;
}
.sia-kpi-grid, .sia-metrics-grid, .sia-levels, .sia-evidence-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.sia-kpi-grid > div, .sia-metrics-grid > div, .sia-levels > div, .sia-evidence-list > div {
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #0f1622;
}
.sia-kpi-grid span, .sia-metrics-grid span, .sia-levels span, .sia-evidence-list span {
  display: block;
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 900;
}
.sia-kpi-grid b, .sia-metrics-grid b, .sia-levels b { font-size: 18px; overflow-wrap: anywhere; }
.sia-section, .sia-sources, .sia-scenarios { padding: 16px; }
.sia-details {
  display: grid;
  gap: 12px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: rgba(255,255,255,.02);
}
.sia-details[open] summary { margin-bottom: 12px; }
.sia-analysis-main {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .75fr);
  gap: 16px;
}
.sia-ai-text { white-space: pre-wrap; overflow-wrap: anywhere; }
.sia-chart { width: 100%; min-height: 170px; }
.sia-volatility-box {
  margin-top: 12px;
  padding: 12px;
  border: 1px solid rgba(245,158,11,.45);
  border-radius: 8px;
  background: rgba(245,158,11,.08);
}
.sia-forecast-row {
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr) 54px;
  gap: 10px;
  align-items: center;
  margin: 10px 0;
}
.sia-progress {
  height: 10px;
  background: #0f1622;
  border-radius: 999px;
  overflow: hidden;
  border: 1px solid var(--border);
}
.sia-progress i { display: block; height: 100%; background: var(--accent); }
.sia-forecast-row.neg .sia-progress i { background: var(--accent-danger); }
.sia-forecast-row.mid .sia-progress i { background: var(--neutral); }
.sia-evidence-card { border-color: rgba(0,200,150,.34); background: rgba(0,200,150,.06); }
.sia-evidence-list p { margin: 0; font-size: 13px; }
.sia-evidence-list .wide { grid-column: span 2; }
.sia-evidence-list ol {
  margin: 0;
  padding: 0 18px 0 0;
  font-size: 13px;
}
.sia-evidence-sources, .sia-sources {
  display: grid;
  gap: 8px;
}
.sia-evidence-sources a, .sia-evidence-sources span, .sia-sources a, .sia-sources span {
  display: grid;
  gap: 3px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #0f1622;
  color: var(--text-primary);
  text-decoration: none;
  overflow-wrap: anywhere;
}
.sia-note {
  padding: 12px;
  border: 1px solid rgba(245,158,11,.36);
  border-radius: 8px;
  color: #fde68a;
  background: rgba(245,158,11,.08);
}
.radar-top-section h3 { margin-bottom: 12px; }
.radar-top-cards {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.radar-result-card, .radar-opportunity-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid rgba(0,200,150,.28);
  border-radius: 8px;
  background: #0f1622;
}
.radar-result-card header, .radar-opportunity-card header {
  display: grid;
  gap: 2px;
}
.radar-result-card header b, .radar-opportunity-card header b {
  color: var(--accent);
  font-size: 21px;
  direction: ltr;
  text-align: right;
}
.radar-result-card header span, .radar-opportunity-card header span {
  color: var(--text-secondary);
  overflow-wrap: anywhere;
}
.radar-result-card div, .radar-opportunity-card div {
  display: grid;
  gap: 2px;
}
.radar-result-card div span, .radar-opportunity-card div span {
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 900;
}
.radar-result-card p, .radar-opportunity-card p {
  margin: 0;
  color: var(--text-primary);
}
.radar-opportunity-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.sia-compare-table {
  max-width: 100%;
  overflow-x: auto;
}
.sia-compare-table table {
  width: 100%;
  border-collapse: collapse;
  min-width: 920px;
}
.sia-compare-table th, .sia-compare-table td {
  padding: 10px;
  border-bottom: 1px solid var(--border);
  vertical-align: top;
  text-align: right;
}
.sia-disclaimer {
  display: block;
  border-top: 1px solid var(--border);
  padding-top: 10px;
  color: var(--text-secondary);
}
.sia-error {
  padding: 16px;
  border-color: rgba(239,68,68,.45);
  color: #fecaca;
}
.sia-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(245,158,11,.4);
  border-radius: 8px;
  background: rgba(245,158,11,.08);
}

.sia-dialog {
  width: min(840px, calc(100vw - 28px));
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--bg-card);
  color: var(--text-primary);
  padding: 18px;
}
.sia-dialog::backdrop { background: rgba(0,0,0,.65); }
.sia-dialog pre {
  direction: ltr;
  text-align: left;
  overflow: auto;
  max-height: 62vh;
  background: #0f1622;
  color: var(--text-primary);
  padding: 12px;
  border-radius: 6px;
}
.sia-close { float: left; }

@media (max-width: 1120px) {
  .app-layout { grid-template-columns: 1fr; }
  .app-sidebar { position: static; grid-template-columns: repeat(3, minmax(0, 1fr)); }
  .radar-grid, .radar-top-cards, .sia-kpi-grid, .sia-metrics-grid, .sia-levels, .sia-evidence-list, .financial-strip-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .sia-two-column { grid-template-columns: 1fr; }
  .sia-action-rail { order: 1; position: static; }
  .sia-workspace { order: 2; }
  .ai-question-box { grid-template-columns: minmax(0, 1fr) 160px; }
}
@media (max-width: 820px) {
  .app-header, .form-row, .sia-analysis-main, .app-sidebar { grid-template-columns: 1fr; }
  .sia-header-actions { justify-content: space-between; }
  .radar-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .ai-question-head, .ai-question-box { display: grid; grid-template-columns: 1fr; }
  #aiQuestionContext { max-width: none; width: 100%; border-radius: 8px; }
  .starter-card div { grid-template-columns: 1fr; }
}
@media (max-width: 560px) {
  .app-shell { width: min(100% - 16px, 1680px); padding-top: 12px; }
  .quick-stock-grid, .radar-grid, .radar-top-cards, .radar-opportunity-grid, .sia-kpi-grid, .sia-metrics-grid, .sia-levels, .sia-evidence-list, .summary-grid, .financial-strip-grid { grid-template-columns: 1fr; }
  .sia-evidence-list .wide { grid-column: auto; }
  .stock-option { grid-template-columns: 72px minmax(0, 1fr); }
  .s-sector, .risk-badge, .partial-badge { grid-column: 1 / -1; }
  .sia-result-head, .form-actions { display: grid; }
  .sia-price { text-align: right; }
  .sia-forecast-row { grid-template-columns: 1fr; }
  .ai-question-panel, .analysis-panel, .opportunity-radar, .sia-analysis-dashboard { padding: 12px; }
  .ai-answer-meta, .ai-answer-actions { display: grid; grid-template-columns: 1fr; }
  .ai-answer-sources a, .ai-answer-sources > span { display: grid; }
}
.diagnostics-safe-grid {
  display: grid;
  gap: 10px;
  white-space: normal;
}
.diagnostics-safe-grid div {
  border: 1px solid rgba(148, 163, 184, .28);
  border-radius: 8px;
  padding: 10px;
  background: rgba(15, 23, 42, .04);
}
.diagnostics-safe-grid b,
.diagnostics-safe-grid span {
  display: block;
}
.diagnostics-safe-grid span {
  margin-top: 4px;
  color: var(--muted);
}
