:root {
  color-scheme: light;
  font-family: "Noto Sans TC", "Segoe UI", Arial, sans-serif;
  background: #f6f7f9;
  color: #1f2933;
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
}

.topbar {
  align-items: center;
  background: #ffffff;
  border-bottom: 1px solid #d8dee7;
  display: flex;
  justify-content: space-between;
  min-height: 84px;
  padding: 18px 28px;
}

.topbar h1 {
  font-size: 24px;
  margin: 0 0 4px;
}

.topbar p,
.section-title span {
  color: #667085;
  margin: 0;
}

.topbar nav:not(.global-nav) {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  justify-content: flex-end;
}

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

.topbar nav:not(.global-nav) a,
.topbar nav:not(.global-nav) summary,
button {
  background: #105c55;
  border: 1px solid #105c55;
  border-radius: 6px;
  color: #ffffff;
  cursor: pointer;
  font-size: 14px;
  line-height: 1;
  padding: 10px 12px;
  text-decoration: none;
}

.topbar nav:not(.global-nav) a[aria-current="page"],
.topbar nav:not(.global-nav) .nav-menu.current summary {
  background: #394150;
  border-color: #394150;
}

.topbar nav:not(.global-nav) .nav-menu {
  position: relative;
}

.topbar nav:not(.global-nav) .nav-menu summary {
  list-style: none;
}

.topbar nav:not(.global-nav) .nav-menu summary::-webkit-details-marker {
  display: none;
}

.topbar nav:not(.global-nav) .nav-menu summary::after {
  content: "▾";
  font-size: 11px;
  margin-left: 7px;
}

.topbar nav:not(.global-nav) .nav-menu[open] summary::after {
  content: "▴";
}

.topbar nav:not(.global-nav) .nav-menu-list {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  box-shadow: 0 10px 28px rgba(20, 31, 43, 0.1);
  display: grid;
  gap: 4px;
  min-width: 170px;
  padding: 8px;
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 20;
}

.topbar nav:not(.global-nav) .nav-menu-list a {
  background: transparent;
  border: 0;
  color: #1f2933;
  justify-content: flex-start;
  line-height: 1.2;
  min-height: 34px;
  width: 100%;
}

.topbar nav:not(.global-nav) .nav-menu-list a:hover,
.topbar nav:not(.global-nav) .nav-menu-list a[aria-current="page"] {
  background: #eef6f5;
  color: #105c55;
}

button:disabled {
  background: #98a2b3;
  border-color: #98a2b3;
  cursor: wait;
}

.shell {
  margin: 0 auto;
  max-width: 1180px;
  padding: 24px;
}

.analysis-shell {
  margin: 0 auto;
  max-width: 1240px;
  padding: 26px;
}

.site-header h1 {
  letter-spacing: 0;
}

.lead-grid {
  display: grid;
  gap: 18px;
  grid-template-columns: minmax(0, 1.18fr) minmax(0, 0.82fr);
  margin-bottom: 26px;
}

.review-band,
.main-pick-band {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  min-width: 0;
  padding: 22px;
}

.latest-draw-hero {
  align-items: center;
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-left: 6px solid #105c55;
  border-radius: 8px;
  display: grid;
  gap: 22px;
  grid-template-columns: minmax(220px, 0.75fr) minmax(360px, 1.2fr) minmax(220px, 0.65fr);
  margin-bottom: 18px;
  min-width: 0;
  padding: 20px 22px;
}

.latest-draw-hero h2 {
  font-size: 28px;
  margin: 0 0 6px;
}

.latest-draw-hero p {
  color: #667085;
  margin: 0;
}

.latest-hero-numbers {
  justify-content: center;
  margin: 0;
}

.latest-hero-note {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  display: grid;
  gap: 4px;
  padding: 12px;
}

.latest-hero-note span {
  color: #667085;
  font-size: 13px;
  line-height: 1.5;
}

.main-pick-band {
  border-left: 6px solid #105c55;
}

.review-band {
  border-left: 6px solid #f2b84b;
}

.eyebrow {
  color: #667085;
  display: block;
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 6px;
}

