*,
*::before,
*::after {
  box-sizing: border-box;
}

[hidden] {
  display: none !important;
}

:root {
  --bg: #f5f7fb;
  --panel: #ffffff;
  --sidebar: #101828;
  --sidebar-2: #172033;
  --text: #0f172a;
  --muted: #64748b;
  --line: #e5e7eb;
  --accent: #2563eb;
  --accent-2: #0f766e;
  --warn: #b45309;
  --danger: #b91c1c;
  --success: #047857;
  --shadow: 0 20px 50px rgba(15, 23, 42, 0.08);
}

html,
body {
  margin: 0;
  min-height: 100%;
  background:
    radial-gradient(circle at top left, rgba(37, 99, 235, 0.08), transparent 30%),
    linear-gradient(180deg, #f8fbff 0%, #f5f7fb 100%);
  color: var(--text);
  font-family: -apple-system, BlinkMacSystemFont, "PingFang SC", "Segoe UI", sans-serif;
}

button,
input,
select {
  font: inherit;
}

a {
  color: inherit;
  text-decoration: none;
}

.app-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
}

.sidebar {
  background: linear-gradient(180deg, var(--sidebar) 0%, var(--sidebar-2) 100%);
  color: #fff;
  padding: 24px 18px;
  display: flex;
  flex-direction: column;
  gap: 18px;
}

.brand {
  padding: 8px 6px 20px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

.brand-mark {
  font-size: 26px;
  font-weight: 800;
  letter-spacing: 0;
}

.brand-sub {
  margin-top: 4px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 12px;
}

.nav {
  display: grid;
  gap: 8px;
}

.nav-item {
  border: 1px solid transparent;
  background: transparent;
  color: rgba(255, 255, 255, 0.8);
  text-align: left;
  padding: 12px 14px;
  border-radius: 10px;
  cursor: pointer;
}

.nav-item.active,
.nav-item:hover {
  background: rgba(255, 255, 255, 0.08);
  color: #fff;
  border-color: rgba(255, 255, 255, 0.08);
}

.nav-item.locked::after {
  content: "Pro";
  float: right;
  font-size: 10px;
  font-weight: 900;
  color: #fde68a;
  border: 1px solid rgba(253, 230, 138, 0.28);
  border-radius: 999px;
  padding: 1px 6px;
}

.sidebar-card {
  margin-top: auto;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
  padding: 16px;
}

.sidebar-label {
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
}

.sidebar-value {
  margin-top: 6px;
  font-size: 15px;
  font-weight: 700;
}

.sidebar-hint {
  margin-top: 8px;
  font-size: 12px;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.66);
}

.sidebar-account-actions {
  display: grid;
  gap: 8px;
  margin-top: 14px;
}

.sidebar-btn {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 10px;
  background: #fff;
  color: #111827;
  padding: 12px 14px;
  cursor: pointer;
  font-weight: 700;
}

.sidebar-btn.secondary {
  background: transparent;
  color: #fff;
}

.sidebar-btn.danger {
  background: transparent;
  color: #fecaca;
  border-color: rgba(248, 113, 113, 0.35);
}

.sidebar-btn.danger:hover {
  background: rgba(248, 113, 113, 0.12);
}

.sidebar-link {
  display: block;
  text-align: center;
  font-size: 13px;
  color: rgba(255, 255, 255, 0.68);
}

.sidebar-account-actions .sidebar-btn,
.sidebar-account-actions .sidebar-link {
  width: 100%;
}

.main {
  padding: 26px;
  min-width: 0;
}

body.reader-open .main {
  padding: 10px 18px 18px;
}

body.reader-open .sidebar-link {
  display: none;
}

.hero {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-end;
  margin-bottom: 18px;
}

.eyebrow {
  font-size: 12px;
  font-weight: 800;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0;
  margin-bottom: 8px;
}

.hero h1 {
  margin: 0;
  font-size: clamp(30px, 4vw, 42px);
  line-height: 1.08;
}

.hero p {
  margin: 10px 0 0;
  color: var(--muted);
  font-size: 15px;
  max-width: 740px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.console-overview {
  display: grid;
  grid-template-columns: 1.15fr 1fr 1fr;
  gap: 12px;
}

.overview-search-card {
  grid-column: 1 / -1;
  background: linear-gradient(135deg, #eef5ff 0%, #ffffff 72%);
}

.overview-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 18px;
  background: #fff;
}

.overview-card.primary {
  background: linear-gradient(135deg, #eaf2ff 0%, #ffffff 72%);
  border-color: rgba(37, 99, 235, 0.16);
}

.overview-card .small-btn {
  margin-top: 12px;
}

.workflow-card {
  grid-column: 1 / -1;
}

.trust-card {
  grid-column: 1 / -1;
  background: #f8fafc;
}

.trust-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}

.trust-list div {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 12px;
}

.trust-list strong,
.trust-list span {
  display: block;
}

.trust-list strong {
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}

.trust-list span {
  margin-top: 7px;
  color: #475569;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.55;
}

.workflow-steps {
  margin-top: 14px;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 8px;
}

.workflow-steps span {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f8fafc;
  padding: 10px;
  color: #334155;
  font-size: 12px;
  line-height: 1.4;
}

.overview-label {
  color: var(--muted);
  font-size: 12px;
  font-weight: 700;
}

.overview-value {
  margin-top: 8px;
  font-size: 22px;
  font-weight: 900;
}

.overview-copy {
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  padding: 18px;
  margin-bottom: 16px;
}

.banner {
  display: flex;
  align-items: center;
  gap: 14px;
  background: linear-gradient(180deg, #fff 0%, #f8fbff 100%);
}

.banner-title {
  font-weight: 800;
  font-size: 18px;
}

.banner-desc,
.subnote {
  margin-top: 4px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.add-grid {
  display: grid;
  grid-template-columns: minmax(240px, 1.4fr) 120px auto;
  gap: 10px;
  align-items: center;
}

.text-input,
.select-input {
  width: 100%;
  border: 1px solid var(--line);
  background: #fff;
  border-radius: 12px;
  padding: 12px 14px;
  color: var(--text);
  outline: none;
}

.text-input.compact {
  min-width: 260px;
  padding: 11px 12px;
}

.text-input:focus,
.select-input:focus {
  border-color: rgba(37, 99, 235, 0.45);
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.08);
}

.action-btn {
  border: 1px solid rgba(37, 99, 235, 0.18);
  background: #fff;
  color: var(--accent);
  border-radius: 12px;
  padding: 12px 14px;
  cursor: pointer;
  font-weight: 800;
}

.action-btn.primary {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.action-btn.ghost {
  background: #fff;
}

.action-btn:disabled,
.sidebar-btn:disabled {
  opacity: 0.65;
  cursor: not-allowed;
}

.loading,
.empty {
  color: var(--muted);
  font-size: 14px;
}

.summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.summary-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
  background: linear-gradient(180deg, #fff 0%, #fbfdff 100%);
}

.summary-label {
  color: var(--muted);
  font-size: 12px;
}

.summary-value {
  margin-top: 8px;
  font-size: 24px;
  font-weight: 900;
}

.digest {
  margin-top: 12px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--line);
  border-radius: 999px;
  padding: 7px 10px;
  font-size: 12px;
  background: #fff;
}

.chip.up {
  color: var(--success);
  border-color: rgba(4, 120, 87, 0.18);
  background: rgba(4, 120, 87, 0.06);
}

.chip.down {
  color: var(--danger);
  border-color: rgba(185, 28, 28, 0.16);
  background: rgba(185, 28, 28, 0.06);
}

.controls {
  display: grid;
  grid-template-columns: minmax(240px, 1.3fr) 180px 180px auto auto auto;
  gap: 10px;
  align-items: center;
}

.controls .select-input,
.controls .text-input {
  min-width: 0;
}

.watchlist-head,
.events-head,
.workspace-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}

.workspace-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.review-subtabs {
  margin-bottom: 14px;
}

.search-home-card,
.insight-assistant-card {
  border: 1px solid rgba(37, 99, 235, 0.14);
  border-radius: 14px;
  background: linear-gradient(135deg, #eef5ff 0%, #ffffff 72%);
  padding: 22px;
  margin-bottom: 14px;
}

.search-home-head {
  max-width: 760px;
  margin: 0 auto 16px;
  text-align: center;
}

.search-home-head .section-title {
  font-size: 24px;
}

.search-home-head .count {
  margin-top: 7px;
  font-size: 14px;
}

.search-home-card .report-builder-grid {
  max-width: 1120px;
  margin: 0 auto;
}

.report-create-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-top: 14px;
}

.report-create-meta span {
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 999px;
  background: #fff;
  color: #1d4ed8;
  padding: 7px 10px;
  font-size: 12px;
  font-weight: 900;
}

.insight-assistant-card {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  align-items: center;
}

.attribute-search-card {
  background: linear-gradient(135deg, #f0fdfa 0%, #ffffff 72%);
}

.keyword-search-card {
  background: linear-gradient(135deg, #f5f3ff 0%, #ffffff 72%);
}

.monitor-search-card {
  background: linear-gradient(135deg, #fff7ed 0%, #ffffff 72%);
}

.voc-search-card {
  background: linear-gradient(135deg, #eff6ff 0%, #ffffff 72%);
}

.tool-search-card {
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 72%);
}

.tool-gallery {
  background: linear-gradient(135deg, #f8fafc 0%, #ffffff 72%);
}

.tool-card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 18px;
  max-width: 960px;
  margin: 18px auto 0;
}

.tool-card {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: #fff;
  padding: 16px;
  text-align: left;
  cursor: pointer;
  min-height: 128px;
}

.tool-card:hover {
  border-color: rgba(37, 99, 235, 0.24);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.07);
}

.tool-card-visual {
  display: grid;
  place-items: center;
  width: 86px;
  height: 86px;
  border: 1px solid rgba(37, 99, 235, 0.14);
  border-radius: 14px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0;
}

.tool-card-body,
.tool-card-body strong,
.tool-card-body em {
  display: block;
  min-width: 0;
}

.tool-card-body strong {
  color: #0f172a;
  font-size: 15px;
  font-weight: 900;
}

.tool-card-body em {
  margin-top: 6px;
  color: #64748b;
  font-size: 12px;
  font-style: normal;
  line-height: 1.5;
}

.tool-textarea.compact {
  min-height: 110px;
}

.search-home-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
  flex-wrap: wrap;
}

.voc-report-shortcuts {
  margin-top: 16px;
}

.voc-report-shortcuts-title {
  color: #64748b;
  font-size: 12px;
  font-weight: 900;
  text-align: left;
}

.voc-report-shortcuts-empty {
  margin-top: 12px;
  border: 1px dashed rgba(37, 99, 235, 0.28);
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.72);
  padding: 12px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.45;
}

.voc-report-shortcuts-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}

