* { margin: 0; padding: 0; box-sizing: border-box; }

:root,
body[data-theme="light"] {
  --app-shell-width: 1000px;
  --body-background:
    radial-gradient(circle at top left, rgba(255, 192, 116, 0.22), transparent 30%),
    radial-gradient(circle at top right, rgba(255, 230, 189, 0.2), transparent 26%),
    linear-gradient(180deg, #fff8f0 0%, #fbf0e1 100%);
  --text-main: #1f2937;
  --text-strong: #132238;
  --text-muted: #72665a;
  --text-soft: #8b7d70;
  --text-faint: #97a3b7;
  --header-background: linear-gradient(180deg, #fffaf3 0%, #ffedd5 100%);
  --header-border: #e7cfb2;
  --header-title: #21364f;
  --tagline-text: #1a73e8;
  --panel-background: rgba(255, 250, 244, 0.92);
  --panel-background-strong: #fffaf4;
  --panel-background-soft: #fff4e8;
  --panel-border: #e8d4bc;
  --panel-border-strong: #dfc4a3;
  --panel-shadow: 0 20px 48px rgba(72, 42, 17, 0.08);
  --input-background: #fffaf4;
  --input-border: #ddc5a7;
  --input-focus: #1a73e8;
  --chip-background: #ffedd5;
  --chip-border: #f0c99d;
  --chip-text: #7a4d26;
  --primary-gradient: linear-gradient(90deg, #ffbf75, #c86718);
  --primary-ink: #fffaf4;
  --primary-outline: #c86718;
  --ghost-background: #fff8ef;
  --ghost-border: #dfc4a3;
  --ghost-text: #655748;
  --results-heading: #1a73e8;
  --card-background: #fffaf4;
  --card-background-selected: #eef5ff;
  --card-border: #ead7c1;
  --card-border-hover: #d9bf9f;
  --card-border-selected: #76a8ff;
  --score-background: #fff1de;
  --score-text: #1c4b92;
  --score-high-background: #eaf8f1;
  --score-high-text: #1f7a52;
  --score-mid-background: #fff4d7;
  --score-mid-text: #8a5c00;
  --pill-background: #f9efe2;
  --pill-text: #6b5a49;
  --pill-good-background: #e9f7ef;
  --pill-good-text: #1f7a52;
  --pill-ok-background: #fff3d4;
  --pill-ok-text: #8a5c00;
  --pill-low-background: #fde9e7;
  --pill-low-text: #a63f34;
  --type-product-background: #e7f4ec;
  --type-product-border: #b6ddc4;
  --type-product-text: #1f7a52;
  --type-service-background: #fff1dc;
  --type-service-border: #ebcf9a;
  --type-service-text: #9b6500;
  --type-content-background: #f3ecff;
  --type-content-border: #d6c6f5;
  --type-content-text: #7142b8;
  --detail-background: #fff4e8;
  --detail-border: #ead8c4;
  --detail-heading: #28415f;
  --detail-text: #6f6459;
  --detail-strong: #1f2d3d;
  --warning-background: #fff4d7;
  --warning-border: #e4c173;
  --warning-text: #8d5f00;
  --danger-background: #fff0ef;
  --danger-border: #e3c1bf;
  --danger-text: #9a4a42;
  --research-background: #fff7ed;
  --research-border: #eed4b3;
  --research-heading: #1f7a52;
  --research-link: #1a73e8;
  --history-hint-background: #eef5ff;
  --history-hint-border: #cfe0fb;
  --history-hint-text: #245da8;
  --modal-background: #fffaf4;
  --modal-border: #ead7c1;
  --section-background: rgba(255, 250, 244, 0.96);
  --section-border: #e8d4bc;
  --divider: #ead8c4;
  --link-color: #1a73e8;
  --error-background: #fff0ef;
  --error-border: #e3c1bf;
  --error-text: #9a4a42;
  --spinner-track: #ecdac6;
  --spinner-head: #1a73e8;
  --overlay-background: rgba(18, 28, 40, 0.48);
  --warning-chip-background: #fff4d7;
  --warning-chip-border: #dfbf76;
  --warning-chip-text: #8d5f00;
  --empty-text: #7a879b;
}

body[data-theme="dark"] {
  --body-background: linear-gradient(180deg, #0f1620 0%, #111927 100%);
  --text-main: #e6eef9;
  --text-strong: #ffffff;
  --text-muted: #8ea0bc;
  --text-soft: #7d8ea8;
  --text-faint: #6d7b93;
  --header-background: linear-gradient(180deg, #101722 0%, #131d2c 100%);
  --header-border: #24354c;
  --header-title: #f4f7fb;
  --tagline-text: #7ed5ff;
  --panel-background: rgba(24, 35, 50, 0.92);
  --panel-background-strong: #1a2332;
  --panel-background-soft: #111827;
  --panel-border: #2b3b52;
  --panel-border-strong: #384a63;
  --panel-shadow: 0 18px 44px rgba(0, 0, 0, 0.32);
  --input-background: #101722;
  --input-border: #33435a;
  --input-focus: #7ed5ff;
  --chip-background: #122234;
  --chip-border: #2d4668;
  --chip-text: #9acbff;
  --primary-gradient: linear-gradient(90deg, #4facfe, #00f2fe);
  --primary-ink: #07101a;
  --primary-outline: #7ed5ff;
  --ghost-background: #0f1723;
  --ghost-border: #2e425b;
  --ghost-text: #9fb3cf;
  --results-heading: #7ed5ff;
  --card-background: #1a2332;
  --card-background-selected: #122033;
  --card-border: #2a3b52;
  --card-border-hover: #3a4d66;
  --card-border-selected: #76a8ff;
  --score-background: #f5f8ff;
  --score-text: #203d74;
  --score-high-background: #0f2c1d;
  --score-high-text: #8cf3c3;
  --score-mid-background: #2e2a0a;
  --score-mid-text: #f2d600;
  --pill-background: #101827;
  --pill-text: #8ea0bc;
  --pill-good-background: #0f2c1d;
  --pill-good-text: #8cf3c3;
  --pill-ok-background: #2d2610;
  --pill-ok-text: #f2d600;
  --pill-low-background: #2c1515;
  --pill-low-text: #f27c75;
  --type-product-background: #0f2c1d;
  --type-product-border: #1e5f47;
  --type-product-text: #8cf3c3;
  --type-service-background: #2a1d0f;
  --type-service-border: #6c5028;
  --type-service-text: #e6c27a;
  --type-content-background: #24182f;
  --type-content-border: #5d4775;
  --type-content-text: #d5aef4;
  --detail-background: #141c29;
  --detail-border: #27354a;
  --detail-heading: #dbe7ff;
  --detail-text: #94a8c7;
  --detail-strong: #d7e7ff;
  --warning-background: #221a0b;
  --warning-border: #6a5323;
  --warning-text: #f0cd73;
  --danger-background: #251414;
  --danger-border: #5a2b2b;
  --danger-text: #f27c75;
  --research-background: #10222a;
  --research-border: #1f4b3d;
  --research-heading: #8cf3c3;
  --research-link: #7ed5ff;
  --history-hint-background: #0f1b2a;
  --history-hint-border: #28415f;
  --history-hint-text: #8fb6e6;
  --modal-background: #182130;
  --modal-border: #2b3b52;
  --section-background: rgba(24, 35, 50, 0.96);
  --section-border: #2b3b52;
  --divider: #24354c;
  --link-color: #7ed5ff;
  --error-background: #251414;
  --error-border: #5a2b2b;
  --error-text: #f27c75;
  --spinner-track: #24354c;
  --spinner-head: #7ed5ff;
  --overlay-background: rgba(0, 0, 0, 0.7);
  --warning-chip-background: #221a0b;
  --warning-chip-border: #6a5323;
  --warning-chip-text: #f0cd73;
  --empty-text: #7d8ea8;
}

body {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  background: var(--body-background);
  color: var(--text-main);
  min-height: 100vh;
}

.header {
  position: relative;
  padding: 1.85rem 1rem 1.2rem;
  background: var(--header-background);
  border-bottom: 1px solid var(--header-border);
}

.header-inner {
  position: relative;
  width: min(100%, var(--app-shell-width));
  margin: 0 auto;
}

.header-app-brand {
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--text-soft);
}

.header-launchpad-shell {
  background: color-mix(in srgb, var(--panel-background) 82%, transparent);
  border: 1px solid var(--panel-border);
  border-radius: 22px;
  box-shadow: var(--panel-shadow);
  padding: 1rem 1.05rem;
}

.header-app-chip {
  display: inline-flex;
  align-items: center;
  padding: 0.44rem 0.82rem;
  border-radius: 999px;
  background: var(--chip-background);
  border: 1px solid var(--chip-border);
  color: var(--chip-text);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.header-launchpad {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(240px, 0.75fr);
  gap: 1rem;
  align-items: start;
}

.header-copy {
  display: grid;
  gap: 0.65rem;
  text-align: left;
}

.header-brand-card {
  padding: 0.8rem 0.95rem 0.72rem;
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel-background) 90%, transparent);
  border: 1px solid var(--panel-border);
}

.header-brand-card .header-app-brand {
  margin-bottom: 0.32rem;
}

.header-copy-card {
  padding: 0.8rem 0.95rem 0.75rem;
  border-radius: 18px;
  background: color-mix(in srgb, var(--panel-background) 90%, transparent);
  border: 1px solid var(--panel-border);
}

.header-framework-badge {
  display: inline-flex;
  align-items: center;
  padding: 0.48rem 0.84rem;
  margin-bottom: 0.95rem;
  border-radius: 999px;
  background: color-mix(in srgb, var(--chip-background) 84%, transparent);
  border: 1px solid var(--chip-border);
  color: var(--chip-text);
  font-size: 0.74rem;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.header-controls {
  position: fixed;
  top: 0.85rem;
  right: 0.85rem;
  z-index: 50;
}

.header h1 {
  font-size: clamp(2rem, 4.2vw, 2.9rem);
  font-weight: 800;
  color: var(--header-title);
  margin-bottom: 0;
  letter-spacing: -0.05em;
  text-transform: none;
}

.header-subtitle {
  color: var(--text-muted);
  font-size: 0.98rem;
  max-width: none;
  margin: 0;
  line-height: 1.45;
}

.header .tagline {
  color: var(--text-soft);
  font-size: 0.83rem;
  margin-top: 0.5rem;
  font-weight: 500;
  max-width: none;
  line-height: 1.5;
}

.header-hero-panel {
  display: grid;
  gap: 0.65rem;
}

.header-hero-card,
.header-metric {
  background: color-mix(in srgb, var(--panel-background) 90%, transparent);
  border: 1px solid var(--panel-border);
  box-shadow: var(--panel-shadow);
}

.header-hero-card {
  padding: 0.9rem 1rem 0.85rem;
  border-radius: 18px;
}

.header-hero-card strong {
  display: block;
  color: var(--text-strong);
  font-size: 1.05rem;
  line-height: 1.1;
  letter-spacing: -0.04em;
}

.header-hero-card p {
  margin: 0.38rem 0 0;
  color: var(--text-muted);
  font-size: 0.78rem;
  line-height: 1.45;
}

.header-hero-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.5rem;
}

.header-metric {
  border-radius: 16px;
  padding: 0.62rem 0.7rem 0.58rem;
}

.header-metric strong {
  display: block;
  color: var(--text-strong);
  font-size: 0.94rem;
  line-height: 1;
  letter-spacing: -0.03em;
}

.header-metric span {
  display: block;
  margin-top: 0.22rem;
  color: var(--text-soft);
  font-size: 0.66rem;
  line-height: 1.35;
}

.theme-toggle-icon {
  width: 42px;
  height: 42px;
  min-width: 42px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-weight: 700;
}

.theme-toggle-glyph {
  font-size: 1rem;
  line-height: 1;
}

.container {
  width: min(100%, calc(var(--app-shell-width) + 2rem));
  margin: 0 auto;
  padding: 2rem 1rem;
}

.account-panel {
  background: var(--panel-background);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  padding: 1rem 1.1rem;
  margin-bottom: 1rem;
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: center;
  box-shadow: var(--panel-shadow);
}

.account-plan-line {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  flex-wrap: wrap;
  color: var(--text-strong);
}

.account-plan-label {
  color: var(--text-soft);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.account-level {
  font-size: 0.72rem;
  background: var(--chip-background);
  color: var(--chip-text);
  padding: 0.18rem 0.45rem;
  border-radius: 999px;
  font-weight: 700;
}

.account-meta {
  color: var(--text-muted);
  font-size: 0.82rem;
  margin-top: 0.25rem;
}

.account-actions {
  display: flex;
  gap: 0.75rem;
  align-items: center;
}

.account-progress {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
  text-align: right;
  color: var(--text-muted);
  font-size: 0.78rem;
}

.mode-row {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  align-items: end;
  margin-bottom: 1rem;
}

.mode-row label {
  display: block;
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 0.4rem;
  font-weight: 600;
}

.input-select,
.mode-row select,
.mode-static {
  padding: 0.75rem 1rem;
  background: var(--input-background);
  border: 1px solid var(--input-border);
  border-radius: 8px;
  color: var(--text-main);
  font-size: 1rem;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.input-select {
  width: 100%;
}

.mode-row select {
  width: 260px;
}

.mode-static {
  width: auto;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  flex-wrap: wrap;
  padding: 0;
  background: none;
  border: none;
  color: var(--text-muted);
  font-size: 0.84rem;
}

.mode-static-pill {
  display: inline-flex;
  align-items: center;
  padding: 0.3rem 0.62rem;
  border-radius: 999px;
  border: 1px solid var(--chip-border);
  background: var(--chip-background);
  color: var(--chip-text);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}

.input-select:focus,
.mode-row select:focus {
  outline: none;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--input-focus) 18%, transparent);
}

.usage-chip {
  white-space: nowrap;
  background: var(--chip-background);
  border: 1px solid var(--chip-border);
  color: var(--chip-text);
  padding: 0.3rem 0.7rem;
  border-radius: 999px;
  font-size: 0.75rem;
  font-weight: 700;
  margin-bottom: 0.2rem;
}

.scanner-workspace {
  position: relative;
  margin-bottom: 2rem;
}

.scan-guide {
  position: fixed;
  top: 10.5rem;
  left: max(1rem, calc(50% - ((var(--app-shell-width) + 2rem) / 2) - 252px));
  width: 216px;
  z-index: 20;
  display: grid;
  gap: 0.55rem;
}

.scan-guide-card,
.scan-guide-note-card {
  position: relative;
  display: grid;
  gap: 0.5rem;
  background: var(--section-background);
  border: 1px solid var(--section-border);
  border-radius: 14px;
  padding: 0.82rem 0.78rem;
  box-shadow: var(--panel-shadow);
  transition: transform 0.18s ease, opacity 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.scan-guide-card::before {
  content: "";
  position: absolute;
  left: 1.48rem;
  top: 2.35rem;
  bottom: 0.92rem;
  width: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--input-focus) 28%, transparent);
}

.scan-guide-head {
  position: relative;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.scan-guide-minimized {
  display: none;
  width: 100%;
  padding: 0.58rem 0.72rem;
  border-radius: 999px;
  border: 1px solid var(--ghost-border);
  background: var(--panel-background);
  color: var(--text-strong);
  box-shadow: var(--panel-shadow);
  cursor: pointer;
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-align: left;
  transition: transform 0.18s ease, border-color 0.18s ease, color 0.18s ease, background 0.18s ease;
}

.scan-guide-minimized:hover {
  border-color: var(--input-focus);
  color: var(--input-focus);
}

.scan-guide-note-card.is-hidden,
.scan-guide-card.is-hidden {
  display: none;
}

.scan-guide-note-card.is-minimized,
.scan-guide-card.is-minimized {
  display: none;
}

.scan-guide-note-card.is-minimized + .scan-guide-minimized,
.scan-guide-minimized.is-visible {
  display: inline-flex;
  align-items: center;
  justify-content: flex-start;
}

.scan-guide-title {
  color: var(--text-soft);
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.scan-guide-controls {
  display: inline-flex;
  gap: 0.32rem;
}

.scan-guide-control {
  width: 24px;
  height: 24px;
  min-width: 24px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--ghost-border);
  background: var(--ghost-background);
  color: var(--ghost-text);
  cursor: pointer;
  font-size: 0.72rem;
  line-height: 1;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.scan-guide-control:hover {
  border-color: var(--input-focus);
  color: var(--input-focus);
  background: color-mix(in srgb, var(--ghost-background) 86%, var(--input-focus) 14%);
}

.scan-guide-body {
  display: grid;
  gap: 0.48rem;
}

.scan-guide-note {
  color: var(--text-muted);
  font-size: 0.71rem;
  line-height: 1.45;
  padding: 0.58rem 0.64rem;
  border-radius: 10px;
  border: 1px solid var(--chip-border);
  background: color-mix(in srgb, var(--chip-background) 78%, transparent);
}

.scan-guide-step {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr);
  gap: 0.55rem;
  align-items: start;
  padding: 0.58rem 0.62rem;
  border-radius: 12px;
  border: 1px solid var(--card-border);
  background: var(--card-background);
  transition: border-color 0.18s ease, transform 0.18s ease, box-shadow 0.18s ease, background 0.18s ease;
}

.scan-guide-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  border: 1px solid var(--chip-border);
  background: var(--chip-background);
  color: var(--chip-text);
  font-size: 0.72rem;
  font-weight: 700;
}

.scan-guide-step strong {
  display: block;
  color: var(--text-strong);
  font-size: 0.77rem;
  line-height: 1.2;
}

.scan-guide-step p {
  margin: 0.18rem 0 0;
  color: var(--text-soft);
  font-size: 0.69rem;
  line-height: 1.45;
}

.scan-guide-step.active {
  border-color: color-mix(in srgb, var(--input-focus) 45%, var(--card-border));
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--input-focus) 18%, transparent);
  transform: translateX(2px);
}

.scan-guide-step.active .scan-guide-index {
  background: var(--score-background);
  color: var(--score-text);
  border-color: transparent;
}

.scan-guide-step.done .scan-guide-index {
  background: var(--type-product-background);
  color: var(--type-product-text);
  border-color: var(--type-product-border);
}

.input-section {
  background: var(--section-background);
  border: 1px solid var(--section-border);
  border-radius: 16px;
  padding: 1.55rem;
  box-shadow: var(--panel-shadow);
}

.input-group {
  margin-bottom: 1rem;
}

.input-group label {
  display: block;
  font-size: 0.85rem;
  color: var(--text-muted);
  margin-bottom: 0.4rem;
  font-weight: 600;
}

.input-group input {
  width: 100%;
  padding: 0.75rem 1rem;
  background: var(--input-background);
  border: 1px solid var(--input-border);
  border-radius: 8px;
  color: var(--text-main);
  font-size: 1rem;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.input-group input:focus {
  outline: none;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--input-focus) 18%, transparent);
}