.compact-title {
  gap: 12px;
}

.compact-title h2 {
  font-size: 24px;
}

.large-numbers,
.hero-numbers {
  margin: 18px 0;
}

.draw-countdown {
  background: #f0fdfa;
  border: 1px solid #99f6e4;
  border-left: 4px solid #105c55;
  border-radius: 8px;
  display: grid;
  gap: 5px;
  margin: 14px 0;
  min-width: 0;
  padding: 12px 14px;
}

.draw-countdown span {
  color: #667085;
  font-size: 12px;
  font-weight: 800;
}

.draw-countdown strong {
  color: #0f3f3a;
  font-size: 26px;
  line-height: 1.15;
  overflow-wrap: anywhere;
}

.draw-countdown small {
  color: #667085;
  font-size: 13px;
  font-weight: 700;
  line-height: 1.45;
}

.draw-countdown.expired {
  background: #fff7ed;
  border-color: #fed7aa;
  border-left-color: #f97316;
}

.draw-countdown.expired strong {
  color: #9a3412;
  font-size: 21px;
}

.mini-section-title {
  align-items: baseline;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 10px;
}

.mini-section-title h3 {
  font-size: 15px;
  margin: 0;
}

.mini-section-title span {
  color: #667085;
  font-size: 12px;
  text-align: right;
}

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

.review-number-row > div {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  padding: 10px;
}

.review-number-row span,
.review-band small {
  color: #667085;
  font-size: 12px;
}

.review-line {
  color: #1f2933;
  font-weight: 800;
}

.review-adjustment {
  border-top: 1px solid #e4e7ec;
  margin-top: 10px !important;
  padding-top: 10px;
}

.ball.large {
  font-size: 20px;
  height: 48px;
  width: 48px;
}

.ball.hero {
  background: #105c55;
  border-color: #105c55;
  color: #ffffff;
  font-size: 28px;
  height: 68px;
  width: 68px;
}

.draw-facts,
.pick-meta,
.probability-meta {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 0;
}

.probability-meta {
  border-top: 1px solid #e4e7ec;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  margin-top: 14px;
  padding-top: 14px;
}

.draw-facts div,
.pick-meta div,
.probability-meta div {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  min-width: 0;
  padding: 10px;
}

.draw-facts dt,
.pick-meta dt,
.probability-meta dt {
  color: #667085;
  font-size: 12px;
  margin-bottom: 5px;
}

.draw-facts dd,
.pick-meta dd,
.probability-meta dd {
  font-weight: 800;
  margin: 0;
  overflow-wrap: anywhere;
}

.probability-meta dd {
  color: #105c55;
}

.analysis-section {
  border-top: 1px solid #d8dee7;
  margin-top: 26px;
  padding-top: 22px;
}

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

.recent-draw,
.backup-pick,
.reason-card,
.verification-card,
.proof-card,
.probability-story-card,
.ai-step,
.pipeline-step,
.valuable-card,
.strategy-factory-card {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  min-width: 0;
  padding: 13px;
}

.recent-draw.latest {
  border-color: #105c55;
  box-shadow: inset 4px 0 0 #105c55;
}

.recent-draw strong,
.backup-head strong {
  display: block;
  font-size: 15px;
}

.recent-draw span,
.backup-head span,
.reason-card span,
.verification-card span {
  color: #667085;
  font-size: 12px;
}

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

.backup-section {
  margin-top: 0;
}

.audit-grid .proof-card {
  border-left: 4px solid #105c55;
}

.audit-grid .proof-card.warning {
  border-left-color: #f2b84b;
}

.playbook-section {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  padding: 18px;
}

.playbook-grid {
  display: block;
}

.playbook-card {
  background: #fbfcfe;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  min-width: 0;
  padding: 14px;
}

.playbook-card.featured {
  border-color: #105c55;
  box-shadow: inset 4px 0 0 #105c55;
}

.playbook-card-head {
  align-items: flex-start;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 8px;
}

.playbook-card-head h3 {
  font-size: 17px;
  line-height: 1.3;
  margin: 0;
}