.voc-report-shortcut-card {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 8px;
  text-align: left;
  cursor: pointer;
}

.voc-report-shortcut-card:hover {
  border-color: rgba(37, 99, 235, 0.28);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.voc-report-shortcut-card img,
.voc-report-shortcut-img {
  width: 56px;
  height: 56px;
  border: 1px solid var(--line);
  border-radius: 9px;
  object-fit: contain;
  background: #f8fafc;
  padding: 7px;
}

.voc-report-shortcut-card strong,
.voc-report-shortcut-card em {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.voc-report-shortcut-card strong {
  color: #0f172a;
  font-size: 12px;
  font-weight: 900;
}

.voc-report-shortcut-card em {
  margin-top: 4px;
  color: #94a3b8;
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.search-home-actions .action-btn {
  min-width: 138px;
  height: 52px;
  border-radius: 14px;
}

.attribute-search-row,
.search-input-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 150px;
  gap: 10px;
  max-width: 860px;
  margin: 0 auto;
}

.attribute-search-row .text-input,
.attribute-search-row .action-btn,
.search-input-row .text-input,
.search-input-row .action-btn {
  height: 54px;
}

.attribute-search-row .text-input,
.search-input-row .text-input {
  border-radius: 14px;
  font-size: 15px;
}

.attribute-search-row .action-btn,
.search-input-row .action-btn {
  border-radius: 14px;
  white-space: nowrap;
}

.monitor-search-row {
  grid-template-columns: minmax(0, 1fr) 130px 190px;
  max-width: 960px;
  margin: 0 auto;
}

.monitor-search-row .text-input,
.monitor-search-row .select-input,
.monitor-search-row .action-btn {
  height: 54px;
  min-width: 0;
  border-radius: 14px;
}

.monitor-search-row .action-btn {
  white-space: nowrap;
}

.monitor-prefill-note {
  width: min(960px, 100%);
  margin: 12px auto 0;
  border: 1px solid rgba(255, 153, 0, 0.28);
  border-radius: 12px;
  background: #fff7ed;
  padding: 10px 12px;
  color: #9a3412;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
  text-align: left;
}

.attribute-report-link {
  margin-bottom: 14px;
}

.attribute-report-link-empty,
.attribute-report-link-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border: 1px solid rgba(37, 99, 235, 0.14);
  border-radius: 12px;
  background: #f8fbff;
  padding: 12px 14px;
}

.attribute-report-link-empty strong,
.attribute-report-link-head strong {
  display: block;
  color: #0f172a;
  font-size: 14px;
  font-weight: 900;
}

.attribute-report-link-empty span,
.attribute-report-link-head span {
  display: block;
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
  line-height: 1.4;
}

.attribute-report-link-empty > span,
.attribute-report-link-head > div {
  min-width: 0;
}

.attribute-report-link-empty em {
  display: block;
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
  font-style: normal;
  line-height: 1.4;
}

.attribute-report-link-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin-top: 10px;
}

.attribute-report-link-card {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 120px minmax(0, 1fr);
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 12px;
  text-align: left;
  cursor: pointer;
}

.attribute-report-link-card:hover {
  border-color: rgba(37, 99, 235, 0.28);
  box-shadow: 0 10px 24px rgba(15, 23, 42, 0.06);
}

.attribute-report-link-card img,
.attribute-report-link-img {
  width: 100%;
  height: 120px;
  border: 1px solid var(--line);
  border-radius: 9px;
  object-fit: contain;
  background: #f8fafc;
  padding: 14px;
}

.attribute-report-link-body {
  display: block;
  min-width: 0;
}

.attribute-report-link-card strong,
.attribute-report-link-card em,
.attribute-report-link-card small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attribute-report-link-card strong {
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}

.attribute-report-link-card em {
  margin-top: 3px;
  color: #64748b;
  font-size: 12px;
  font-style: normal;
}

.attribute-report-link-card small {
  margin-top: 5px;
  color: #94a3b8;
  font-size: 11px;
  font-weight: 800;
}

.section-title {
  font-size: 18px;
  font-weight: 800;
}

.count {
  color: var(--muted);
  font-size: 13px;
}

.monitor-list,
.event-list {
  display: grid;
  gap: 12px;
}

.monitor-report {
  display: grid;
  gap: 14px;
  margin-bottom: 16px;
  border: 1px solid rgba(37, 99, 235, 0.12);
  border-radius: 14px;
  background: linear-gradient(180deg, #fbfdff 0%, #fff 100%);
  padding: 14px;
}

.monitor-report-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.monitor-period-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.monitor-period-tabs span {
  border: 1px solid var(--line);
  border-radius: 9px;
  background: #fff;
  color: #64748b;
  padding: 7px 9px;
  font-size: 12px;
  font-weight: 900;
}

.monitor-period-tabs span.active {
  border-color: rgba(37, 99, 235, 0.22);
  background: rgba(37, 99, 235, 0.08);
  color: var(--accent);
}

.monitor-product-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.monitor-product-card {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 10px;
  min-width: 0;
}

.monitor-product-card img,
.monitor-card-img-placeholder {
  width: 54px;
  height: 54px;
  border: 1px solid var(--line);
  border-radius: 10px;
  object-fit: contain;
  background: #f8fafc;
}

.monitor-product-card > div > strong,
.monitor-product-card > div > span,
.monitor-product-card > div > em,
.monitor-product-card > div > b {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.monitor-product-card > div > strong {
  color: #0f172a;
  font-size: 13px;
}

.monitor-product-card > div > span,
.monitor-product-card > div > em {
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
}

.monitor-product-card > div > b {
  margin-top: 3px;
  color: var(--success);
  font-size: 12px;
}

.monitor-product-card > div > b.muted {
  color: #94a3b8;
}

.monitor-report-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}

.monitor-report-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 12px;
}

.monitor-report-card span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.monitor-report-card strong {
  display: block;
  margin-top: 6px;
  color: #0f172a;
  font-size: 24px;
  font-weight: 900;
}

.monitor-report-card em {
  display: block;
  margin-top: 6px;
  color: #64748b;
  font-size: 12px;
  font-style: normal;
  line-height: 1.35;
}

.monitor-visual-summary {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(0, 1.08fr);
  gap: 12px;
}

.monitor-chart-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 14px;
}

.monitor-chart-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  margin-bottom: 12px;
}

.monitor-chart-head strong {
  color: #0f172a;
  font-size: 14px;
  font-weight: 900;
}

.monitor-chart-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.monitor-donut-row {
  display: grid;
  grid-template-columns: 132px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
}

.monitor-donut {
  position: relative;
  width: 132px;
  height: 132px;
  border-radius: 50%;
  box-shadow: inset 0 0 0 1px rgba(15, 23, 42, 0.06);
}

.monitor-donut::after {
  content: "";
  position: absolute;
  inset: 30px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 0 0 1px rgba(15, 23, 42, 0.06);
}

.monitor-donut span {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  color: #0f172a;
  font-size: 22px;
  font-weight: 900;
}

.monitor-chart-legend {
  display: grid;
  gap: 8px;
}

.monitor-chart-legend div {
  display: grid;
  grid-template-columns: 10px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
}

.monitor-chart-legend i {
  width: 10px;
  height: 10px;
  border-radius: 999px;
}

.monitor-chart-legend span {
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.monitor-chart-legend strong {
  color: #0f172a;
  font-size: 12px;
  font-weight: 900;
}

.monitor-bar-list {
  display: grid;
  gap: 12px;
}

.monitor-bar-row {
  display: grid;
  gap: 6px;
}

.monitor-bar-row div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.monitor-bar-row span {
  color: #475569;
  font-size: 12px;
  font-weight: 900;
}

.monitor-bar-row strong {
  color: #0f172a;
  font-size: 12px;
  font-weight: 900;
}

.monitor-bar-row em {
  display: block;
  height: 9px;
  border-radius: 999px;
  background: #e2e8f0;
  overflow: hidden;
}

.monitor-bar-row em i {
  display: block;
  height: 100%;
  min-width: 4px;
  border-radius: inherit;
}

.monitor-report-brief {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 12px;
  background: #f8fbff;
  padding: 14px;
}

.monitor-report-brief span {
  display: block;
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
}

.monitor-report-brief strong {
  display: block;
  margin-top: 4px;
  color: #0f172a;
  font-size: 18px;
  font-weight: 900;
}

.monitor-report-brief em {
  display: block;
  margin-top: 5px;
  color: #475569;
  font-size: 13px;
  font-style: normal;
}

.monitor-report-brief-actions {
  display: flex;
  gap: 7px;
  flex-wrap: wrap;
  justify-content: flex-end;
  max-width: 460px;
}

.monitor-report-brief-actions span {
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 999px;
  background: #fff;
  color: #334155;
  padding: 7px 9px;
  font-size: 12px;
  font-weight: 900;
}

.monitor-data-quality {
  border: 1px solid rgba(220, 38, 38, 0.16);
  border-radius: 12px;
  background: #fff7f7;
  overflow: hidden;
}

.monitor-data-quality-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  border-bottom: 1px solid rgba(220, 38, 38, 0.12);
  padding: 12px 14px;
}

.monitor-data-quality-head strong {
  color: #991b1b;
  font-size: 14px;
  font-weight: 900;
}

.monitor-data-quality-head span {
  color: #7f1d1d;
  font-size: 12px;
  font-weight: 800;
}

.monitor-data-quality-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
}