.input-group .hint {
  font-size: 0.75rem;
  color: var(--text-soft);
  margin-top: 0.3rem;
  line-height: 1.45;
}

.role-chips {
  display: flex;
  gap: 0.45rem;
  flex-wrap: wrap;
  margin-top: 0.55rem;
}

.role-chip-label {
  margin-top: 0.7rem;
  color: var(--text-soft);
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.role-chip {
  background: var(--chip-background);
  border: 1px solid var(--chip-border);
  color: var(--chip-text);
  padding: 0.28rem 0.65rem;
  border-radius: 999px;
  cursor: pointer;
  font-size: 0.72rem;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.role-chip:hover {
  border-color: var(--input-focus);
  color: var(--text-strong);
  background: color-mix(in srgb, var(--chip-background) 72%, var(--input-focus) 28%);
}

.scan-btn {
  width: 100%;
  padding: 0.85rem;
  background: var(--primary-gradient);
  color: var(--primary-ink);
  font-weight: 700;
  font-size: 1rem;
  border: none;
  border-radius: 999px;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.15s, box-shadow 0.2s;
  box-shadow: 0 10px 24px color-mix(in srgb, var(--primary-outline) 24%, transparent);
}

.scan-btn:hover {
  opacity: 0.96;
  transform: translateY(-1px);
}
.scan-btn:disabled { opacity: 0.5; cursor: not-allowed; }

.loading {
  text-align: center;
  padding: 3rem;
  display: none;
}

.loading.active { display: block; }

.loading-copy {
  color: var(--text-muted);
}

.spinner {
  width: 40px;
  height: 40px;
  border: 3px solid var(--spinner-track);
  border-top-color: var(--spinner-head);
  border-radius: 50%;
  animation: spin 0.8s linear infinite;
  margin: 0 auto 1rem;
}

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

.results { display: none; }
.results.active { display: block; }

.results-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
  gap: 0.75rem;
  flex-wrap: wrap;
}

.results-header h2 {
  font-size: 1.3rem;
  color: var(--results-heading);
}

.results-header-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.results-sort-wrap {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
}

.results-sort-label {
  font-size: 0.78rem;
  color: var(--text-soft);
}

.results-sort {
  padding: 0.42rem 0.7rem;
  background: var(--panel-background-soft);
  border: 1px solid var(--panel-border);
  border-radius: 7px;
  color: var(--text-main);
  font-size: 0.8rem;
  margin-right: 0.55rem;
}

.results-sort:focus {
  outline: none;
  border-color: var(--input-focus);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--input-focus) 18%, transparent);
}