.playbook-card-head span {
  background: #e7f1ef;
  border: 1px solid #b6d4ce;
  border-radius: 999px;
  color: #105c55;
  flex: 0 0 auto;
  font-size: 12px;
  font-weight: 800;
  padding: 6px 9px;
  white-space: nowrap;
}

.playbook-fit,
.playbook-note,
.playbook-empty,
.playbook-risk {
  color: #344054;
  line-height: 1.7;
  margin: 0;
}

.playbook-note {
  border-top: 1px solid #e4e7ec;
  color: #7a4b00;
  font-size: 13px;
  margin-top: 12px;
  padding-top: 10px;
}

.playbook-risk {
  background: #fff8e7;
  border: 1px solid #f2d28c;
  border-radius: 8px;
  margin-top: 12px;
  padding: 12px;
}

.segmented-row {
  background: #eef2f6;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  display: grid;
  gap: 4px;
  grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
  padding: 4px;
}

.segmented-row button,
.ghost-button {
  border-radius: 6px;
  font-weight: 800;
  min-height: 38px;
}

.segmented-row button {
  background: transparent;
  border-color: transparent;
  color: #344054;
  padding: 9px 8px;
  width: 100%;
}

.segmented-row button.active {
  background: #105c55;
  border-color: #105c55;
  color: #ffffff;
}

.playbook-tabs {
  margin-bottom: 12px;
}

.playbook-panel {
  background: #fbfcfe;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  padding: 16px;
}

.playbook-panel-head {
  align-items: flex-start;
  display: flex;
  gap: 14px;
  justify-content: space-between;
  margin-bottom: 14px;
}

.playbook-panel-head h3 {
  font-size: 20px;
  margin: 0 0 6px;
}

.playbook-panel-head p {
  color: #344054;
  line-height: 1.6;
  margin: 0;
}

.ghost-button {
  background: #ffffff;
  border-color: #b6d4ce;
  color: #105c55;
  flex: 0 0 auto;
}

.playbook-spotlight {
  background: #ffffff;
  border: 1px solid #e4e7ec;
  border-left: 5px solid #105c55;
  border-radius: 8px;
  padding: 14px;
}

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

.playbook-subgrid section {
  background: #ffffff;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  min-width: 0;
  padding: 12px;
}

.playbook-subgrid h4 {
  font-size: 15px;
  margin: 0 0 8px;
}

.playbook-controls {
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
  margin-bottom: 12px;
}

.playbook-controls > div > span {
  color: #667085;
  display: block;
  font-size: 12px;
  font-weight: 800;
  margin-bottom: 6px;
}