.monitor-data-quality-item {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 12px;
  border-right: 1px solid rgba(220, 38, 38, 0.1);
  border-bottom: 1px solid rgba(220, 38, 38, 0.1);
}

.monitor-data-quality-item strong {
  display: block;
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}

.monitor-data-quality-item span {
  display: block;
  margin-top: 3px;
  color: #7f1d1d;
  font-size: 12px;
  line-height: 1.35;
}

.monitor-data-quality-item .monitor-mini-actions {
  margin-top: 8px;
}

.monitor-action-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.monitor-action-lane {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.monitor-action-lane-head {
  min-height: 84px;
  border-bottom: 1px solid var(--line);
  background: #f8fafc;
  padding: 12px;
}

.monitor-action-lane-head strong,
.monitor-action-item strong {
  display: block;
  color: #0f172a;
  font-weight: 900;
}

.monitor-action-lane-head span {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.4;
}

.monitor-action-items {
  display: grid;
}

.monitor-action-item,
.monitor-action-empty {
  padding: 10px 12px;
  border-top: 1px solid var(--line);
}

.monitor-action-item {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}

.monitor-action-item:first-child,
.monitor-action-empty:first-child {
  border-top: 0;
}

.monitor-action-item span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.35;
}

.monitor-action-item em {
  display: block;
  margin-top: 7px;
  color: #334155;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
}

.monitor-action-item-main {
  min-width: 0;
}

.monitor-mini-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 9px;
}

.monitor-mini-actions .small-btn {
  min-height: 28px;
  padding: 5px 8px;
  font-size: 11px;
}

.monitor-action-status {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 8px;
  background: rgba(37, 99, 235, 0.06);
  color: var(--accent);
  padding: 5px 8px;
  font-size: 11px;
  font-weight: 900;
}

.monitor-action-empty {
  color: #94a3b8;
  font-size: 12px;
}

.monitor-trend-matrix-wrap {
  overflow-x: auto;
}

.monitor-trend-matrix,
.monitor-trend-table {
  width: 100%;
  min-width: 920px;
  border-collapse: collapse;
  font-size: 12px;
}

.monitor-trend-matrix th,
.monitor-trend-matrix td,
.monitor-trend-table th,
.monitor-trend-table td {
  padding: 10px 12px;
  border-top: 1px solid var(--line);
  text-align: left;
  vertical-align: top;
}

.monitor-trend-matrix th,
.monitor-trend-table th {
  background: #f8fafc;
  color: #64748b;
  font-weight: 900;
}

.monitor-trend-matrix td:first-child,
.monitor-trend-table td:first-child {
  min-width: 260px;
}

.monitor-trend-matrix td strong,
.monitor-trend-table td strong {
  display: block;
  color: #0f172a;
  font-weight: 900;
}

.monitor-trend-matrix td span:not(.matrix-pill):not(.matrix-empty),
.monitor-trend-table td span {
  color: var(--muted);
}