.token-cost {
  font-size: 0.8rem;
  color: var(--text-soft);
}

.opp-section {
  margin-bottom: 1.25rem;
}

.opp-section.secondary {
  margin-top: 1.5rem;
}

.opp-section-header {
  margin-bottom: 0.85rem;
}

.opp-section-header h3 {
  color: var(--text-strong);
  font-size: 0.98rem;
  margin-bottom: 0.18rem;
}

.opp-section-header p {
  font-size: 0.78rem;
  color: var(--text-soft);
  line-height: 1.45;
}

.opp-card {
  background: var(--card-background);
  border: 1px solid var(--card-border);
  border-radius: 14px;
  padding: 1.25rem;
  margin-bottom: 1rem;
  transition: border-color 0.2s, transform 0.18s, box-shadow 0.2s, background 0.2s;
  box-shadow: var(--panel-shadow);
}

.opp-card:hover {
  border-color: var(--card-border-hover);
  transform: translateY(-1px);
}

.opp-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 0.5rem;
}

.opp-name {
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--text-strong);
}

.opp-score {
  background: var(--score-background);
  color: var(--score-text);
  font-weight: 700;
  padding: 0.28rem 0.72rem;
  border-radius: 999px;
  font-size: 0.9rem;
  white-space: nowrap;
}