.playbook-controls .segmented-row {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.playbook-controls .budget-options {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.budget-plan-head {
  align-items: center;
  background: #ffffff;
  border: 1px solid #b6d4ce;
  border-radius: 8px;
  display: flex;
  gap: 12px;
  justify-content: space-between;
  margin-bottom: 10px;
  padding: 12px;
}

.budget-plan-head span,
.playbook-more-hint {
  color: #667085;
  font-size: 13px;
  margin: 0;
}

.budget-ticket-list {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.playbook-note.compact {
  margin-top: 10px;
}

.playbook-numbers {
  margin: 12px 0;
}

.compact-numbers {
  margin: 6px 0 0;
}

.combo-row,
.drag-block,
.budget-line {
  background: #ffffff;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  margin-top: 10px;
  min-width: 0;
  padding: 10px;
}

.drag-block.featured {
  border-color: #b6d4ce;
}

.combo-label,
.drag-block span,
.budget-line span {
  color: #667085;
  display: block;
  font-size: 12px;
  font-weight: 700;
}

.combo-row small {
  color: #667085;
  display: block;
  line-height: 1.5;
  margin-top: 4px;
}

.budget-list {
  display: grid;
  gap: 8px;
  margin-top: 10px;
}

.budget-line {
  margin-top: 0;
}

.budget-line small {
  color: #667085;
  display: block;
  line-height: 1.5;
}

.budget-line strong {
  display: block;
  margin-bottom: 4px;
}

.playbook-meta {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  margin: 12px 0 0;
}

.playbook-meta div {
  background: #ffffff;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  padding: 9px;
}

.playbook-meta dt {
  color: #667085;
  font-size: 12px;
  margin-bottom: 5px;
}

.playbook-meta dd {
  color: #1f2933;
  font-weight: 800;
  line-height: 1.5;
  margin: 0;
  overflow-wrap: anywhere;
}

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

.backup-pick small {
  color: #667085;
  display: block;
  margin-bottom: 8px;
}

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

.reason-card strong,
.verification-card strong {
  display: block;
  font-size: 22px;
  margin: 8px 0;
  overflow-wrap: anywhere;
}

.reason-card p,
.ai-step p,
.settlement-box p,
.strategy-band p,
.main-pick-band p,
.review-band p {
  color: #344054;
  line-height: 1.7;
  margin: 0;
}

.split-section {
  display: grid;
  gap: 24px;
  grid-template-columns: minmax(0, 1.15fr) minmax(0, 0.85fr);
}

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

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

.proof-card {
  background: #fbfcfe;
}

.proof-card span,
.probability-story-card span,
.number-detail-grid span {
  color: #667085;
  display: block;
  font-size: 12px;
  margin-bottom: 7px;
}

.proof-card strong,
.probability-story-card strong,
.number-detail-grid strong {
  display: block;
  font-size: 19px;
  overflow-wrap: anywhere;
}

.probability-story {
  margin-bottom: 12px;
}

.probability-story-card p {
  color: #344054;
  line-height: 1.6;
  margin: 8px 0 0;
}

.settlement-box {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  min-height: 142px;
  padding: 16px;
}

.playbook-settlement {
  border-top: 1px solid #e4e7ec;
  margin-top: 14px;
  padding-top: 14px;
}

.settlement-subtitle {
  align-items: baseline;
  display: flex;
  gap: 10px;
  justify-content: space-between;
  margin-bottom: 10px;
}

.settlement-subtitle span,
.settlement-hit-row small,
.settlement-empty,
.settlement-budget-row span {
  color: #667085;
  font-size: 12px;
  line-height: 1.5;
}

.settlement-play-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
}

.settlement-play-grid article,
.settlement-budget-row {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  min-width: 0;
  padding: 10px;
}

.settlement-play-grid article > span {
  color: #667085;
  display: block;
  font-size: 12px;
  margin-bottom: 5px;
}

.settlement-play-grid article > strong,
.settlement-budget-row strong {
  display: block;
  line-height: 1.5;
  overflow-wrap: anywhere;
}

.settlement-hit-row {
  border-top: 1px solid #e4e7ec;
  margin-top: 8px;
  padding-top: 8px;
}

.settlement-empty {
  margin: 8px 0 0;
}

.settlement-budget-list {
  display: grid;
  gap: 8px;
  margin-top: 8px;
}

.status-badge {
  background: #fff4d6;
  border: 1px solid #f2b84b;
  border-radius: 999px;
  color: #7a4b00;
  display: inline-flex;
  font-weight: 800;
  padding: 8px 12px;
  white-space: nowrap;
}

.status-badge.good {
  background: #e7f8ef;
  border-color: #8bd3a7;
  color: #087443;
}

.status-badge.caution {
  background: #fff4d6;
  border-color: #f2b84b;
}

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

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

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

.pipeline-step span,
.ai-step span {
  align-items: center;
  background: #105c55;
  border-radius: 50%;
  color: #ffffff;
  display: inline-flex;
  font-weight: 800;
  height: 28px;
  justify-content: center;
  margin-bottom: 12px;
  width: 28px;
}

.pipeline-step strong,
.ai-step strong {
  display: block;
  margin-bottom: 8px;
}

.pipeline-step p,
.valuable-card p,
.strategy-factory-card p,
.strategy-factory-card small {
  color: #344054;
  line-height: 1.7;
}

.lab-meta {
  margin-top: 14px;
}

.admin-details {
  margin-top: 12px;
}

.strategy-band {
  align-items: center;
  display: flex;
  justify-content: space-between;
}

.strategy-band h2 {
  margin: 0 0 6px;
}

.hero-panel {
  align-items: center;
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-left: 6px solid #105c55;
  border-radius: 8px;
  display: flex;
  justify-content: space-between;
  margin-bottom: 18px;
  padding: 20px;
}

.hero-panel h2 {
  font-size: 22px;
  margin: 0 0 8px;
}

.hero-panel p {
  color: #52606d;
  margin: 0;
}

.risk-pill {
  background: #fff4d6;
  border: 1px solid #f2b84b;
  border-radius: 999px;
  color: #7a4b00;
  font-weight: 700;
  padding: 10px 14px;
  white-space: nowrap;
}

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

.metric,
.panel,
.candidate {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
}

.metric {
  padding: 16px;
}

.metric b {
  display: block;
  font-size: 22px;
  margin-top: 6px;
}

.panel {
  margin-bottom: 18px;
  padding: 18px;
}

.section-title {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 14px;
}

.section-title h2 {
  font-size: 18px;
  margin: 0;
}

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

.explain-item {
  background: #f8fafc;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  padding: 14px;
}

.explain-item span {
  color: #667085;
  display: block;
  margin-bottom: 8px;
}

.explain-item b {
  font-size: 20px;
  overflow-wrap: anywhere;
}

.playbook-admin-grid {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.admin-pipeline-grid {
  grid-template-columns: repeat(7, minmax(0, 1fr));
}

.playbook-admin-item {
  border-left: 4px solid #d8dee7;
}

.playbook-admin-item.is-ok {
  border-left-color: #087443;
}

.playbook-admin-item.is-fail {
  border-left-color: #b42318;
}

.pipeline-admin-item {
  border-left: 4px solid #d8dee7;
}

.pipeline-admin-item.is-ok {
  border-left-color: #087443;
}

.pipeline-admin-item.is-waiting {
  border-left-color: #f2b84b;
}

.playbook-admin-item small,
.pipeline-admin-item small {
  color: #52606d;
  display: block;
  line-height: 1.5;
  margin-top: 8px;
  overflow-wrap: anywhere;
}

.plain-list {
  color: #344054;
  line-height: 1.8;
  margin: 0;
  padding-left: 22px;
}

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

.candidate p {
  color: #344054;
  line-height: 1.7;
}

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

.mini-facts div {
  background: #f8fafc;
  border-radius: 6px;
  padding: 8px;
}

.mini-facts dt {
  color: #667085;
  font-size: 12px;
}

.mini-facts dd {
  font-weight: 700;
  margin: 4px 0 0;
}

main details {
  margin: 12px 0;
}

main summary {
  cursor: pointer;
  font-weight: 700;
}

table {
  border-collapse: collapse;
  margin-top: 10px;
  width: 100%;
}

td,
th {
  border-bottom: 1px solid #e4e7ec;
  font-size: 13px;
  padding: 7px 5px;
  text-align: left;
}

.candidate {
  padding: 14px;
}

.numbers {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
}

.ball {
  align-items: center;
  background: #f2b84b;
  border: 1px solid #d49c30;
  border-radius: 50%;
  display: inline-flex;
  font-weight: 700;
  height: 34px;
  justify-content: center;
  width: 34px;
}

.ball.small {
  font-size: 12px;
  height: 28px;
  width: 28px;
}

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

.ticket-line {
  background: #f8fafc;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  padding: 10px;
}

.settlement-row {
  display: grid;
  gap: 12px;
  grid-template-columns: 2fr 1fr 1fr;
}

.settlement-row span {
  color: #667085;
  display: block;
  margin-bottom: 8px;
}

.period-controls {
  align-items: center;
  display: grid;
  gap: 12px;
  grid-template-columns: minmax(0, 1fr) 220px;
}

.period-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
}

.period-chip-row button {
  background: #ffffff;
  border-color: #b6d4ce;
  color: #105c55;
  font-weight: 800;
}

.period-chip-row button.active {
  background: #105c55;
  color: #ffffff;
}

.period-select-wrap {
  display: grid;
  gap: 6px;
  min-width: 0;
}

.period-select-wrap span,
.snapshot-meta span,
.review-visual-grid span,
.strategy-performance-head p,
.strategy-rate {
  color: #667085;
  font-size: 12px;
}

.period-select-wrap select {
  background: #ffffff;
  border: 1px solid #b6d4ce;
  border-radius: 6px;
  color: #1f2933;
  min-height: 38px;
  min-width: 0;
  padding: 8px 10px;
  width: 100%;
}

.snapshot-status {
  background: #f8fafc;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  color: #344054;
  font-weight: 800;
  margin-top: 12px;
  padding: 10px 12px;
}

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

.snapshot-card,
.strategy-performance-card {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-radius: 8px;
  min-width: 0;
  padding: 14px;
}

.snapshot-card.is-empty {
  background: #fbfcfe;
  border-style: dashed;
}

.snapshot-card h3 {
  font-size: 16px;
  margin: 0 0 10px;
}

.snapshot-card p {
  color: #344054;
  line-height: 1.6;
  margin: 10px 0 0;
}

.snapshot-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: space-between;
}

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

.snapshot-lines > div {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  padding: 8px;
}

.review-number-row.compact {
  margin-top: 10px;
}

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

.review-visual-grid > div {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  min-width: 0;
  padding: 9px;
}

.ball.hit {
  background: #18a058;
  border-color: #087443;
  color: #ffffff;
}

.ball.muted,
.ball.pale {
  background: #eef2f6;
  border-color: #cbd5e1;
  color: #667085;
}

.heatmap-grid {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(13, minmax(0, 1fr));
}

.heat-cell {
  background: rgba(16, 92, 85, var(--heat, 0.16));
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  color: #1f2933;
  display: grid;
  gap: 3px;
  line-height: 1.2;
  min-height: 76px;
  min-width: 0;
  padding: 8px;
  text-align: left;
}

.heat-cell.hot {
  border-color: #105c55;
}

.heat-cell.warm {
  border-color: #6ca39b;
}

.heat-cell strong {
  font-size: 18px;
}

.heat-cell.active {
  box-shadow: inset 0 0 0 3px #105c55;
}

.heat-cell span,
.heat-cell small {
  color: #344054;
  font-size: 12px;
  line-height: 1.2;
}

.number-detail-panel {
  background: #ffffff;
  border: 1px solid #d8dee7;
  border-left: 5px solid #105c55;
  border-radius: 8px;
  margin-top: 14px;
  padding: 16px;
}

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

.number-detail-head h3 {
  font-size: 24px;
  margin: 0;
}

.number-detail-panel p {
  color: #344054;
  line-height: 1.7;
  margin: 10px 0;
}

.number-detail-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  margin: 12px 0;
}