.monitor-product-cell {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.monitor-product-cell > div {
  min-width: 0;
}

.monitor-product-cell span {
  display: block;
  margin-top: 3px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.monitor-report-thumb {
  width: 40px;
  height: 40px;
  border: 1px solid var(--line);
  border-radius: 8px;
  object-fit: contain;
  background: #fff;
}

.monitor-product-cell .monitor-report-thumb {
  width: 44px;
  height: 44px;
}

.monitor-report-thumb.placeholder {
  background: linear-gradient(180deg, #f8fafc, #eef2f7);
}

.monitor-report .amazon-stars,
.monitor-report .amazon-star.full,
.monitor-report .amazon-star.half span {
  color: #ffa41c;
}

.monitor-report .amazon-star.empty,
.monitor-report .amazon-star.half {
  color: #ddd;
}

.monitor-report .amazon-rating-value {
  color: #0f1111;
}

.matrix-pill,
.matrix-empty {
  display: inline-flex;
  align-items: center;
  margin: 2px 3px 2px 0;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #f8fafc;
  color: #475569;
  padding: 3px 7px;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.matrix-pill.green {
  border-color: rgba(22, 163, 74, 0.2);
  background: rgba(22, 163, 74, 0.08);
  color: var(--success);
}

.matrix-pill.orange {
  border-color: rgba(245, 158, 11, 0.24);
  background: rgba(245, 158, 11, 0.1);
  color: #b45309;
}

.matrix-pill.blue {
  border-color: rgba(37, 99, 235, 0.18);
  background: rgba(37, 99, 235, 0.08);
  color: var(--accent);
}

.matrix-pill.red {
  border-color: rgba(220, 38, 38, 0.18);
  background: rgba(220, 38, 38, 0.08);
  color: #b91c1c;
}

.matrix-empty {
  color: #cbd5e1;
}

.monitor-daily-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
}

.monitor-daily-title {
  padding: 12px 14px;
  color: #0f172a;
  font-weight: 900;
  border-bottom: 1px solid var(--line);
}

.monitor-daily-table {
  width: 100%;
  min-width: 860px;
  border-collapse: collapse;
  font-size: 12px;
}

.monitor-daily-table th,
.monitor-daily-table td {
  padding: 11px 12px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  vertical-align: middle;
}

.monitor-daily-table th {
  background: #f8fafc;
  color: #64748b;
  font-weight: 900;
}

.monitor-daily-table td {
  color: #334155;
}

.monitor-daily-table td span,
.monitor-daily-empty {
  color: var(--muted);
}

.monitor-daily-table .badge {
  max-width: 260px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.monitor-daily-empty {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 14px;
  font-size: 13px;
}

.monitor-report-section {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  overflow: hidden;
}

.monitor-row,
.event-row,
.report-row {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 14px;
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: start;
  background: #fff;
}

.monitor-img,
.event-img {
  width: 56px;
  height: 56px;
  border-radius: 12px;
  object-fit: contain;
  background: #f8fafc;
  border: 1px solid var(--line);
}

.monitor-img.placeholder,
.event-img.placeholder {
  background: linear-gradient(180deg, #f8fafc, #eef2f7);
}

.monitor-title,
.event-title {
  font-weight: 800;
  font-size: 15px;
  line-height: 1.35;
}

.monitor-meta,
.event-meta {
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
}

.report-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 14px;
}

.competitor-voc-builder {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 14px;
  margin-bottom: 18px;
}

.form-grid {
  display: grid;
  grid-template-columns: minmax(320px, 1fr) 140px;
  gap: 12px;
  align-items: end;
}

.report-builder-grid {
  grid-template-columns: minmax(0, 1fr) 220px;
  align-items: stretch;
  gap: 18px;
}

.report-asin-field {
  min-width: 0;
}

.report-side-field {
  display: grid;
  gap: 12px;
  align-content: end;
}

.report-side-field label {
  display: grid;
  gap: 6px;
}

.report-side-field .select-input,
.report-side-field .action-btn {
  width: 100%;
  min-width: 0;
}

.report-side-field .select-input {
  height: 52px;
}

.report-side-field .action-btn {
  height: 52px;
  border-radius: 12px;
  padding: 0 14px;
  font-size: 15px;
  white-space: nowrap;
}

.competitor-voc-builder label,
.field-block {
  display: grid;
  gap: 6px;
  color: #334155;
  font-size: 12px;
  font-weight: 800;
}

.field-block {
  margin-top: 12px;
}

.tool-textarea.compact {
  min-height: 112px;
}

.competitor-voc-status {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 10px 12px;
  color: #475569;
  background: #f8fafc;
  font-size: 13px;
  line-height: 1.5;
}

.competitor-voc-status.loading {
  color: #075985;
  border-color: #bae6fd;
  background: #f0f9ff;
}

.competitor-voc-status.success {
  color: #047857;
  border-color: #bbf7d0;
  background: #f0fdf4;
}

.competitor-voc-status.warning {
  color: #92400e;
  border-color: #fde68a;
  background: #fffbeb;
}

.competitor-voc-status.error {
  color: #b91c1c;
  border-color: #fecaca;
  background: #fef2f2;
}

.report-created-status {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
}

.report-created-status strong,
.report-created-status span {
  display: block;
}

.report-created-status strong {
  color: #065f46;
  font-size: 13px;
  font-weight: 900;
}

.report-created-status span {
  margin-top: 2px;
  color: #047857;
  font-size: 12px;
}

.report-created-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.report-created-actions .small-btn {
  border-color: #bbf7d0;
  background: #fff;
  color: #047857;
}

.report-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 18px;
}

.report-task-head {
  margin-top: 18px;
}

.report-task-list {
  display: grid;
  gap: 12px;
  margin-bottom: 18px;
}

.report-task-filter {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f8fafc;
  color: #64748b;
  padding: 9px 12px;
  font-size: 12px;
  font-weight: 800;
}

.report-task-card {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 12px;
}

.report-task-img {
  width: 86px;
  height: 86px;
  border: 1px solid var(--line);
  border-radius: 12px;
  object-fit: contain;
  background: #f8fafc;
  padding: 10px;
}

.report-task-img.placeholder {
  background: linear-gradient(180deg, #fff, #eef2f7);
}

.report-task-main {
  min-width: 0;
}

.report-task-headline,
.report-task-foot {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.report-task-headline strong {
  display: block;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #0f172a;
  font-size: 14px;
  font-weight: 900;
}

.report-task-progress {
  height: 8px;
  margin: 9px 0;
  border-radius: 999px;
  background: #e5e7eb;
  overflow: hidden;
}

.report-task-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2563eb, #22c55e);
}

.report-task-foot {
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.report-history-actions {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 150px auto;
  width: min(560px, 100%);
}

.report-list .report-row {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 210px minmax(0, 1fr) auto;
  gap: 0;
  padding: 0;
  border-radius: 16px;
  background: linear-gradient(180deg, #fff 0%, #fbfdff 100%);
  height: 100%;
  min-height: 312px;
  overflow: hidden;
  cursor: pointer;
}

.report-list .report-row:hover {
  border-color: rgba(37, 99, 235, 0.22);
  box-shadow: 0 14px 34px rgba(15, 23, 42, 0.07);
}

.report-list .report-row:focus-visible {
  outline: 3px solid rgba(37, 99, 235, 0.24);
  outline-offset: 3px;
}

.report-list .report-row .monitor-img {
  width: 100%;
  height: 210px;
  border: 0;
  border-bottom: 1px solid var(--line);
  border-radius: 0;
  background: #f8fafc;
  padding: 28px;
}

.report-list .report-row .monitor-title {
  display: -webkit-box;
  color: #0f172a;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.35;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.report-list .report-row .report-card-body {
  min-width: 0;
  padding: 14px 16px 10px;
}

.report-card-footer {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  padding: 0 16px 16px;
  color: #94a3b8;
  font-size: 12px;
  font-weight: 800;
}

.report-card-footer span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.report-row.highlight {
  border-color: #f59e0b;
  background: #fffbeb;
  box-shadow: 0 0 0 3px rgba(245, 158, 11, 0.16);
  transition: background .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.report-product-strip {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}

.report-product-chip {
  width: 58px;
  min-height: 74px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafc;
  padding: 5px;
  text-align: center;
}

.report-product-chip-img {
  width: 36px;
  height: 36px;
  border-radius: 7px;
  object-fit: contain;
  background: #fff;
  border: 1px solid var(--line);
}

.report-product-chip-img.placeholder {
  background: linear-gradient(180deg, #fff, #eef2f7);
}

.report-product-chip-asin {
  margin-top: 4px;
  color: #334155;
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  overflow-wrap: anywhere;
}

.report-product-chip-role {
  margin-top: 2px;
  color: var(--muted);
  font-size: 10px;
  line-height: 1.2;
}

.action-board {
  margin-top: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 14px;
}

.action-board-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 12px;
}

.action-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.action-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 12px;
  background: #f8fafc;
  min-width: 0;
}

.action-card span {
  display: inline-flex;
  border-radius: 999px;
  background: #eef6ff;
  color: #2563eb;
  padding: 3px 8px;
  font-size: 11px;
  font-weight: 900;
}

.action-card strong {
  display: block;
  margin-top: 8px;
  color: #111827;
  font-size: 13px;
  line-height: 1.35;
}

.action-card em {
  display: block;
  margin-top: 5px;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  line-height: 1.4;
}

.action-card .small-btn {
  margin-top: 12px;
}

.module-divider {
  height: 1px;
  background: var(--line);
  margin: 18px -18px;
}

.queue-toolbar {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) 150px;
  gap: 10px;
  margin: 0 0 12px;
}

.queue-quota {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  margin: 0 0 12px;
}

.queue-quota[hidden] {
  display: none;
}

.queue-quota div {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 10px 12px;
}

.queue-quota span {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.queue-quota strong {
  display: block;
  margin-top: 4px;
  color: #0f172a;
  font-size: 15px;
  font-weight: 900;
}

.queue-quota strong.warn {
  color: #92400e;
}

.queue-quota strong.danger {
  color: var(--danger);
}

.queue-list {
  display: grid;
  gap: 10px;
}

.queue-row {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  gap: 14px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 12px;
}

.queue-img {
  width: 56px;
  height: 56px;
  border: 1px solid var(--line);
  border-radius: 10px;
  object-fit: contain;
  background: #fff;
  padding: 4px;
}

.queue-img.placeholder {
  background: linear-gradient(135deg, #eef2ff, #f8fafc);
}

.queue-side {
  display: grid;
  justify-items: end;
  gap: 6px;
}

.queue-status {
  border-radius: 999px;
  background: #eef2ff;
  color: #3730a3;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}

.queue-status.running {
  background: #dbeafe;
  color: #1d4ed8;
}

.queue-status.done {
  background: #dcfce7;
  color: #166534;
}

.queue-status.partial {
  background: #fef3c7;
  color: #92400e;
}

.queue-status.failed,
.queue-status.blocked {
  background: #fee2e2;
  color: #991b1b;
}

.queue-status.canceled {
  background: #f1f5f9;
  color: #475569;
}

.queue-error {
  margin-top: 6px;
  color: var(--danger);
  font-size: 12px;
  line-height: 1.4;
}

.queue-notice {
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 12px;
  background: rgba(37, 99, 235, 0.06);
  color: #1d4ed8;
  padding: 10px 12px;
  margin-bottom: 12px;
  font-size: 13px;
  font-weight: 800;
  line-height: 1.5;
}

.queue-notice-meta {
  margin-top: 4px;
  color: #64748b;
  font-size: 12px;
  font-weight: 700;
}

.tool-workbench {
  margin-top: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 14px;
}

.tool-workbench.search-home-card {
  margin-top: 0;
  padding: 22px;
}

.tool-search-card .tool-textarea {
  max-width: 960px;
  min-height: 150px;
  margin: 0 auto;
  display: block;
  background: #fff;
  border-radius: 14px;
  font-size: 14px;
}

.tool-search-card .tool-actions {
  max-width: 960px;
  margin: 12px auto 0;
  justify-content: center;
}

.tool-search-card .tool-output {
  max-width: 960px;
  margin: 14px auto 0;
}

.tool-textarea {
  width: 100%;
  min-height: 128px;
  resize: vertical;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #f8fafc;
  color: var(--text);
  padding: 12px 14px;
  font: 13px/1.5 ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
}

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

.tool-actions .select-input {
  width: 110px;
}

.tool-output {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #f8fafc;
  padding: 12px;
  min-height: 48px;
}

.tool-output-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  color: #334155;
  font-size: 13px;
}

.tool-output-head span {
  color: var(--muted);
}

.tool-output-usage {
  margin-top: 8px;
  color: #64748b;
  font-size: 12px;
  font-weight: 800;
}

.tool-output-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.search-snapshot-toolbar {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.search-snapshot-toolbar-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #f8fafc;
  padding: 8px;
}

.toolbar-label {
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
  min-width: 32px;
}

.toolbar-select {
  height: 34px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  color: #0f172a;
  padding: 0 28px 0 10px;
  font-size: 12px;
  font-weight: 800;
}

.tool-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}

.tool-chip {
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.06);
  color: #1d4ed8;
  padding: 5px 9px;
  font-size: 12px;
  font-weight: 900;
}

.tool-chip.muted {
  border-color: var(--line);
  background: #f8fafc;
  color: var(--muted);
}

[data-search-snapshot-asin] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
}

.search-snapshot-table-wrap {
  margin-top: 12px;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
}

.search-snapshot-table {
  width: 100%;
  min-width: 1120px;
  border-collapse: collapse;
  table-layout: fixed;
  font-size: 12px;
}

.search-snapshot-table th,
.search-snapshot-table td {
  border-right: 1px solid #e5e7eb;
  border-bottom: 1px solid #e5e7eb;
  padding: 8px 10px;
  vertical-align: middle;
}

.search-snapshot-table th:last-child,
.search-snapshot-table td:last-child {
  border-right: 0;
}

.search-snapshot-table tbody tr:last-child td {
  border-bottom: 0;
}

.search-snapshot-table th {
  background: #f1f5f9;
  color: #334155;
  font-weight: 900;
  text-align: left;
  white-space: nowrap;
}

.search-snapshot-table tbody tr:nth-child(even) {
  background: #fbfdff;
}

.search-snapshot-table tbody tr:hover {
  background: #eff6ff;
}

.search-snapshot-table tbody tr.is-selected {
  background: #eef6ff;
}

.search-snapshot-table .select-col {
  width: 42px;
  text-align: center;
}

.search-snapshot-table .rank-col {
  width: 46px;
  text-align: right;
  color: #475569;
  font-variant-numeric: tabular-nums;
}

.search-snapshot-table .asin-col {
  width: 118px;
}

.search-snapshot-table .product-col {
  width: auto;
}

.search-snapshot-table .reason-col {
  width: 170px;
}

.search-snapshot-table .number-col {
  width: 92px;
  text-align: right;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.search-snapshot-table .asin-chip {
  display: inline-block;
  max-width: 98px;
  border-radius: 6px;
  padding: 4px 6px;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 11px;
  white-space: nowrap;
}

.search-snapshot-product {
  display: flex;
  gap: 9px;
  align-items: center;
  min-width: 0;
}

.search-snapshot-product img {
  width: 42px;
  height: 42px;
  object-fit: contain;
  flex: 0 0 auto;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 6px;
}

.search-snapshot-product span {
  min-width: 0;
  color: #111827;
  line-height: 1.35;
}

.reason-pill {
  display: inline-block;
  margin: 2px 4px 2px 0;
  border: 1px solid #bfdbfe;
  border-radius: 6px;
  background: #eff6ff;
  color: #1d4ed8;
  padding: 3px 6px;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.25;
  white-space: normal;
}

.reason-separator {
  color: #94a3b8;
  font-weight: 700;
}

.reason-muted {
  color: var(--muted);
}

.report-selection-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.report-selection-summary span {
  border: 1px solid #bbf7d0;
  border-radius: 6px;
  background: #f0fdf4;
  color: #166534;
  padding: 5px 8px;
  font-size: 12px;
  font-weight: 900;
}

.search-report-preview-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}

.search-report-preview-row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #fff;
  padding: 10px;
}

.search-report-preview-row img,
.search-report-preview-img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 7px;
  background: #fff;
  padding: 4px;
}

.search-report-preview-img.placeholder {
  background: #f1f5f9;
}

.search-report-preview-main {
  min-width: 0;
}

.search-report-preview-title {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #0f172a;
  font-size: 13px;
}

.search-report-preview-title strong {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 12px;
}

.search-report-preview-title span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
}

.search-report-preview-main p {
  margin: 3px 0 0;
  color: #334155;
  font-size: 12px;
  line-height: 1.4;
}

.search-report-preview-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 6px;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.search-report-preview-reasons {
  margin-top: 5px;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.35;
}

.monitor-preview-wrap {
  margin-top: 10px;
}

.monitor-preview-table {
  min-width: 860px;
}

.search-quality-panel {
  margin: 12px 0;
  border: 1px solid var(--line);
  border-left: 4px solid #64748b;
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.search-quality-good {
  border-left-color: #16a34a;
}

.search-quality-usable {
  border-left-color: #f59e0b;
}

.search-quality-review {
  border-left-color: var(--danger);
}

.search-quality-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  color: #334155;
  font-size: 13px;
}

.search-quality-head span {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.search-quality-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  margin-top: 10px;
}

.search-quality-card {
  border: 1px solid #e2e8f0;
  border-radius: 7px;
  background: #fff;
  padding: 8px;
  min-width: 0;
}

.search-quality-card span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 800;
}