.opp-score.high { background: var(--score-high-background); color: var(--score-high-text); }
.opp-score.mid { background: var(--score-mid-background); color: var(--score-mid-text); }

.opp-score-subtle {
  font-size: 0.68rem;
  color: var(--pill-text);
  background: var(--pill-background);
  border: 1px solid var(--panel-border);
  border-radius: 999px;
  padding: 0.12rem 0.45rem;
}

.opp-desc {
  color: var(--text-muted);
  font-size: 0.9rem;
  margin-bottom: 0.75rem;
  line-height: 1.55;
}

.opp-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 0.5rem;
  font-size: 0.8rem;
  margin-bottom: 0.75rem;
}

.opp-meta-item {
  color: var(--detail-text);
  background: color-mix(in srgb, var(--detail-background) 78%, transparent);
  border: 1px solid var(--detail-border);
  border-radius: 10px;
  padding: 0.55rem 0.65rem;
}

.opp-meta-item strong {
  color: var(--detail-heading);
}

.opp-scores-bar {
  display: flex;
  gap: 0.4rem;
  flex-wrap: wrap;
}

.score-pill {
  font-size: 0.7rem;
  padding: 0.2rem 0.5rem;
  border-radius: 999px;
  background: var(--pill-background);
  color: var(--pill-text);
  border: 1px solid color-mix(in srgb, var(--panel-border) 92%, transparent);
}

.score-pill.good { color: var(--pill-good-text); background: var(--pill-good-background); border-color: color-mix(in srgb, var(--pill-good-text) 26%, transparent); }
.score-pill.ok { color: var(--pill-ok-text); background: var(--pill-ok-background); border-color: color-mix(in srgb, var(--pill-ok-text) 22%, transparent); }
.score-pill.low { color: var(--pill-low-text); background: var(--pill-low-background); border-color: color-mix(in srgb, var(--pill-low-text) 22%, transparent); }

.opp-risk {
  font-size: 0.8rem;
  color: var(--danger-text);
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px solid var(--divider);
}

.error {
  background: var(--error-background);
  border: 1px solid var(--error-border);
  color: var(--error-text);
  padding: 1rem;
  border-radius: 8px;
  display: none;
}

.error.active { display: block; }

.api-note {
  text-align: center;
  font-size: 0.75rem;
  color: var(--text-soft);
  margin-top: 2rem;
  padding-top: 1rem;
  border-top: 1px solid var(--divider);
}

.api-note a { color: var(--link-color); text-decoration: none; }

.history-section {
  margin-top: 2rem;
  padding-top: 1.5rem;
  border-top: 1px solid var(--divider);
}

.history-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 1rem;
}

.history-header h2 {
  font-size: 1.2rem;
  color: var(--text-muted);
}