.number-detail-grid > div {
  background: #f8fafc;
  border: 1px solid #e4e7ec;
  border-radius: 8px;
  padding: 10px;
}

.number-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: flex-end;
}

.number-badges span {
  background: #e7f1ef;
  border: 1px solid #b6d4ce;
  border-radius: 999px;
  color: #105c55;
  font-size: 12px;
  font-weight: 800;
  padding: 6px 9px;
}

.number-detail-panel small {
  color: #667085;
}

.mobile-bottom-nav {
  display: none;
}

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

.strategy-performance-head strong {
  display: block;
  font-size: 18px;
  margin-bottom: 4px;
}

.strategy-performance-head p,
.strategy-rate {
  line-height: 1.6;
  margin: 0;
}

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

.bar-row {
  align-items: center;
  display: grid;
  gap: 10px;
  grid-template-columns: 70px minmax(0, 1fr) 46px;
}

.bar-row span,
.bar-row strong {
  font-size: 13px;
}

.bar-row strong {
  text-align: right;
}

.bar-track {
  background: #eef2f6;
  border-radius: 999px;
  height: 14px;
  min-width: 0;
  overflow: hidden;
}

.bar-fill {
  background: #105c55;
  border-radius: inherit;
  height: 100%;
  min-width: 4px;
}