.search-quality-card strong {
  display: block;
  margin-top: 3px;
  color: #111827;
  font-size: 15px;
  line-height: 1.2;
}

.search-candidate-alert {
  color: var(--danger);
  font-weight: 900;
}

.search-evidence-alert {
  color: #b45309;
  font-weight: 900;
}

.search-structure-alert {
  color: #7c3aed;
  font-weight: 900;
}

.monitor-duplicate-warning,
.monitor-duplicate-text {
  color: var(--danger);
  font-weight: 900;
}

.tool-chip.monitor-duplicate-chip {
  border-color: #fecaca;
  background: #fef2f2;
  color: var(--danger);
  font-weight: 900;
}

.tool-chip.monitor-added-chip {
  border-color: #bbf7d0;
  background: #f0fdf4;
  color: #15803d;
  font-weight: 900;
}

.tool-chip.monitor-failed-chip {
  border-color: #fed7aa;
  background: #fff7ed;
  color: #c2410c;
  font-weight: 900;
}

.monitor-result-panel {
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 8px;
  background: #f8fafc;
  padding: 12px;
}

.monitor-result-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.monitor-result-card {
  border: 1px solid #e2e8f0;
  border-top: 3px solid #94a3b8;
  border-radius: 8px;
  background: #fff;
  padding: 10px;
  min-width: 0;
}

.monitor-result-card.is-added {
  border-top-color: #16a34a;
}

.monitor-result-card.is-duplicate {
  border-top-color: var(--danger);
}

.monitor-result-card.is-failed {
  border-top-color: #f97316;
}

.monitor-result-card > span {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 900;
}

.monitor-result-card > strong {
  display: block;
  margin-top: 4px;
  color: #111827;
  font-size: 22px;
  line-height: 1.1;
}

.monitor-result-chip-row {
  margin-top: 8px;
  gap: 6px;
}

.monitor-result-errors {
  margin-top: 10px;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  background: #fff7ed;
  color: #9a3412;
  padding: 9px;
  font-size: 12px;
  font-weight: 800;
  line-height: 1.5;
}

.search-snapshot-table tbody tr.is-duplicate-monitor {
  background: #fef2f2;
}

.search-snapshot-table tbody tr.is-duplicate-monitor:hover {
  background: #fee2e2;
}

.review-analysis-result {
  margin-top: 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 14px;
}

.review-analysis-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  margin-bottom: 12px;
}

.review-product-head {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-width: 0;
}

.review-head-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

.review-product-img {
  width: 72px;
  height: 72px;
  border: 1px solid var(--line);
  border-radius: 12px;
  object-fit: contain;
  background: #fff;
  padding: 4px;
}

.review-product-img.placeholder {
  background: linear-gradient(135deg, #eef2ff, #f8fafc);
}

.review-product-title {
  margin-top: 4px;
  color: #334155;
  font-size: 13px;
  line-height: 1.45;
}

.review-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-bottom: 12px;
}

.rating-bars {
  display: grid;
  gap: 8px;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #f8fafc;
  padding: 12px;
  margin-bottom: 12px;
}

.rating-bar-row {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 34px;
  gap: 10px;
  align-items: center;
  color: #475569;
  font-size: 12px;
  font-weight: 800;
}

.rating-bar-row em {
  color: var(--muted);
  font-style: normal;
  text-align: right;
}

.rating-bar-track {
  height: 8px;
  border-radius: 999px;
  background: #e2e8f0;
  overflow: hidden;
}

.rating-bar-fill {
  height: 100%;
  border-radius: inherit;
  background: var(--accent);
}

.review-insight-panel {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 12px;
  margin-bottom: 12px;
}

.review-insight-title {
  color: #111827;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 10px;
}

.review-theme-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.review-theme-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f8fafc;
  padding: 10px;
  min-width: 0;
}

.review-theme-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: center;
}

.review-theme-head strong {
  color: #111827;
  font-size: 13px;
  line-height: 1.3;
}

.review-theme-head span {
  color: #991b1b;
  background: #fee2e2;
  border-radius: 999px;
  padding: 3px 7px;
  font-size: 11px;
  font-weight: 900;
  white-space: nowrap;
}

.review-theme-action {
  margin-top: 7px;
  color: #334155;
  font-size: 12px;
  line-height: 1.45;
}

.review-evidence-list {
  display: grid;
  gap: 7px;
  margin-top: 9px;
}

.review-evidence {
  border-left: 3px solid #f59e0b;
  background: #fff;
  padding: 7px 8px;
  border-radius: 7px;
}

.review-evidence-meta {
  color: #64748b;
  font-size: 11px;
  font-weight: 800;
  line-height: 1.35;
}

.review-evidence-body {
  margin-top: 4px;
  color: #334155;
  font-size: 12px;
  line-height: 1.45;
}

.review-sample-list {
  display: grid;
  gap: 0;
}

.review-sample {
  border-top: 1px solid #ddd;
  background: #fff;
  padding: 14px 0;
  font-family: Arial, "Amazon Ember", sans-serif;
}

.review-sample:first-child {
  border-top: 0;
}

.review-sample-author {
  color: #111;
  font-size: 13px;
  line-height: 1.4;
  margin-bottom: 4px;
}

.review-sample-title {
  display: flex;
  align-items: baseline;
  gap: 7px;
  color: #0f1111;
  font-size: 14px;
  line-height: 1.35;
}

.review-sample-title strong {
  font-weight: 700;
}

.review-stars {
  color: #ffa41c;
  font-size: 15px;
  letter-spacing: 0;
  white-space: nowrap;
}

.review-sample-meta {
  margin-top: 4px;
  color: #565959;
  font-size: 12px;
  line-height: 1.35;
}

.review-verified {
  margin-top: 4px;
  color: #c45500;
  font-size: 12px;
  font-weight: 700;
  line-height: 1.35;
}

.review-sample-body {
  margin-top: 8px;
  color: #0f1111;
  font-size: 14px;
  line-height: 1.5;
}

.review-sample-helpful {
  margin-top: 8px;
  color: #565959;
  font-size: 12px;
  line-height: 1.35;
}

.report-summary {
  margin-top: 8px;
  color: #334155;
  font-size: 13px;
  line-height: 1.55;
}

.report-summary.lead {
  font-size: 15px;
  line-height: 1.7;
  margin-top: 12px;
}

.report-json {
  margin: 14px 0 0;
  max-height: 420px;
  overflow: auto;
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  background: #f8fafc;
  color: #334155;
  font-size: 12px;
  line-height: 1.5;
  white-space: pre-wrap;
}

.report-reader {
  min-height: calc(100vh - 20px);
}

.reader-topbar {
  position: sticky;
  top: 0;
  z-index: 3;
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: center;
  padding: 6px 0 10px;
  background: rgba(245, 247, 251, 0.94);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--line);
  margin-bottom: 10px;
}

.reader-topbar .small-btn {
  margin-bottom: 6px;
}

.reader-topbar .row-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  flex-wrap: wrap;
}

.report-next-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.report-next-actions .small-btn {
  border-color: rgba(255, 153, 0, 0.32);
  background: #fff7ed;
  color: #9a3412;
}

.reader-topbar.compact .section-title {
  font-size: 20px;
}

.reader-topbar.compact .count {
  max-width: 980px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.reader-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 18px;
  align-items: start;
}

.reader-layout.single {
  grid-template-columns: minmax(0, 1fr);
}

.reader-main,
.reader-aside {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 12px;
  box-shadow: 0 12px 28px rgba(15, 23, 42, 0.06);
}

.reader-main {
  padding: 16px 18px 22px;
  min-width: 0;
}

.reader-aside {
  position: sticky;
  top: 92px;
  padding: 16px;
}

.reader-product-img {
  width: 74px;
  height: 74px;
  border-radius: 10px;
  object-fit: cover;
  border: 1px solid var(--line);
  background: #f8fafc;
}

.reader-product-img.placeholder {
  background: #f1f5f9;
}

.reader-aside-img {
  width: 100%;
  aspect-ratio: 1.25;
  object-fit: contain;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #f8fafc;
  margin-bottom: 12px;
}

.reader-aside-title {
  font-size: 18px;
  font-weight: 900;
}

.reader-aside-meta {
  margin-top: 6px;
  color: var(--muted);
  font-size: 12px;
}

.reader-aside-block {
  margin-top: 14px;
  border-top: 1px solid var(--line);
  padding-top: 14px;
}

.reader-toc {
  margin-top: 8px;
  color: #334155;
  font-size: 13px;
  line-height: 1.6;
}

.web-voc-head {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 12px;
  border-radius: 12px;
  background: linear-gradient(90deg, #eef5ff 0%, #f8fbff 62%, #fff 100%);
  border: 1px solid rgba(37, 99, 235, 0.1);
}

.web-voc-summary {
  min-width: 0;
}

.web-voc-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.summary-card.compact {
  padding: 10px;
  box-shadow: none;
}

.summary-text {
  margin-top: 7px;
  color: #334155;
  font-size: 13px;
  line-height: 1.45;
}

.amazon-rating {
  display: inline-flex;
  align-items: baseline;
  gap: 5px;
  white-space: nowrap;
  font-family: Arial, "Amazon Ember", sans-serif;
}

.amazon-rating.compact {
  gap: 4px;
}

.amazon-stars {
  color: #ffa41c;
  font-size: 15px;
  line-height: 1;
  letter-spacing: 0;
}

.amazon-star {
  display: inline-block;
  position: relative;
  width: 1em;
  color: #ffa41c;
}

.amazon-star.empty {
  color: #ddd;
}

.amazon-star.half {
  color: #ddd;
}

.amazon-star.half span {
  position: absolute;
  inset: 0 auto 0 0;
  width: 50%;
  overflow: hidden;
  color: #ffa41c;
}

.amazon-rating.compact .amazon-stars {
  font-size: 13px;
}

.amazon-rating-value {
  color: #0f1111;
  font-weight: 800;
}

.report-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 12px 0 12px;
  border-bottom: 1px solid var(--line);
  padding-bottom: 8px;
}