.history-toggle,
.theme-toggle,
.export-btn,
.shortlist-btn,
.action-btn,
.pref-btn {
  background: none;
  border: 1px solid var(--ghost-border);
  color: var(--ghost-text);
  padding: 0.4rem 0.8rem;
  border-radius: 999px;
  cursor: pointer;
  font-size: 0.8rem;
  transition: border-color 0.15s, color 0.15s, background 0.15s, transform 0.15s;
}

.history-toggle:hover,
.theme-toggle:hover,
.export-btn:hover,
.shortlist-btn:hover,
.action-btn:hover,
.pref-btn:hover {
  border-color: var(--input-focus);
  color: var(--input-focus);
  background: color-mix(in srgb, var(--ghost-background) 86%, var(--input-focus) 14%);
}

.theme-toggle {
  font-weight: 600;
}

.history-list { display: none; }
.history-list.active { display: block; }

.history-item {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 0.6rem 0.8rem;
  background: var(--card-background);
  border: 1px solid var(--card-border);
  border-radius: 10px;
  margin-bottom: 0.4rem;
  cursor: pointer;
  transition: border-color 0.2s, transform 0.15s;
}

.history-item:hover {
  border-color: var(--card-border-hover);
  transform: translateY(-1px);
}

.history-item-info {
  display: flex;
  gap: 1rem;
  align-items: center;
  font-size: 0.85rem;
  min-width: 0;
}

.history-item-actions {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.history-item-topic { color: var(--text-strong); font-weight: 600; }
.history-item-meta { color: var(--text-soft); font-size: 0.75rem; }
.history-item-score { color: var(--results-heading); font-weight: 700; font-size: 0.85rem; }

.history-version-badge {
  display: inline-flex;
  align-items: center;
  margin-left: 0.4rem;
  padding: 0.12rem 0.38rem;
  border-radius: 999px;
  border: 1px solid var(--panel-border);
  font-size: 0.64rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--chip-text);
  background: var(--chip-background);
}

.history-version-badge.current {
  border-color: var(--type-product-border);
  color: var(--type-product-text);
  background: var(--type-product-background);
}

.history-version-badge.legacy {
  border-color: var(--panel-border);
  color: var(--text-soft);
  background: var(--panel-background-soft);
}

.history-compare-hint {
  display: none;
  margin-bottom: 0.85rem;
  padding: 0.65rem 0.85rem;
  border: 1px solid var(--history-hint-border);
  border-radius: 8px;
  background: var(--history-hint-background);
  color: var(--history-hint-text);
  font-size: 0.78rem;
}

.history-compare-hint.active {
  display: block;
}

.export-btn {
  padding: 0.34rem 0.72rem;
  font-size: 0.75rem;
  margin-left: 0.5rem;
}

.phase-tracker {
  text-align: center;
  padding: 2rem;
  display: none;
}

.phase-tracker.active { display: block; }

.phase-steps {
  display: flex;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 1.5rem;
}

.phase-step {
  display: flex;
  align-items: center;
  gap: 0.3rem;
  font-size: 0.75rem;
  color: var(--text-soft);
  padding: 0.3rem 0.6rem;
  border-radius: 999px;
  background: var(--panel-background-soft);
  border: 1px solid var(--panel-border);
}

.phase-step.active {
  color: var(--input-focus);
  background: color-mix(in srgb, var(--chip-background) 84%, var(--panel-background-soft) 16%);
  border-color: color-mix(in srgb, var(--input-focus) 28%, var(--panel-border));
}

.phase-step.done {
  color: var(--type-product-text);
  background: var(--type-product-background);
  border-color: var(--type-product-border);
}

.phase-message {
  color: var(--text-muted);
  font-size: 0.9rem;
  display: inline-flex;
  gap: 0.65rem;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
}

.phase-elapsed {
  color: var(--chip-text);
  font-size: 0.78rem;
  font-weight: 700;
  padding: 0.18rem 0.45rem;
  border: 1px solid var(--chip-border);
  border-radius: 999px;
  background: var(--chip-background);
}

.research-panel {
  background: var(--research-background);
  border: 1px solid var(--research-border);
  border-radius: 14px;
  padding: 1rem;
  margin-bottom: 1rem;
  display: none;
}

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

.research-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
}

.research-panel h3 {
  color: var(--research-heading);
  font-size: 0.9rem;
  margin: 0;
}

.research-toggle {
  width: 28px;
  height: 28px;
  min-width: 28px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  border: 1px solid var(--ghost-border);
  background: var(--ghost-background);
  color: var(--ghost-text);
  cursor: pointer;
  font-size: 0.88rem;
  line-height: 1;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}

.research-toggle:hover {
  border-color: var(--input-focus);
  color: var(--input-focus);
  background: color-mix(in srgb, var(--ghost-background) 86%, var(--input-focus) 14%);
}

.research-panel-body {
  margin-top: 0.6rem;
}

.research-panel-body.is-collapsed {
  display: none;
}

.research-panel .sources {
  font-size: 0.75rem;
  color: var(--text-soft);
}

.research-cache-note {
  display: none;
  margin-top: 0.75rem;
  font-size: 0.76rem;
  color: var(--warning-chip-text);
  line-height: 1.5;
}

.research-cache-note.active {
  display: block;
}

.research-panel .sources a {
  color: var(--research-link);
  text-decoration: none;
}

.research-panel .sources a:hover { text-decoration: underline; }

.sources-label {
  color: var(--text-soft);
}

.citation-notice {
  font-size: 0.75rem;
  color: var(--warning-chip-text);
  margin-top: 0.5rem;
}

.research-findings {
  display: grid;
  gap: 0.65rem;
  max-height: 320px;
  overflow-y: auto;
  padding-right: 0.25rem;
}

.research-empty {
  margin: 0;
  font-size: 0.8rem;
  color: var(--text-muted);
}

.research-item {
  padding: 0.72rem 0.78rem;
  border-radius: 12px;
  border: 1px solid var(--card-border);
  background: var(--card-background);
  box-shadow: var(--panel-shadow);
}

.research-item-head {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  margin-bottom: 0.45rem;
}