.bar-fill.hit-0,
.bar-fill.hit-1 {
  background: #98a2b3;
}

.bar-fill.hit-2,
.bar-fill.hit-3 {
  background: #f2b84b;
}

.bar-fill.hit-4,
.bar-fill.hit-5 {
  background: #18a058;
}

.strategy-rate {
  margin-top: 12px;
}

pre {
  background: #111827;
  border-radius: 8px;
  color: #e5e7eb;
  margin: 0;
  overflow: auto;
  padding: 14px;
  white-space: pre-wrap;
}

.status-ok {
  color: #087443;
}

.status-fail {
  color: #b42318;
}

@media (max-width: 760px) {
  .topbar {
    align-items: flex-start;
    flex-direction: column;
    gap: 14px;
    padding: 16px;
  }

  .topbar nav:not(.global-nav) {
    justify-content: flex-start;
    width: 100%;
  }

  .topbar nav:not(.global-nav) a,
  .topbar nav:not(.global-nav) summary {
    flex: 1 1 140px;
    text-align: center;
  }

  .topbar nav:not(.global-nav) .nav-menu {
    flex: 1 1 140px;
  }

  .topbar nav:not(.global-nav) .nav-menu-list {
    left: 0;
    right: auto;
  }

  .topbar nav:not(.global-nav) .nav-menu[open] {
    flex-basis: 100%;
  }

  .topbar nav:not(.global-nav) .nav-menu[open] .nav-menu-list {
    margin-top: 8px;
    position: static;
  }

  .shell {
    padding: 16px;
  }

  .analysis-shell {
    padding: 16px;
  }

  .latest-draw-hero {
    align-items: stretch;
    gap: 14px;
    grid-template-columns: 1fr;
  }

  .latest-draw-hero h2 {
    font-size: 24px;
  }

  .latest-hero-numbers {
    justify-content: flex-start;
  }

  .metrics,
  .candidate-grid,
  .explain-grid,
  .mini-facts,
  .ticket-grid,
  .settlement-row,
  .lead-grid,
  .recent-strip,
  .backup-grid,
  .reason-grid,
  .proof-grid,
  .probability-story,
  .playbook-grid,
  .split-section,
  .verification-grid,
  .pipeline-grid,
  .valuable-grid,
    .settlement-play-grid,
    .probability-meta,
    .playbook-meta,
    .playbook-admin-grid,
    .admin-pipeline-grid,
    .budget-line,
    .ai-steps,
    .review-number-row,
    .period-controls,
    .snapshot-grid,
    .review-visual-grid,
    .number-detail-grid {
    grid-template-columns: 1fr;
  }

  .section-title {
    align-items: flex-start;
    flex-direction: column;
    gap: 6px;
  }

  .period-chip-row {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .period-chip-row button {
    min-width: 0;
    padding: 10px 8px;
  }

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

  .number-detail-head {
    flex-direction: column;
  }

  .number-badges {
    justify-content: flex-start;
  }

  .mobile-bottom-nav {
    background: #ffffff;
    border-top: 1px solid #d8dee7;
    bottom: 0;
    display: grid;
    gap: 6px;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    left: 0;
    padding: 8px 10px;
    position: fixed;
    right: 0;
    z-index: 10;
  }

  .mobile-bottom-nav a {
    background: #105c55;
    border-radius: 6px;
    color: #ffffff;
    font-size: 13px;
    font-weight: 800;
    padding: 10px 6px;
    text-align: center;
    text-decoration: none;
  }

  body {
    padding-bottom: 62px;
  }

  .strategy-performance-head {
    flex-direction: column;
  }

  .bar-row {
    grid-template-columns: 64px minmax(0, 1fr) 34px;
  }

  .ball.hero {
    font-size: 22px;
    height: 52px;
    width: 52px;
  }

  .ball.large {
    height: 42px;
    width: 42px;
  }

  .hero-panel {
    align-items: flex-start;
    flex-direction: column;
    gap: 14px;
  }

  .segmented-row,
  .playbook-controls .budget-options {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .playbook-panel-head,
  .budget-plan-head {
    align-items: stretch;
    flex-direction: column;
  }

  .ghost-button {
    width: 100%;
  }

  .playbook-subgrid,
  .playbook-controls,
  .budget-ticket-list {
    grid-template-columns: 1fr;
  }
}