.report-tab {
  border: 1px solid var(--line);
  background: #fff;
  color: #334155;
  border-radius: 7px;
  padding: 7px 10px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 800;
}

.report-tab.active,
.report-tab:hover {
  border-color: rgba(37, 99, 235, 0.24);
  background: #eff6ff;
  color: var(--accent);
}

.report-panel {
  display: none;
}

.report-panel.active {
  display: block;
}

.report-section {
  display: grid;
  gap: 10px;
}

.report-section + .report-section {
  margin-top: 14px;
}

.report-section-title {
  font-weight: 900;
  color: #0f172a;
}

.report-rows {
  display: grid;
  gap: 10px;
}

.report-row-card {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 11px 12px;
  background: #f8fafc;
  color: #334155;
  font-size: 13px;
  line-height: 1.55;
}

.report-row-title {
  margin-bottom: 6px;
  color: #0f172a;
  font-weight: 900;
}

.reader-main .at-card {
  background: #f7f7f7;
  border-radius: 10px;
  padding: 16px;
  margin-bottom: 14px;
  border: 1px solid #ebebeb;
}

.reader-main .at-section-label {
  font-weight: 800;
  color: #111827;
  margin-bottom: 6px;
}

.reader-main .at-info {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 10px;
  color: #334155;
  font-size: 12px;
  line-height: 1.55;
}

.reader-main .at-voc-report-tabs {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 10px 0 2px;
  margin-top: 8px;
}

.reader-main .at-voc-report-tab {
  border: 1px solid #e5e7eb;
  background: #fff;
  color: #64748b;
  border-radius: 7px;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
  cursor: pointer;
}

.reader-main .at-voc-report-tab.active {
  background: #fff7ed;
  border-color: #ff9900;
  color: #c2410c;
}

.reader-main .at-voc-report-panel {
  display: none;
}

.reader-main .at-voc-report-panel.active {
  display: block;
}

.reader-main .at-voc-report-img {
  width: 58px;
  height: 58px;
  object-fit: contain;
  flex-shrink: 0;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 7px;
}

.reader-main .at-voc-report-img.placeholder {
  background: #f1f5f9;
}

.reader-main .at-voc-trace-btn {
  display: inline-flex;
  align-items: center;
  border: 1px solid #fed7aa;
  background: #fff7ed;
  color: #c2410c;
  border-radius: 6px;
  padding: 4px 8px;
  margin-top: 6px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
}

.reader-main .at-voc-trace-btn:hover {
  background: #ffedd5;
  border-color: #ff9900;
}

.reader-main .at-voc-trace-btn:disabled {
  cursor: wait;
  opacity: 0.65;
}

.web-voc-ask-card {
  margin-top: 14px;
}

.web-voc-ask-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}

.web-voc-question {
  width: 100%;
  min-height: 88px;
  resize: vertical;
  margin-top: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 11px 12px;
  color: #0f172a;
  font: inherit;
  line-height: 1.5;
  background: #fff;
}

.web-voc-question:focus {
  outline: none;
  border-color: #ffa41c;
  box-shadow: 0 0 0 3px rgba(255, 164, 28, 0.16);
}

.web-voc-ask-actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 10px;
}

.web-voc-answer {
  margin-top: 12px;
  border: 1px solid #e5e7eb;
  border-radius: 10px;
  background: #fff;
  padding: 12px;
}

.web-voc-answer-body {
  color: #334155;
  font-size: 13px;
  line-height: 1.65;
}

.web-voc-answer-body p {
  margin: 0 0 10px;
}

.web-voc-answer-body p:last-child {
  margin-bottom: 0;
}

.report-trace-card {
  margin-top: 14px !important;
}

.report-trace-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 12px;
  color: #64748b;
  margin-bottom: 10px;
}

.report-trace-meta strong {
  color: #111827;
}

.report-trace-meta span {
  background: #f8fafc;
  border: 1px solid #e5e7eb;
  border-radius: 999px;
  padding: 2px 7px;
}

.reader-main .at-comp-hero {
  background: linear-gradient(90deg, #f8fbff, #eef6ff);
}

.reader-main .at-comp-hero-metric {
  text-align: right;
  min-width: 104px;
  margin-left: auto;
}

.reader-main .at-comp-hero-number {
  font-size: 30px;
  font-weight: 900;
  color: #111827;
  line-height: 1;
}

.reader-main .at-comp-hero-label {
  font-size: 11px;
  color: #64748b;
  margin-top: 4px;
}

.reader-main .at-comp-hero-products {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 12px;
}

.reader-main .at-comp-hero-product {
  position: relative;
  width: 74px;
  background: rgba(255, 255, 255, .82);
  border: 1px solid #e5e7eb;
  border-radius: 8px;
  padding: 8px 6px 6px;
  text-align: center;
}

.reader-main .at-comp-rank {
  position: absolute;
  top: -7px;
  left: 6px;
  background: #ff9900;
  color: #fff;
  border-radius: 4px;
  padding: 1px 5px;
  font-size: 10px;
  font-weight: 800;
}

.reader-main .at-comp-hero-asin {
  font-size: 10px;
  color: #64748b;
  margin-top: 4px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.reader-main .at-comp-report-section {
  overflow: hidden;
}

.reader-main .at-comp-report-img {
  width: 54px;
  height: 54px;
  object-fit: contain;
  flex-shrink: 0;
  background: #fff;
  border: 1px solid #e5e7eb;
  border-radius: 7px;
}

.reader-main .at-comp-report-img.placeholder {
  background: #f1f5f9;
}

.reader-main .at-comp-table-wrap {
  overflow-x: auto;
  margin-top: 8px;
}

.reader-main .at-comp-report-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 11px;
  min-width: 560px;
}

.reader-main .at-comp-report-table th,
.reader-main .at-comp-report-table td {
  border: 1px solid #e5e7eb;
  padding: 8px;
  text-align: left;
  vertical-align: top;
}

.reader-main .at-comp-report-table th {
  background: #f8fafc;
  color: #334155;
  font-weight: 800;
}

.reader-main .at-comp-report-table td {
  color: #111827;
  background: #fff;
}

.reader-main .at-comp-bar {
  position: relative;
  height: 18px;
  background: #eff6ff;
  border-radius: 4px;
  overflow: hidden;
  min-width: 92px;
}

.reader-main .at-comp-bar-fill {
  position: absolute;
  inset: 0 auto 0 0;
  background: #bfdbfe;
  border-radius: 4px;
}

.reader-main .at-comp-bar span {
  position: relative;
  z-index: 1;
  display: block;
  text-align: right;
  padding-right: 5px;
  font-size: 11px;
  color: #334155;
  line-height: 18px;
}

.reader-main .at-comp-report-item {
  border-top: 1px solid #e5e7eb;
  padding: 9px 0;
}

.reader-main .at-comp-report-item:first-of-type {
  border-top: 0;
  padding-top: 0;
}

.metric-row {
  margin-top: 10px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.metric {
  border: 1px solid var(--line);
  border-radius: 10px;
  padding: 7px 10px;
  font-size: 12px;
  background: #fff;
}

.metric.up {
  color: var(--success);
  border-color: rgba(4, 120, 87, 0.18);
  background: rgba(4, 120, 87, 0.06);
}

.metric.down {
  color: var(--danger);
  border-color: rgba(185, 28, 28, 0.16);
  background: rgba(185, 28, 28, 0.06);
}

.event-body {
  margin-top: 6px;
  color: #334155;
  font-size: 13px;
  line-height: 1.5;
}

.event-actions,
.row-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: flex-end;
}

.small-btn {
  border: 1px solid var(--line);
  background: #fff;
  color: #0f172a;
  border-radius: 10px;
  padding: 8px 10px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}

.small-btn:hover {
  border-color: rgba(37, 99, 235, 0.22);
}

.small-btn.primary {
  border-color: rgba(37, 99, 235, 0.26);
  background: #2563eb;
  color: #fff;
}

.small-btn.primary:hover {
  border-color: #1d4ed8;
}

.small-btn.ghost-danger {
  border-color: #fecaca;
  color: var(--danger);
}

.small-btn:disabled {
  cursor: wait;
  opacity: 0.62;
}

.badge {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 800;
  padding: 4px 8px;
  border: 1px solid transparent;
}

.badge.green {
  color: var(--success);
  background: rgba(4, 120, 87, 0.06);
  border-color: rgba(4, 120, 87, 0.15);
}

.badge.orange {
  color: var(--warn);
  background: rgba(180, 83, 9, 0.06);
  border-color: rgba(180, 83, 9, 0.15);
}

.badge.red {
  color: var(--danger);
  background: rgba(185, 28, 28, 0.06);
  border-color: rgba(185, 28, 28, 0.16);
}

.history {
  margin-top: 8px;
  font-size: 11px;
  color: #94a3b8;
  line-height: 1.45;
}

.settings-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.account-console {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 16px;
  margin-top: 14px;
}

.account-console-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}

.account-login-grid,
.account-license-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(150px, 0.45fr) auto;
  gap: 10px;
  margin-top: 14px;
}

.account-register-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
  color: var(--muted);
  font-size: 13px;
  line-height: 1.5;
}

.account-register-row a {
  color: var(--ink);
  font-weight: 900;
  text-decoration: none;
}

.account-license-row {
  grid-template-columns: minmax(0, 1fr) auto;
}

.account-license-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.account-license-item {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f8fafc;
  padding: 10px 12px;
  font-size: 13px;
}

.account-license-item strong {
  display: block;
  font-size: 14px;
}

.account-license-item span,
.account-message {
  color: var(--muted);
}

.account-license-item em {
  font-style: normal;
  font-weight: 900;
  color: var(--success);
}

.account-license-item.expired em {
  color: var(--danger);
}

.account-upgrade-card {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
  border: 1px solid rgba(37, 99, 235, 0.18);
  border-radius: 10px;
  background: #eff6ff;
  padding: 12px;
  margin-top: 12px;
}

.account-upgrade-card[hidden] {
  display: none;
}