.research-item-index,
.research-item-type {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 0.67rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.research-item-index {
  min-width: 24px;
  height: 24px;
  padding: 0 0.38rem;
  border: 1px solid var(--chip-border);
  background: var(--chip-background);
  color: var(--chip-text);
}

.research-item-type {
  padding: 0.22rem 0.5rem;
  border: 1px solid var(--detail-border);
  background: var(--panel-background-soft);
  color: var(--text-soft);
}

.research-item-title {
  margin: 0 0 0.28rem;
  font-size: 0.86rem;
  color: var(--text-strong);
  line-height: 1.35;
}

.research-item-detail {
  margin: 0;
  font-size: 0.77rem;
  color: var(--text-soft);
  line-height: 1.5;
}

.research-item-tool .research-item-type {
  color: var(--type-product-text);
  border-color: var(--type-product-border);
  background: var(--type-product-background);
}

.research-item-complaint .research-item-type {
  color: var(--warning-chip-text);
  border-color: var(--warning-chip-border);
  background: var(--warning-chip-background);
}

.research-item-trend .research-item-type {
  color: var(--score-text);
  border-color: var(--score-border);
  background: var(--score-background);
}

.research-item-gap .research-item-type {
  color: var(--chip-text);
  border-color: var(--chip-border);
  background: color-mix(in srgb, var(--chip-background) 82%, transparent);
}

.opp-evidence {
  font-size: 0.78rem;
  color: var(--link-color);
  margin-top: 0.4rem;
  font-style: italic;
}

.opp-competitors {
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-top: 0.4rem;
  padding-top: 0.4rem;
  border-top: 1px solid var(--divider);
}

.opp-competitors strong { color: var(--warning-chip-text); }

.opp-market-gap {
  font-size: 0.78rem;
  color: var(--type-product-text);
  margin-top: 0.3rem;
}

.opp-novelty {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.55rem;
}

.opp-novelty-pill {
  display: inline-flex;
  align-items: center;
  font-size: 0.68rem;
  border-radius: 999px;
  padding: 0.16rem 0.45rem;
  border: 1px solid var(--warning-chip-border);
  background: var(--warning-chip-background);
  color: var(--warning-chip-text);
}

.opp-detail-block {
  margin-top: 0.7rem;
  padding: 0.75rem 0.85rem;
  border: 1px solid var(--detail-border);
  border-radius: 12px;
  background: var(--detail-background);
}

.opp-detail-block h4 {
  color: var(--detail-heading);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-bottom: 0.45rem;
}

.opp-detail-line {
  color: var(--detail-text);
  font-size: 0.78rem;
  line-height: 1.5;
}

.opp-detail-line + .opp-detail-line {
  margin-top: 0.22rem;
}

.opp-detail-line strong {
  color: var(--detail-strong);
}

.opp-type-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  margin-bottom: 0.65rem;
}

.opp-type-badge {
  display: inline-flex;
  align-items: center;
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: 999px;
  padding: 0.16rem 0.48rem;
  border: 1px solid var(--chip-border);
  color: var(--chip-text);
  background: var(--chip-background);
  font-weight: 700;
}

.opp-type-badge.product {
  border-color: var(--type-product-border);
  color: var(--type-product-text);
  background: var(--type-product-background);
}

.opp-type-badge.service {
  border-color: var(--type-service-border);
  color: var(--type-service-text);
  background: var(--type-service-background);
}

.opp-type-badge.content {
  border-color: var(--type-content-border);
  color: var(--type-content-text);
  background: var(--type-content-background);
}

/* ── Opportunity action bar ── */
.opp-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.75rem;
  padding-top: 0.75rem;
  border-top: 1px solid var(--divider);
  flex-wrap: wrap;
}

.action-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  padding: 0.3rem 0.7rem;
  font-size: 0.75rem;
  border-radius: 999px;
}