.account-upgrade-card strong,
.account-upgrade-card span {
  display: block;
}

.account-upgrade-card strong {
  color: #0f172a;
  font-size: 14px;
  font-weight: 900;
}

.account-upgrade-card span {
  margin-top: 5px;
  color: #475569;
  font-size: 13px;
  line-height: 1.5;
}

.account-security-panel {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 12px;
  margin-top: 12px;
}

.account-security-panel > div:first-child {
  min-width: 0;
  flex: 1;
}

.account-security-panel.warning {
  border-color: rgba(217, 119, 6, 0.38);
  background: #fffbeb;
}

.account-security-panel.danger {
  border-color: rgba(220, 38, 38, 0.34);
  background: #fff1f2;
}

.account-security-panel[hidden] {
  display: none;
}

.account-security-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.account-session-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.account-session-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f8fafc;
  padding: 10px 12px;
  font-size: 13px;
}

.account-session-item.current {
  border-color: rgba(15, 118, 110, 0.28);
  background: #f0fdfa;
}

.account-session-item strong,
.account-session-item span {
  display: block;
}

.account-session-item strong {
  color: #0f172a;
  font-size: 13px;
  font-weight: 900;
}

.account-session-item span {
  margin-top: 5px;
  color: var(--muted);
  line-height: 1.45;
}

.account-session-item em {
  flex-shrink: 0;
  border-radius: 999px;
  background: #e2e8f0;
  color: #334155;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  padding: 4px 8px;
}

.account-session-item.current em {
  background: #ccfbf1;
  color: #0f766e;
}

.account-session-empty {
  border: 1px dashed var(--line);
  border-radius: 10px;
  color: var(--muted);
  padding: 10px 12px;
  font-size: 13px;
}

.account-message {
  min-height: 20px;
  margin-top: 10px;
  font-size: 13px;
}

.account-message.error {
  color: var(--danger);
}

.account-message.success {
  color: var(--success);
}

.account-message.notice {
  color: #9a3412;
}

.data-source-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  margin: 14px 0;
}

.data-source-card {
  border: 1px solid var(--line);
  border-radius: 12px;
  background: #fff;
  padding: 16px;
  border-top: 4px solid #64748b;
}

.data-source-card.live {
  border-top-color: #059669;
}

.data-source-card.historical,
.data-source-card.planned {
  border-top-color: #2563eb;
}

.data-source-card.pending {
  border-top-color: #f97316;
}

.source-capability-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.source-capability-list span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: #f8fafc;
  color: #334155;
  padding: 6px 9px;
  font-size: 12px;
  font-weight: 900;
}

.attribute-hero {
  margin-top: 12px;
  border-radius: 16px;
  border: 1px solid rgba(37, 99, 235, 0.12);
  background: linear-gradient(90deg, #e9f2ff 0%, #f7fbff 58%, #eef3ff 100%);
  padding: 18px;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}

.product-stack {
  display: flex;
  gap: 10px;
}

.product-tile {
  position: relative;
  width: 78px;
  height: 86px;
  border-radius: 10px;
  border: 1px solid rgba(37, 99, 235, 0.14);
  background: #fff;
  display: grid;
  justify-items: center;
  align-content: center;
  gap: 4px;
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
}

.product-tile b {
  position: absolute;
  top: 5px;
  left: 5px;
  border-radius: 5px;
  background: #ff7a45;
  color: #fff;
  padding: 2px 6px;
  font-size: 10px;
  line-height: 1.2;
}

.product-tile.muted b {
  background: #94a3b8;
}

.product-tile-img {
  width: 54px;
  height: 44px;
  object-fit: contain;
  display: block;
}

.product-tile-img.placeholder {
  width: 54px;
  height: 44px;
  border-radius: 8px;
  background: #eef2ff;
}

.product-tile span {
  display: block;
  max-width: 68px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.product-tile em {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-style: normal;
  font-weight: 800;
}

.product-tile.muted {
  color: #64748b;
}

.attribute-title {
  font-size: 22px;
  font-weight: 900;
  line-height: 1.25;
}

.attribute-meta {
  margin-top: 8px;
  color: var(--muted);
  font-size: 13px;
}

.module-tabs {
  display: flex;
  gap: 22px;
  border-bottom: 1px solid var(--line);
  margin: 18px 0 14px;
}

.module-tab {
  border: 0;
  border-bottom: 3px solid transparent;
  background: transparent;
  color: #475569;
  padding: 0 0 10px;
  font-weight: 800;
  cursor: pointer;
}

.module-tab.active {
  color: var(--accent);
  border-color: var(--accent);
}

.attribute-toolbar {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: center;
  margin-bottom: 14px;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.filter-chip {
  border: 1px solid var(--line);
  background: #f8fafc;
  color: #334155;
  border-radius: 10px;
  padding: 9px 12px;
  font-weight: 800;
  cursor: pointer;
}

.filter-chip.active {
  background: rgba(37, 99, 235, 0.1);
  border-color: rgba(37, 99, 235, 0.2);
  color: var(--accent);
}

.filter-chip span {
  color: var(--muted);
  font-size: 11px;
  margin-left: 4px;
}

.analytics-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, 0.75fr);
  gap: 14px;
}

.analysis-panel {
  border: 1px solid var(--line);
  border-radius: 14px;
  background: #fff;
  padding: 16px;
  min-height: 260px;
}

.analysis-panel.wide {
  grid-column: 1 / -1;
}

.analysis-title {
  font-size: 16px;
  font-weight: 900;
  border-left: 4px solid var(--accent);
  padding-left: 10px;
}

.analysis-subtitle {
  margin-top: 8px;
  color: var(--muted);
  font-size: 12px;
}

.bar-chart {
  height: 260px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(72px, 1fr));
  gap: 18px;
  align-items: end;
  padding: 24px 12px 10px;
  border-bottom: 1px solid var(--line);
}

.bar-item {
  display: grid;
  gap: 8px;
  justify-items: center;
  align-items: end;
}

.bar {
  width: 34px;
  border-radius: 8px 8px 0 0;
  background: var(--accent);
}

.bar-label {
  color: var(--muted);
  font-size: 12px;
  text-align: center;
  word-break: break-word;
}

.donut-chart {
  width: 210px;
  height: 210px;
  border-radius: 50%;
  margin: 28px auto 8px;
  display: grid;
  place-items: center;
  background: conic-gradient(#2563eb 0 48%, #22c55e 48% 66%, #f59e0b 66% 80%, #fb7185 80% 92%, #cbd5e1 92% 100%);
}

.donut-chart::after {
  content: attr(data-label);
  width: 112px;
  height: 112px;
  border-radius: 50%;
  background: #fff;
  display: grid;
  place-items: center;
  color: #334155;
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  padding: 12px;
}

.line-chart {
  min-height: 218px;
  margin-top: 26px;
  border-left: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  background:
    linear-gradient(180deg, rgba(148, 163, 184, 0.12) 1px, transparent 1px) 0 0 / 100% 44px,
    linear-gradient(90deg, rgba(37, 99, 235, 0.12), rgba(37, 99, 235, 0.03));
  position: relative;
  overflow: hidden;
}

.line-chart svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.attribute-breakdown {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  padding: 12px;
}

.attribute-breakdown-row {
  display: grid;
  grid-template-columns: minmax(80px, 1.2fr) 72px 72px 88px minmax(140px, 1.5fr);
  gap: 8px;
  align-items: center;
  border: 1px solid rgba(148, 163, 184, 0.22);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.92);
  padding: 9px 10px;
  font-size: 12px;
}

.attribute-breakdown-row strong {
  color: #0f172a;
}

.attribute-breakdown-row span,
.attribute-breakdown-row em {
  color: var(--muted);
  font-style: normal;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.attribute-breakdown-row .amazon-stars {
  color: #ffa41c;
}

.attribute-breakdown-row .amazon-star {
  color: #ffa41c;
}

.attribute-breakdown-row .amazon-star.empty,
.attribute-breakdown-row .amazon-star.half {
  color: #ddd;
}

.attribute-breakdown-row .amazon-star.half span {
  color: #ffa41c;
}

.attribute-breakdown-row .amazon-rating-value {
  color: #0f1111;
}

.attribute-market-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.attribute-market-card {
  min-height: 180px;
}

.source-card-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.source-pill {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  border-radius: 999px;
  background: #ecfdf5;
  color: #047857;
  padding: 4px 8px;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.source-pill.pending {
  background: #fff7ed;
  color: #c2410c;
}

.source-pill.estimate {
  background: #eff6ff;
  color: #1d4ed8;
}

.attribute-market-value {
  margin-top: 10px;
  color: #0f172a;
  font-size: 24px;
  font-weight: 900;
  line-height: 1.2;
  word-break: break-word;
}

.attribute-market-metric {
  margin-top: 8px;
  color: #334155;
  font-size: 13px;
  font-weight: 800;
}

.attribute-market-note {
  margin-top: 12px;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.45;
}

.attribute-table-wrap {
  margin-top: 14px;
  overflow-x: auto;
}

.attribute-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 820px;
  font-size: 12px;
}

.attribute-table th,
.attribute-table td {
  border-bottom: 1px solid var(--line);
  padding: 10px 9px;
  text-align: left;
  vertical-align: top;
}

.attribute-table th {
  background: #f8fafc;
  color: #475569;
  font-weight: 900;
  white-space: nowrap;
}

.attribute-table td {
  color: #334155;
  line-height: 1.45;
}

.attribute-table td:first-child {
  color: #0f172a;
  white-space: nowrap;
}

.attribute-table-img {
  width: 54px;
  height: 44px;
  object-fit: contain;
  display: block;
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
}

.attribute-table-img.placeholder {
  background: #f1f5f9;
}

.keyword-result {
  display: grid;
  gap: 14px;
}

.keyword-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.keyword-panel {
  min-height: 320px;
}

.keyword-market-panel,
.keyword-cloud-panel,
.keyword-detail-panel {
  overflow: hidden;
}

.keyword-action-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin: 14px 0;
}

.keyword-action-panel {
  overflow: hidden;
  border-top: 4px solid #0f766e;
}

.keyword-action-panel.risk {
  border-top-color: #e11d48;
}

.keyword-action-panel.seo {
  border-top-color: #2563eb;
}

.keyword-action-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.keyword-action-item {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  padding: 11px;
}

.keyword-action-head {
  display: flex;
  justify-content: space-between;
  gap: 10px;
  align-items: center;
}

.keyword-action-head strong {
  min-width: 0;
  color: #0f172a;
  font-size: 15px;
  overflow-wrap: anywhere;
}

.keyword-action-head span {
  flex: 0 0 auto;
  border-radius: 999px;
  background: #ecfdf5;
  color: #047857;
  padding: 4px 8px;
  font-size: 11px;
  font-weight: 900;
}

.keyword-action-panel.risk .keyword-action-head span {
  background: #fff1f2;
  color: #be123c;
}

.keyword-action-panel.seo .keyword-action-head span {
  background: #eff6ff;
  color: #1d4ed8;
}

.keyword-action-meta,
.keyword-action-reason {
  margin-top: 7px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  line-height: 1.45;
}

.keyword-action-reason {
  color: #334155;
  font-weight: 700;
}

.keyword-source-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}

.keyword-category-table {
  display: grid;
  gap: 0;
  margin-top: 16px;
  border: 1px solid var(--line);
  border-radius: 10px;
  overflow: hidden;
}

.keyword-category-row {
  display: grid;
  grid-template-columns: 1.25fr .55fr 1.2fr .75fr .8fr .8fr;
  gap: 12px;
  align-items: center;
  min-width: 820px;
  padding: 12px 14px;
  border-top: 1px solid var(--line);
  color: #334155;
  font-size: 13px;
  font-weight: 800;
}

.keyword-category-row.head {
  border-top: 0;
  background: #f8fafc;
  color: #64748b;
  font-size: 12px;
}

.keyword-category-row strong {
  color: #0f172a;
  font-size: 14px;
}

.keyword-category-row span {
  position: relative;
}

.keyword-category-row i {
  display: inline-block;
  height: 12px;
  margin-right: 8px;
  border-radius: 999px;
  background: #5b7cfa;
  vertical-align: -1px;
}

.keyword-category-row .muted,
.keyword-detail-table .muted {
  color: #94a3b8;
}

.keyword-category-terms {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  min-width: 820px;
  padding: 0 14px 12px;
  border-top: 0;
  background: #fff;
}

.keyword-category-terms em {
  padding: 5px 8px;
  border: 1px solid var(--line);
  border-radius: 999px;
  color: #475569;
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
}

.keyword-ai-summary {
  display: grid;
  gap: 8px;
  margin-top: 14px;
  padding: 14px;
  border-radius: 10px;
  background: #f8fafc;
  color: #475569;
  font-size: 13px;
  line-height: 1.6;
}

.keyword-ai-summary strong {
  color: #0f172a;
  font-size: 15px;
}

.keyword-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.keyword-item {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #f8fafc;
  padding: 11px;
}

.keyword-item-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  align-items: baseline;
}

.keyword-item-head strong {
  color: #0f172a;
  font-size: 15px;
}

.keyword-item-head span,
.keyword-item-meta {
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}

.keyword-item-intent {
  margin-top: 7px;
  color: #334155;
  font-size: 12px;
  line-height: 1.45;
}

.keyword-evidence {
  margin-top: 9px;
  border-left: 3px solid #ffa41c;
  background: #fff;
  border-radius: 7px;
  padding: 8px;
  color: #334155;
  font-size: 12px;
  line-height: 1.45;
}

.keyword-cloud {
  min-height: 230px;
  display: flex;
  align-content: center;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 12px 18px;
  padding: 24px 18px;
}

.keyword-cloud span {
  display: inline-block;
  font-weight: 900;
  line-height: 1;
}

.keyword-cloud .pain {
  color: #e11d48;
}

.keyword-cloud .scenario {
  color: #2563eb;
}

.keyword-cloud .feature {
  color: #059669;
}

.keyword-cloud .listing {
  color: #8b5cf6;
}

.keyword-detail-scroll {
  margin-top: 16px;
  overflow-x: auto;
}

.keyword-detail-table {
  width: 100%;
  min-width: 920px;
  border-collapse: collapse;
  font-size: 13px;
}

.keyword-detail-table th,
.keyword-detail-table td {
  padding: 13px 14px;
  border-bottom: 1px solid var(--line);
  text-align: left;
  white-space: nowrap;
}

.keyword-detail-table th {
  background: #f8fafc;
  color: #64748b;
  font-size: 12px;
}

.keyword-detail-table td strong {
  color: #0f172a;
}

.attribute-notes {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.attribute-note {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
  color: #334155;
  background: #f8fafc;
  font-size: 13px;
  line-height: 1.55;
}

.data-quality-notice {
  display: grid;
  gap: 6px;
  border: 1px solid rgba(37, 99, 235, 0.16);
  border-radius: 12px;
  background: rgba(37, 99, 235, 0.06);
  color: #1e40af;
  padding: 12px;
}

.data-quality-notice.low,
.data-quality-notice.empty {
  border-color: rgba(245, 158, 11, 0.24);
  background: rgba(245, 158, 11, 0.08);
  color: #92400e;
}

.data-quality-notice.high {
  border-color: rgba(34, 197, 94, 0.2);
  background: rgba(34, 197, 94, 0.08);
  color: #166534;
}

.data-quality-notice strong,
.data-quality-notice span,
.data-quality-notice em {
  display: block;
}

.data-quality-notice strong {
  font-size: 13px;
  font-weight: 900;
}

.data-quality-notice span,
.data-quality-notice em {
  font-size: 12px;
  font-style: normal;
  font-weight: 800;
  line-height: 1.45;
}

.setting-card {
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 16px;
  background: #fff;
}

.setting-title {
  font-weight: 800;
  margin-bottom: 8px;
}

.setting-body {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.6;
}

.upgrade-panel {
  border: 1px solid rgba(37, 99, 235, 0.14);
  border-radius: 16px;
  background: linear-gradient(135deg, #eff6ff 0%, #ffffff 70%);
  padding: 28px;
  max-width: 760px;
}

.upgrade-kicker {
  color: var(--accent);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: 0;
}

.upgrade-title {
  margin-top: 8px;
  font-size: 26px;
  font-weight: 900;
}

.upgrade-copy {
  margin-top: 10px;
  color: var(--muted);
  line-height: 1.65;
  font-size: 14px;
}

.upgrade-link {
  display: inline-flex;
  margin-top: 18px;
}

@media (max-width: 1180px) {
  .app-shell {
    grid-template-columns: 1fr;
  }

  .sidebar {
    position: sticky;
    top: 0;
    z-index: 4;
  }

  .main {
    padding-top: 0;
  }
}

@media (max-width: 920px) {
  .hero,
  .watchlist-head,
  .events-head,
  .workspace-head,
  .attribute-toolbar,
  .monitor-report-head,
  .search-quality-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .add-grid,
  .controls,
  .form-grid,
  .summary-grid,
  .report-summary-grid,
  .review-metric-grid,
  .review-theme-grid,
  .action-grid,
  .web-voc-head,
  .web-voc-metrics,
  .workflow-steps,
	  .settings-grid,
	  .data-source-board,
	  .console-overview,
	  .analytics-grid,
	  .attribute-hero,
	  .monitor-visual-summary,
	  .monitor-action-board,
	  .monitor-data-quality-list,
	  .monitor-product-strip,
	  .monitor-report-grid,
	  .trust-list,
	  .keyword-action-board,
	  .keyword-grid,
	  .attribute-report-link-list,
	  .voc-report-shortcuts-list,
	  .attribute-search-row,
	  .search-input-row,
	  .monitor-search-row,
	  .account-login-grid,
	  .account-license-row,
	  .search-quality-grid,
	  .search-report-preview-row,
	  .monitor-result-grid {
	    grid-template-columns: 1fr;
	  }

	  .attribute-report-link-empty,
	  .attribute-report-link-head {
	    align-items: stretch;
	    flex-direction: column;
	  }

	  .attribute-report-link-empty .small-btn,
	  .attribute-report-link-head .small-btn {
	    width: 100%;
	  }

    .account-security-panel {
      align-items: flex-start;
      flex-direction: column;
    }

    .account-security-actions {
      justify-content: flex-start;
      width: 100%;
    }

    .account-session-item {
      align-items: flex-start;
      flex-direction: column;
    }

    .account-upgrade-card {
      align-items: flex-start;
      flex-direction: column;
    }

  .report-created-status {
    align-items: flex-start;
    flex-direction: column;
  }

  .report-created-actions {
    justify-content: flex-start;
  }

  .report-task-card {
    grid-template-columns: 72px minmax(0, 1fr);
    align-items: flex-start;
  }

  .report-task-img {
    width: 72px;
    height: 72px;
    border-radius: 10px;
    padding: 8px;
  }

  .report-task-headline,
  .report-task-foot {
    align-items: flex-start;
    flex-direction: column;
  }

  .monitor-report-brief {
    grid-template-columns: 1fr;
  }

  .monitor-data-quality-head {
    flex-direction: column;
    align-items: flex-start;
  }

  .monitor-report-brief-actions {
    justify-content: flex-start;
  }

  .monitor-row,
  .event-row,
  .report-row,
  .queue-row,
  .reader-layout {
    grid-template-columns: 1fr;
  }

  .report-list .report-row {
    grid-template-columns: 1fr;
    grid-template-rows: 180px minmax(0, 1fr) auto;
  }

  .report-list .report-row .monitor-img {
    width: 100%;
    height: 180px;
  }

  .report-history-actions {
    grid-template-columns: 1fr;
  }

  .queue-toolbar {
    grid-template-columns: 1fr;
  }

  .queue-quota {
    grid-template-columns: 1fr;
  }

  .queue-side {
    justify-items: start;
  }

  .reader-topbar {
    position: static;
    flex-direction: column;
    align-items: stretch;
  }

  .reader-topbar .row-actions {
    justify-content: flex-start;
  }

  .reader-aside {
    position: static;
  }

  .event-actions,
  .row-actions {
    justify-content: flex-start;
  }
}