.action-btn.copied { border-color: var(--type-product-border); color: var(--type-product-text); }
.action-btn.copy-image-btn:hover { border-color: var(--type-service-border); color: var(--type-service-text); }
.action-btn.x-btn:hover { border-color: var(--text-strong); color: var(--text-strong); }
.action-btn.brief-btn:hover { border-color: var(--type-content-border); color: var(--type-content-text); }
.action-btn.preview-btn { border-color: #8b5cf6; color: #8b5cf6; }
.action-btn.preview-btn:hover { background: #8b5cf6; color: #fff; }
.action-btn.getbuilt-btn { border-color: #10b981; color: #10b981; }
.action-btn.getbuilt-btn:hover { background: #10b981; color: #fff; }
.action-btn.loading { opacity: 0.7; cursor: wait; }

.shortlist-btn.preview-btn { border-color: #8b5cf6; color: #8b5cf6; }
.shortlist-btn.preview-btn:hover { background: #8b5cf6; color: #fff; }
.shortlist-btn.getbuilt-btn { border-color: #10b981; color: #10b981; }
.shortlist-btn.getbuilt-btn:hover { background: #10b981; color: #fff; }

/* ── Get It Built Modal ── */
.getbuilt-opp-name {
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--text-strong);
  margin-bottom: 0.5rem;
}

.getbuilt-price {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
  background: var(--pill-bg, rgba(251, 191, 36, 0.1));
  border: 1px solid var(--pill-border, rgba(251, 191, 36, 0.25));
  border-radius: 0.75rem;
  padding: 0.75rem 1rem;
  margin-bottom: 1rem;
}

.getbuilt-price-range {
  font-size: 1.35rem;
  font-weight: 700;
  color: var(--text-strong);
  letter-spacing: -0.02em;
}

.getbuilt-price-label {
  font-size: 0.75rem;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.getbuilt-success {
  margin-top: 0.75rem;
  padding: 0.75rem 1rem;
  background: rgba(16, 185, 129, 0.1);
  border: 1px solid rgba(16, 185, 129, 0.3);
  border-radius: 0.5rem;
  color: #10b981;
  font-weight: 500;
  text-align: center;
}

#getBuiltModal input,
#getBuiltModal textarea,
#feedbackModal input,
#feedbackModal textarea {
  width: 100%;
  padding: 0.55rem 0.75rem;
  border: 1px solid var(--divider);
  border-radius: 0.45rem;
  background: var(--input-bg, var(--card-bg));
  color: var(--text-strong);
  font-size: 0.9rem;
  font-family: inherit;
  box-sizing: border-box;
}

#getBuiltModal input:focus,
#getBuiltModal textarea:focus,
#feedbackModal input:focus,
#feedbackModal textarea:focus {
  outline: none;
  border-color: var(--accent, #3b82f6);
  box-shadow: 0 0 0 2px rgba(59, 130, 246, 0.15);
}

/* ── Build Brief Modal ── */
.modal-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: var(--overlay-background);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}

.modal-overlay.active { display: flex; }

.modal {
  background: var(--modal-background);
  border: 1px solid var(--modal-border);
  border-radius: 18px;
  width: 100%;
  max-width: 580px;
  max-height: 90vh;
  overflow-y: auto;
  box-shadow: var(--panel-shadow);
}

.pricing-modal { max-width: 880px; }
.compare-modal { max-width: 920px; }

.modal-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 1.25rem 1.5rem 0;
}

.modal-header h3 {
  color: var(--text-strong);
  font-size: 1rem;
  font-weight: 700;
}

.modal-close {
  background: none;
  border: none;
  color: var(--text-soft);
  font-size: 1.1rem;
  cursor: pointer;
  padding: 0.2rem 0.4rem;
  border-radius: 4px;
  transition: color 0.15s;
}

.modal-close:hover { color: var(--text-strong); }

.modal-body { padding: 1.25rem 1.5rem 1.5rem; }

.pricing-copy {
  color: var(--text-muted);
  margin-bottom: 1rem;
  line-height: 1.5;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 0.9rem;
}

.pricing-card {
  background: var(--detail-background);
  border: 1px solid var(--detail-border);
  border-radius: 14px;
  padding: 1rem;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.pricing-card.current {
  border-color: var(--input-focus);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--input-focus) 30%, transparent);
}

.pricing-card h4 {
  color: var(--text-strong);
  font-size: 1rem;
}

.pricing-price {
  color: var(--results-heading);
  font-size: 1.35rem;
  font-weight: 800;
}

.pricing-subtitle {
  color: var(--text-soft);
  font-size: 0.78rem;
}

.pricing-card ul {
  padding-left: 1rem;
  color: var(--text-muted);
  font-size: 0.82rem;
  line-height: 1.5;
}

.pricing-card li + li {
  margin-top: 0.25rem;
}

.pricing-card .scan-btn {
  margin-top: auto;
}

.compare-layout {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1rem;
}

.compare-column {
  background: var(--detail-background);
  border: 1px solid var(--detail-border);
  border-radius: 14px;
  padding: 1rem;
}

.compare-column-head {
  position: sticky;
  top: 0;
  z-index: 1;
  margin: -0.2rem -0.2rem 0.75rem;
  padding: 0.2rem;
  background: color-mix(in srgb, var(--detail-background) 92%, transparent);
  backdrop-filter: blur(8px);
}

.compare-column h4 {
  color: var(--text-strong);
  margin-bottom: 0.35rem;
}

.compare-meta {
  color: var(--text-soft);
  font-size: 0.78rem;
  margin-bottom: 0.9rem;
}

.compare-list {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}

.compare-item {
  border: 1px solid var(--panel-border);
  border-radius: 10px;
  padding: 0.7rem;
  background: var(--card-background);
}

.compare-item strong {
  color: var(--text-strong);
  display: block;
  margin-bottom: 0.25rem;
}

.compare-item span {
  color: var(--text-muted);
  font-size: 0.8rem;
}

.pref-group { margin-bottom: 1rem; }

.pref-group label {
  display: block;
  font-size: 0.78rem;
  color: var(--text-muted);
  margin-bottom: 0.5rem;
  font-weight: 600;
}

.pref-options { display: flex; gap: 0.4rem; flex-wrap: wrap; }

.pref-btn {
  background: var(--panel-background-soft);
  padding: 0.35rem 0.75rem;
  font-size: 0.78rem;
  border-radius: 999px;
}

.pref-btn.active {
  border-color: var(--input-focus);
  color: var(--input-focus);
  background: color-mix(in srgb, var(--chip-background) 84%, var(--panel-background-soft) 16%);
}

.brief-pre {
  background: var(--panel-background-soft);
  border: 1px solid var(--panel-border);
  border-radius: 12px;
  padding: 1rem;
  font-size: 0.75rem;
  color: var(--text-muted);
  white-space: pre-wrap;
  word-break: break-word;
  max-height: 340px;
  overflow-y: auto;
  line-height: 1.6;
  font-family: 'Menlo', 'Monaco', 'Consolas', monospace;
}

.brief-output-actions {
  display: flex;
  gap: 0.5rem;
  margin-top: 1rem;
}

.opp-warning {
  margin-top: 0.55rem;
  font-size: 0.77rem;
  color: var(--warning-text);
  background: var(--warning-background);
  border: 1px solid var(--warning-border);
  border-radius: 10px;
  padding: 0.5rem 0.65rem;
}

/* ── Shortlist / selection ── */
.opp-card.selected {
  border-color: var(--card-border-selected);
  background: var(--card-background-selected);
  box-shadow: 0 0 0 1px color-mix(in srgb, var(--card-border-selected) 28%, transparent);
}

.opp-right {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  flex-shrink: 0;
}

.select-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text-faint);
  padding: 0;
  line-height: 1;
  transition: color 0.15s, transform 0.1s;
  display: flex;
  align-items: center;
}

.select-btn:hover { color: var(--input-focus); transform: scale(1.15); }
.select-btn.active { color: var(--input-focus); }

.shortlist-bar {
  display: none;
  align-items: center;
  justify-content: space-between;
  background: var(--history-hint-background);
  border: 1px solid var(--history-hint-border);
  border-radius: 12px;
  padding: 0.6rem 1rem;
  margin-bottom: 1rem;
}

.shortlist-bar.active { display: flex; }

#shortlistCount {
  color: var(--results-heading);
  font-weight: 700;
  font-size: 0.9rem;
}

.shortlist-actions {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  flex-wrap: wrap;
}

.shortlist-btn {
  padding: 0.34rem 0.7rem;
  font-size: 0.8rem;
  margin-left: 0.5rem;
}

.shortlist-btn.primary {
  background: var(--primary-gradient);
  border-color: transparent;
  color: var(--primary-ink);
  font-weight: 600;
}

.shortlist-btn.primary:hover {
  background: var(--primary-gradient);
  border-color: transparent;
  color: var(--primary-ink);
  opacity: 0.85;
}

.smart-badge {
  display: inline-block;
  font-size: 0.65rem;
  background: var(--type-product-background);
  color: var(--type-product-text);
  padding: 0.15rem 0.4rem;
  border-radius: 999px;
  margin-left: 0.5rem;
  font-weight: 600;
  vertical-align: middle;
  border: 1px solid var(--type-product-border);
}

.smart-badge.cached {
  background: var(--warning-chip-background);
  color: var(--warning-chip-text);
  border-color: var(--warning-chip-border);
}

#billingMode:disabled,
#provider:disabled,
#apiKey:disabled,
.scan-btn:disabled,
.history-toggle:disabled,
.theme-toggle:disabled,
.export-btn:disabled,
.shortlist-btn:disabled,
.pref-btn:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

.empty-state,
.history-list > p {
  color: var(--empty-text);
  font-size: 0.85rem;
}

@media (max-width: 720px) {
  .mode-row,
  .compare-layout {
    grid-template-columns: 1fr;
    display: grid;
  }

  .account-panel {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: start;
  }

  .account-actions {
    justify-content: flex-end;
  }

  .account-progress {
    text-align: left;
  }

  .mode-row select {
    width: 100%;
  }

  .input-select,
  .mode-static {
    width: 100%;
  }

  .shortlist-bar {
    align-items: flex-start;
    gap: 0.75rem;
    flex-direction: column;
  }

  .header {
    padding-top: 3.65rem;
  }

  .header-controls {
    top: 0.7rem;
    right: 0.7rem;
  }

  .header-launchpad {
    grid-template-columns: 1fr;
    display: grid;
  }

  .header-launchpad-shell {
    padding: 0.9rem;
  }

  .header-hero-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .header-launchpad {
    grid-template-columns: 1fr;
  }

  .scanner-workspace {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0.9rem;
  }

  .scan-guide {
    position: static;
    width: auto;
    z-index: auto;
  }

  .scan-guide-minimized {
    width: auto;
  }

  .results-header {
    align-items: stretch;
  }

  .results-header-actions {
    justify-content: flex-start;
    width: 100%;
  }

  .results-sort-wrap {
    margin-right: auto;
  }

  .history-item {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.7rem;
  }

  .history-item-info,
  .history-item-actions {
    width: 100%;
  }

  .history-item-actions {
    justify-content: flex-start;
  }

  .opp-header {
    flex-direction: column;
    gap: 0.65rem;
  }

  .opp-right {
    width: 100%;
    flex-direction: row;
    justify-content: space-between;
    align-items: center;
  }

  .compare-layout {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 560px) {
  .header {
    padding: 3.7rem 0.9rem 1.05rem;
  }

  .header-app-brand {
    font-size: 0.72rem;
  }

  .header-launchpad-shell {
    border-radius: 18px;
    padding: 0.8rem;
  }

  .header h1 {
    font-size: 1.72rem;
  }

  .header-copy-card {
    padding: 0.72rem 0.82rem 0.68rem;
    border-radius: 16px;
  }

  .header-brand-card {
    padding: 0.68rem 0.82rem 0.62rem;
    border-radius: 16px;
  }

  .header-subtitle {
    font-size: 0.92rem;
    max-width: none;
  }

  .header .tagline {
    font-size: 0.77rem;
    max-width: none;
  }

  .header-hero-card {
    padding: 0.78rem 0.85rem;
  }

  .header-hero-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 0.42rem;
  }

  .header-metric {
    padding: 0.52rem 0.55rem;
  }

  .header-metric strong {
    font-size: 0.82rem;
  }

  .header-metric span {
    font-size: 0.61rem;
  }

  .container {
    padding: 1.2rem 0.8rem 2rem;
  }

  .scan-guide-card {
    padding: 0.9rem 0.85rem;
  }

  .scan-guide-card::before {
    left: 1.78rem;
  }

  .input-section,
  .account-panel,
  .research-panel,
  .opp-card {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .modal-overlay {
    padding: 0.65rem;
  }

  .modal-header,
  .modal-body {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .results-header {
    gap: 0.6rem;
  }

  .results-header-actions {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto auto;
    align-items: center;
    gap: 0.45rem;
  }

  .results-sort-wrap {
    min-width: 0;
    display: grid;
    grid-template-columns: auto minmax(0, 1fr);
    align-items: center;
    gap: 0.35rem;
    margin-right: 0;
  }

  .results-sort {
    width: 100%;
    margin-right: 0;
    min-width: 0;
  }

  .results-sort-label {
    white-space: nowrap;
  }

  .token-cost {
    grid-column: 1 / -1;
    font-size: 0.72rem;
  }

  .opp-meta {
    grid-template-columns: 1fr;
  }

  .opp-actions {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.5rem;
  }

  .action-btn {
    width: 100%;
    justify-content: center;
    padding-left: 0.55rem;
    padding-right: 0.55rem;
  }

  .shortlist-bar {
    padding: 0.7rem 0.8rem;
  }

  .shortlist-actions,
  .brief-output-actions {
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    align-items: stretch;
    gap: 0.45rem;
  }

  .shortlist-btn,
  .brief-output-actions .shortlist-btn {
    margin-left: 0;
    width: 100%;
  }

  .compare-column-head {
    margin-left: -0.1rem;
    margin-right: -0.1rem;
    padding-bottom: 0.35rem;
    border-bottom: 1px solid var(--detail-border);
  }

  .account-panel {
    grid-template-columns: 1fr;
    gap: 0.7rem;
    padding-top: 0.9rem;
    padding-bottom: 0.9rem;
  }

  .account-actions {
    width: 100%;
    justify-content: space-between;
    align-items: center;
  }

  .account-progress {
    display: none;
  }

  .history-toggle {
    margin-left: auto;
  }
}

/* ── Privacy notice ── */
.getbuilt-privacy { font-size: 0.72rem; color: var(--text-soft); margin: 0.5rem 0 0.25rem; line-height: 1.4; }

/* ── Token cost pill ── */
.token-cost-pill { display: inline-block; font-size: 0.72rem; padding: 0.2rem 0.6rem; border-radius: 999px; background: var(--pill-background); color: var(--pill-text); border: 1px solid var(--panel-border); font-weight: 600; }

/* ── Feedback FAB + intro ── */
.feedback-fab {
  position: fixed; bottom: 1.5rem; right: 1.5rem; z-index: 90;
  width: 48px; height: 48px; border-radius: 50%; border: none;
  background: var(--primary-gradient); color: var(--primary-ink);
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 4px 14px color-mix(in srgb, var(--primary-outline) 28%, transparent);
  transition: transform 0.15s;
}
.feedback-fab:hover { transform: scale(1.08); }
body.modal-open .feedback-fab { display: none; }
.feedback-intro { font-size: 0.85rem; color: var(--text-muted); margin-bottom: 0.75rem; line-height: 1.5; }
