@import url("../challify-admin-context/design-system/cds-tokens.css");
@import url("../challify-admin-context/design-system/cds-chrome.css");
@import url("../challify-admin-context/design-system/cds-components.css");

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  width: 100%;
  height: 100%;
  min-height: 100%;
  overflow: hidden;
  background: var(--cds-color-bg-page);
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-primary);
  -webkit-font-smoothing: antialiased;
}

button,
input,
textarea {
  font: inherit;
}

button {
  -webkit-tap-highlight-color: transparent;
}

#app {
  width: 100%;
  height: 100vh;
  height: 100svh;
  height: 100dvh;
  min-height: 0;
  overflow: hidden;
}

:root {
  /* Toss TDS Mobile의 계층형 typography 접근을 이 프로토타입 role token으로 매핑한다. */
  --app-type-screen-title-size: var(--cds-font-size-18);
  --app-type-screen-title-line: var(--cds-line-height-28);
  --app-type-hero-size: var(--cds-font-size-20);
  --app-type-hero-line: 29px;
  --app-type-section-size: var(--cds-font-size-17);
  --app-type-section-line: var(--cds-line-height-26);
  --app-type-row-size: var(--cds-font-size-15);
  --app-type-row-line: var(--cds-line-height-22);
  --app-type-body-size: var(--cds-font-size-14);
  --app-type-body-line: 21px;
  --app-type-meta-size: var(--cds-font-size-12);
  --app-type-meta-line: var(--cds-line-height-18);
  --app-type-caption-size: 11px;
  --app-type-caption-line: var(--cds-line-height-17);
  --app-phone-width: 390px;
  --app-phone-height: 844px;
  --app-bottom-tabs-height: calc(58px + max(18px, env(safe-area-inset-bottom)));
}

.entry-shell {
  width: 100%;
  max-width: var(--app-phone-width);
  height: 100%;
  min-height: 0;
  margin: 0 auto;
  padding: 36px 16px 20px;
  display: flex;
  flex-direction: column;
  gap: var(--spacing-16);
  overflow-y: auto;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  background: var(--cds-color-page-background);
}

.entry-hero {
  padding: var(--spacing-18, 18px);
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: var(--cds-shadow-card);
}

.brand-mark {
  width: fit-content;
  padding: 8px 12px;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.2px;
}

.eyebrow,
.section-header > span,
.row-meta {
  margin: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-12);
  font-weight: var(--cds-font-weight-semibold);
  line-height: var(--cds-line-height-18);
}

.entry-hero h1,
.hero-card h2,
.card h2,
.section-header h2,
.detail-hero h2,
.settlement-hero strong {
  margin: 0;
  color: var(--cds-color-text-primary);
  letter-spacing: -.3px;
}

.entry-hero h1 {
  margin-top: var(--spacing-10, 10px);
  font-size: 24px;
  line-height: 32px;
}

.entry-hero p,
.card p,
.hero-card p,
.section-header p,
.detail-hero p,
.tool-card p,
.feed-card p,
.revenue-guide-card p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
}

.entry-hero > p:last-child {
  margin-top: var(--spacing-12);
}

.scenario-grid {
  display: grid;
  gap: var(--spacing-8);
}

.scenario-card {
  width: 100%;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-14, 14px);
  text-align: left;
  display: grid;
  gap: var(--spacing-5, 5px);
  cursor: pointer;
  box-shadow: var(--cds-shadow-card);
}

.scenario-card:focus-visible,
.interactive-row:focus-visible,
.bottom-tab:focus-visible,
.row-action:focus-visible,
.chip:focus-visible,
.info-dot:focus-visible,
.appbar-action:focus-visible,
.back-action:focus-visible,
.root-exit-action:focus-visible {
  outline: 0;
  box-shadow: var(--cds-button-focus-ring);
}

.scenario-tier,
.badge {
  width: fit-content;
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  padding: 0 9px;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  font-size: var(--cds-font-size-12);
  font-weight: var(--cds-font-weight-semibold);
  line-height: var(--cds-line-height-18);
}

.scenario-card strong {
  font-size: var(--cds-font-size-16);
  line-height: var(--cds-line-height-22);
}

.scenario-note {
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-13);
  line-height: var(--cds-line-height-18);
}

.scenario-card em {
  color: var(--cds-color-brand-primary-dark);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-style: normal;
  font-weight: var(--cds-font-weight-semibold);
}

.device-shell {
  width: 100%;
  height: 100%;
  min-height: 0;
  display: flex;
  justify-content: center;
  align-items: stretch;
  padding: 0;
  overflow: hidden;
}

.phone {
  position: relative;
  width: 100%;
  height: 100%;
  min-height: 0;
  background: var(--cds-color-page-background);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: none;
}

.appbar {
  position: relative;
  z-index: 3;
}

.appbar.drilldown {
  grid-template-columns: 52px minmax(0, 1fr) 72px;
}

.root-exit-action {
  width: 36px;
  height: 36px;
  min-width: 36px;
  border: 0;
  border-radius: var(--cds-radius-sm);
  background: transparent;
  color: var(--cds-color-text-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  cursor: pointer;
  flex: 0 0 36px;
}

.root-exit-action svg {
  width: 22px;
  height: 22px;
  stroke: currentColor;
  fill: none;
  stroke-width: 2.2;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.appbar.root .root-exit-action {
  margin-left: calc(var(--spacing-4) * -1);
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-secondary);
}

.appbar.root .appbar-actions {
  width: 36px;
  min-width: 36px;
  margin-left: auto;
}

.title-stack {
  min-width: 0;
}

.title-stack h1 {
  font-size: var(--app-type-screen-title-size);
  line-height: var(--app-type-screen-title-line);
  letter-spacing: -.2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.title-stack .freshness {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.appbar-action {
  width: auto;
  min-width: 48px;
  padding: 0 8px;
  font-size: var(--cds-font-size-12);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
}

.appbar-actions .appbar-action,
.appbar.drilldown .appbar-actions .appbar-action {
  width: auto;
  min-width: 64px;
  padding: 0 10px;
}

.back-action {
  color: var(--cds-color-text-primary);
  font-size: 34px;
  line-height: 1;
}

.appbar.drilldown .back-action {
  /*
   * Drilldown back control uses the appbar slot as an invisible touch target.
   * Keep the slot transparent so it does not read as a large broken square
   * surface on deep screens.
   */
  background: transparent;
  box-shadow: none;
  border-radius: 0;
}

.screen-scroll {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  margin-bottom: var(--app-bottom-tabs-height);
  padding: var(--spacing-16) var(--grid-mobile-margin) calc(var(--app-bottom-tabs-height) + var(--spacing-40, 40px));
  display: flex;
  flex-direction: column;
  gap: var(--spacing-20);
  background: var(--cds-color-page-background);
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  scroll-padding-bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-32));
}

.screen-scroll:has(.edit-submit-bar) {
  /*
   * Edit screens keep the save CTA fixed above the bottom tabs. Reserve the
   * same vertical space in the scroll viewport so form rows never render under
   * the fixed CTA.
   */
  --edit-submit-bar-height: 66px;
  --edit-submit-bar-gap: var(--spacing-16);
  margin-bottom: calc(var(--app-bottom-tabs-height) + var(--edit-submit-bar-height) + var(--edit-submit-bar-gap));
  padding-bottom: var(--spacing-32);
  scroll-padding-bottom: calc(var(--edit-submit-bar-height) + var(--spacing-32));
}

.screen-scroll:has(.edit-submit-bar) > :nth-last-child(2),
.screen-scroll:has(.edit-submit-bar) > .form-section:last-of-type {
  margin-bottom: var(--spacing-32);
}

.bottom-tabs {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 4;
  min-height: var(--app-bottom-tabs-height);
  padding: 0 10px max(18px, env(safe-area-inset-bottom));
  border-top: 1px solid var(--cds-color-border-default);
  background: var(--cds-color-surface-primary);
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.bottom-tab {
  border: 0;
  background: transparent;
  color: var(--cds-color-text-tertiary);
  display: grid;
  place-items: center;
  align-content: center;
  gap: 2px;
  font-size: 11px;
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.bottom-tab span {
  font-size: 18px;
  line-height: 1;
}

.bottom-tab.is-active {
  color: var(--cds-color-brand-primary-dark);
}

.hero-card,
.detail-hero,
.settlement-hero {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-lg);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-18, 18px);
  display: grid;
  gap: var(--spacing-10, 10px);
  box-shadow: var(--cds-shadow-card);
}

.hero-card h2,
.detail-hero h2 {
  font-size: var(--app-type-hero-size);
  line-height: var(--app-type-hero-line);
  word-break: keep-all;
}

.phone[data-scenario="pro"] .hero-card {
  padding: var(--spacing-12);
  gap: var(--spacing-6);
  border-radius: var(--cds-radius-card);
}

.hero-metric-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--spacing-6);
}

.hero-metric-row span {
  min-width: 0;
  min-height: 34px;
  display: grid;
  align-content: center;
  gap: 1px;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  padding: 4px 6px;
}

.hero-metric-row em {
  overflow: hidden;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-style: normal;
  font-weight: var(--cds-font-weight-semibold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.hero-metric-row strong {
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-bold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.card,
.batch-card,
.empty-card,
.tool-card,
.preview-card,
.mini-card,
.reaction-card,
.secondary-panel,
.locked-panel {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-14, 14px);
  box-shadow: var(--cds-shadow-card);
}

.card,
.empty-card,
.reaction-card,
.secondary-panel,
.locked-panel {
  display: grid;
  gap: var(--spacing-12);
}

.secondary-panel,
.handoff-panel,
.diagnosis-card {
  border-top: 1px solid var(--cds-color-border-default);
  padding-top: var(--spacing-16);
  display: grid;
  gap: var(--spacing-12);
}

.locked-panel {
  border-style: dashed;
  background: var(--cds-color-surface-raised);
}

.section-header {
  display: grid;
  gap: var(--spacing-4);
  margin-bottom: var(--spacing-10, 10px);
}

.section-header h2,
.card h2,
.reaction-card h2,
.secondary-panel h2,
.handoff-panel h2,
.diagnosis-card h2,
.locked-panel h2,
.tool-card h3,
.feed-card h3 {
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-semibold);
  letter-spacing: -.15px;
  word-break: keep-all;
}

.metric-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-8);
}

.metric-strip .metric-cell:nth-child(3):last-child {
  grid-column: 1 / -1;
}

.metric-cell {
  min-width: 0;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-raised);
  padding: var(--spacing-10, 10px);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px;
  align-items: center;
}

.metric-cell span,
.metric-cell small,
.settlement-hero span,
.list-line span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--cds-line-height-18);
  font-weight: var(--cds-font-weight-medium);
}

.metric-cell strong {
  min-width: 0;
  justify-self: end;
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: clamp(var(--app-type-meta-size), 3.8vw, var(--app-type-row-size));
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.2px;
  white-space: nowrap;
}

.metric-cell small {
  grid-column: 1 / -1;
}

.reaction-card {
  grid-template-columns: minmax(0, 1fr) 56px;
  align-items: start;
  padding: var(--spacing-12);
  gap: var(--spacing-6);
}

.reaction-card .cta-primary,
.reaction-card .helper-text {
  grid-column: 1 / -1;
}

.reaction-card.is-primary-action {
  border-color: rgba(0, 204, 97, .35);
  box-shadow: 0 1px 2px rgba(0, 204, 97, .08);
}

.reaction-number {
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  padding: var(--spacing-8) var(--spacing-5, 5px);
  text-align: center;
  display: grid;
  gap: 0;
}

.reaction-number strong {
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-bold);
}

.reaction-card .reason-chip-row span {
  min-height: 24px;
  padding: 0 var(--spacing-8);
}

.reaction-card .cta-primary {
  min-height: 40px;
  font-size: var(--cds-font-size-14);
  line-height: 40px;
}

.reaction-card.is-home-reaction-summary {
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-10, 10px);
}

.reaction-card.is-simple-reaction {
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
}

.reaction-card.is-home-reaction-summary .cta-primary,
.reaction-card.is-home-reaction-summary .helper-text,
.reaction-card.is-simple-reaction .cta-primary,
.reaction-card.is-simple-reaction .helper-text {
  grid-column: auto;
}

.reaction-card.is-empty-reaction {
  padding: var(--spacing-10, 10px) var(--spacing-12);
  gap: var(--spacing-6);
}

.reaction-card.is-empty-reaction .reaction-number {
  padding: var(--spacing-6) var(--spacing-4);
}

.reaction-card.is-empty-reaction .reason-chip-row span {
  min-height: 22px;
}

.reaction-card.is-empty-reaction .cta-primary {
  min-height: 36px;
  font-size: var(--cds-font-size-13);
  line-height: 36px;
}

.reaction-card .inline-hint {
  grid-column: 1 / -1;
  margin-top: -2px;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.reaction-number span,
.helper-text {
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-12);
  line-height: var(--cds-line-height-18);
}

.row-list,
.tool-list,
.feed-list,
.simple-list,
.guide-list {
  display: grid;
  gap: var(--spacing-10, 10px);
}

.challenge-row {
  min-height: 88px;
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr) auto;
  gap: var(--spacing-10, 10px);
  align-items: center;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-12);
  box-shadow: var(--cds-shadow-card);
}

.challenge-row.is-recent {
  min-height: 64px;
  grid-template-columns: 30px minmax(0, 1fr) auto;
  gap: var(--spacing-6);
  border-radius: var(--cds-radius-card);
  padding: var(--spacing-4) var(--spacing-6);
}


.challenge-row.is-recent .thumb {
  width: 30px;
  height: 30px;
  border-radius: 12px;
}

.challenge-row.is-recent .row-body {
  gap: 2px;
}

.challenge-row.is-recent .row-body strong {
  -webkit-line-clamp: 1;
}

.challenge-row.is-recent .stage-chip-row {
  gap: 3px;
  margin-top: 1px;
}

.challenge-row.is-recent .stage-chip-row span {
  min-height: 17px;
  padding: 0 3px;
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.challenge-row.is-recent .stage-chip-row span.is-cp {
  flex-basis: auto;
  width: auto;
}

.challenge-row.is-recent .row-affordance {
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}


.challenge-row.is-operation-target {
  min-height: 60px;
  grid-template-columns: 32px minmax(0, 1fr) auto;
  gap: var(--spacing-6);
  padding: var(--spacing-7, 7px) var(--spacing-8);
}

.challenge-row.is-operation-target .thumb {
  width: 32px;
  height: 32px;
  border-radius: 12px;
}

.challenge-row.is-operation-target .row-body {
  gap: 1px;
}

.challenge-row.is-operation-target .row-body strong,
.challenge-row.is-operation-target .row-signal span {
  -webkit-line-clamp: 1;
}

.challenge-row.is-operation-target .row-signal {
  display: none;
}

.challenge-row.is-analysis-target {
  min-height: 72px;
  grid-template-columns: 30px minmax(0, 1fr) auto;
  gap: var(--spacing-6);
  padding: var(--spacing-6) var(--spacing-8);
}

.challenge-row.is-analysis-target .thumb {
  width: 30px;
  height: 30px;
  border-radius: 12px;
}

.challenge-row.is-analysis-target .row-body {
  gap: 2px;
}

.challenge-row.is-analysis-target .row-body strong,
.challenge-row.is-analysis-target .row-signal span {
  -webkit-line-clamp: 1;
}

.challenge-row.is-analysis-target .row-signal {
  display: flex;
}

.challenge-row.is-analysis-target .row-affordance {
  max-width: 82px;
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.analysis-challenge-list {
  gap: var(--spacing-4);
}

.operation-target-list {
  gap: var(--spacing-6);
}

.reaction-card.is-operation-summary {
  padding: var(--spacing-14, 14px);
}

.reaction-card.is-operation-summary .reason-chip-row {
  display: none;
}

.reaction-card.is-operation-summary .cta-primary {
  min-height: 44px;
  line-height: 44px;
}

.list-more-row {
  min-height: 38px;
  width: 100%;
  border: 1px dashed var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  color: var(--cds-color-text-secondary);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-8);
  padding: 0 var(--spacing-12);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.list-more-row strong {
  margin-left: auto;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
}

.list-more-row.is-challenge-more {
  min-height: 44px;
  padding: 0 var(--spacing-12);
}

.interactive-row {
  cursor: pointer;
  transition:
    background-color .16s ease,
    border-color .16s ease,
    transform .16s ease;
}

.interactive-row:active {
  background: var(--cds-color-surface-raised);
  border-color: var(--cds-color-border-strong);
  transform: translateY(1px);
}

.thumb,
.tool-icon,
.empty-icon,
.preview-art {
  width: 48px;
  height: 48px;
  border-radius: 16px;
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  display: grid;
  place-items: center;
  font-weight: var(--cds-font-weight-bold);
}

.row-body {
  min-width: 0;
  display: grid;
  gap: 3px;
}

.row-body strong,
.list-line strong,
.preview-card strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.challenge-row .row-body strong {
  display: -webkit-box;
  white-space: normal;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
}

.row-body p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.row-signal {
  display: flex;
  min-width: 0;
}

.row-signal span,
.tool-preview {
  display: -webkit-box;
  min-width: 0;
  max-width: 100%;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  font-weight: var(--cds-font-weight-medium);
  line-height: var(--app-type-meta-line);
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.challenge-row.is-analysis-target .row-signal span {
  text-overflow: ellipsis;
}

.stage-text-row {
  min-width: 0;
  display: flex;
  flex-wrap: nowrap;
  gap: 5px;
  overflow: hidden;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  white-space: nowrap;
}

.stage-text-row span {
  min-width: 0;
  flex: 0 0 auto;
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.stage-text-row em {
  color: var(--cds-color-text-tertiary);
  font-style: normal;
  font-weight: var(--cds-font-weight-medium);
}

.stage-text-row strong {
  display: inline;
  overflow: visible;
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: inherit;
  font-weight: var(--cds-font-weight-semibold);
  line-height: inherit;
  white-space: nowrap;
}

.tool-preview {
  -webkit-line-clamp: 3;
}

.row-action {
  border: 1px solid var(--cds-color-border-strong);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-primary);
  min-height: 36px;
  padding: 0 10px;
  font-size: var(--app-type-meta-size);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
  cursor: pointer;
}

.row-affordance {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 3px;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  font-weight: var(--cds-font-weight-semibold);
  line-height: var(--app-type-meta-line);
  white-space: nowrap;
}

.interactive-row:hover .row-affordance,
.interactive-row:focus-visible .row-affordance {
  color: var(--cds-color-text-primary);
}

.tools-card .cta-secondary {
  margin-top: var(--spacing-4);
}

.insight-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--spacing-8);
}

.mini-card {
  padding: var(--spacing-12);
  display: grid;
  gap: 2px;
}

.analysis-summary {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.mini-card.is-warning {
  border-color: rgba(255, 102, 0, .28);
  background: #fff7ed;
}

.mini-card.is-warning strong {
  color: var(--cds-color-semantic-warning);
}

.mini-card span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-12);
  font-weight: var(--cds-font-weight-semibold);
}

.mini-card strong {
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.mini-card p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.button-row,
.feed-actions,
.stacked-actions {
  display: flex;
  gap: var(--spacing-6);
  flex-wrap: wrap;
}

.button-row.single-primary {
  display: grid;
  grid-template-columns: 1fr;
}

.diagnosis-actions {
  display: grid;
  grid-template-columns: 1fr;
  justify-items: stretch;
  gap: var(--spacing-6);
}

.diagnosis-actions .text-link-action {
  justify-self: start;
  margin-top: 0;
  padding-left: var(--spacing-4);
}

.button-row > *,
.feed-actions > *,
.stacked-actions > * {
  flex: 1 1 auto;
}

.revenue-guide-actions {
  display: grid;
  gap: var(--spacing-12);
  justify-items: stretch;
}

.revenue-guide-hero,
.free-revenue-signal-card,
.revenue-guide-preview {
  display: grid;
  gap: var(--spacing-12);
  box-shadow: none;
}

.revenue-guide-hero h2,
.revenue-guide-heading h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.35px;
  word-break: keep-all;
}

.revenue-guide-hero p,
.free-revenue-signal-card p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  font-weight: var(--cds-font-weight-medium);
  word-break: keep-all;
}

.revenue-guide-hero.is-active,
.free-revenue-signal-card {
  border-color: color-mix(in srgb, var(--cds-color-primary) 22%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-primary) 4%, var(--cds-color-surface-primary));
}

.free-revenue-signal-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
}

.free-revenue-signal-grid div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
  padding: var(--spacing-12);
  border-right: 1px solid var(--app-simple-border);
}

.free-revenue-signal-grid div:last-child {
  border-right: 0;
}

.free-revenue-signal-grid span,
.revenue-preview-row span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.free-revenue-signal-grid strong {
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.revenue-preview-list {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
}

.revenue-preview-panel {
  display: grid;
  gap: var(--spacing-12);
  padding: var(--spacing-14, 14px) var(--spacing-16);
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
}

.revenue-preview-panel-head {
  display: grid;
  grid-template-columns: var(--spacing-32) minmax(0, 1fr);
  align-items: center;
  gap: var(--spacing-12);
}

.revenue-preview-lock {
  width: var(--spacing-32);
  height: var(--spacing-32);
  display: grid;
  place-items: center;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-surface-secondary);
  color: var(--cds-color-text-tertiary);
}

.revenue-preview-lock-icon {
  display: block;
  width: var(--spacing-20);
  height: var(--spacing-20);
}

.revenue-preview-panel h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
}

.revenue-preview-panel p {
  margin: var(--spacing-2, 2px) 0 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.revenue-preview-items {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid var(--app-simple-border);
}

.revenue-preview-items li {
  min-height: var(--spacing-52);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  border-bottom: 1px solid var(--app-simple-border);
  color: var(--cds-color-text-primary);
}

.revenue-preview-items li > span {
  min-width: 0;
  display: grid;
  gap: var(--spacing-2, 2px);
}

.revenue-preview-items li strong {
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.revenue-preview-items li small {
  overflow: hidden;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.revenue-preview-items li::after {
  content: "";
  width: var(--spacing-64);
  height: var(--spacing-24);
  border-radius: var(--cds-radius-sm);
  background:
    linear-gradient(
      90deg,
      color-mix(in srgb, var(--cds-color-primary-background) 72%, var(--cds-color-surface-secondary)) 0 42%,
      color-mix(in srgb, var(--cds-color-border-default) 64%, var(--cds-color-surface-secondary)) 42% 100%
    );
  opacity: .9;
}

.revenue-preview-items li:last-child {
  border-bottom: 0;
}

.revenue-preview-row {
  appearance: none;
  min-width: 0;
  min-height: 50px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  color: inherit;
  font: inherit;
  padding: var(--spacing-12);
  text-align: left;
  cursor: pointer;
}

.revenue-preview-row:last-child {
  border-bottom: 0;
}

.revenue-preview-row:active {
  background: var(--cds-color-surface-secondary);
}

.revenue-preview-row:focus-visible {
  outline: 0;
  box-shadow: var(--cds-button-focus-ring);
}

.revenue-preview-row strong {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
}

.text-link-action {
  width: fit-content;
  max-width: 100%;
  border: 0;
  background: transparent;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  text-align: left;
  text-decoration: underline;
  text-underline-offset: 3px;
  cursor: pointer;
  padding: 0;
  white-space: normal;
  word-break: keep-all;
}

.text-link-action:hover,
.text-link-action:focus-visible {
  color: var(--cds-color-text-primary);
}

.inline-hint {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  word-break: keep-all;
}

.chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-8);
  overflow-x: visible;
  padding-bottom: 2px;
  scrollbar-width: none;
}

.certification-chip-row {
  flex-wrap: nowrap;
  overflow-x: auto;
  overflow-y: hidden;
  align-items: center;
  min-height: 34px;
  margin-right: calc(var(--grid-mobile-margin) * -1);
  padding-right: var(--grid-mobile-margin);
  scroll-padding-inline: var(--grid-mobile-margin);
  -webkit-overflow-scrolling: touch;
}

.chip-row::-webkit-scrollbar {
  display: none;
}

.chip {
  min-height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  flex: 0 0 auto;
  border: 1px solid var(--cds-color-border-strong);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-secondary);
  padding: 0 12px;
  white-space: nowrap;
  font-size: var(--app-type-meta-size);
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.chip b {
  min-width: 18px;
  min-height: 18px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
  color: inherit;
  font-family: var(--cds-font-family-numeric);
  font-size: 11px;
  line-height: 16px;
}

.chip.is-active {
  border-color: var(--cds-color-primary);
  background: var(--cds-color-primary);
  color: var(--cds-color-text-inverse);
}

.chip.is-active b {
  background: rgba(255, 255, 255, .2);
}

.batch-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--spacing-12);
  align-items: center;
  background: var(--cds-color-surface-raised);
}

.preview-panel {
  border-style: dashed;
  box-shadow: none;
}

.batch-card h2,
.batch-card p {
  margin: 4px 0 0;
}

.feed-card {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-6);
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: var(--spacing-6);
  align-items: start;
  overflow: hidden;
  box-shadow: var(--cds-shadow-card);
}

.feed-image {
  width: 32px;
  height: 32px;
  border-radius: 11px;
  background: var(--cds-color-surface-secondary);
}

.tone-green { background: linear-gradient(135deg, var(--cds-color-primary-background), var(--cds-color-primary)); }
.tone-blue { background: linear-gradient(135deg, var(--cds-color-secondary), var(--cds-color-semantic-info)); }
.tone-orange { background: linear-gradient(135deg, var(--cds-color-primary-background), var(--cds-color-semantic-warning)); }
.tone-purple { background: linear-gradient(135deg, var(--cds-color-secondary), var(--cds-color-primary-background)); }

.feed-content {
  padding: 0;
  display: grid;
  gap: 2px;
}

.feed-topline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-8);
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-11);
  line-height: var(--cds-line-height-16);
  font-weight: var(--cds-font-weight-semibold);
}

.feed-card h3 {
  margin: 0;
  font-size: var(--cds-font-size-15);
  line-height: var(--cds-line-height-20);
  letter-spacing: -.2px;
}

.feed-card p {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  font-size: var(--cds-font-size-13);
  line-height: var(--cds-line-height-18);
}

.reason-box,
.preset-box,
.feed-suggestion,
.sheet-preview {
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  color: var(--cds-color-text-secondary);
  padding: 5px var(--spacing-6);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.feed-suggestion {
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  min-width: 0;
  background: var(--cds-color-primary-light);
  color: var(--cds-color-primary-light-foreground);
}

.feed-suggestion span {
  flex: 0 1 42%;
  min-width: 0;
  color: color-mix(in srgb, var(--cds-color-primary-light-foreground) 64%, var(--cds-color-text-secondary));
  display: block;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.feed-suggestion strong {
  flex: 1 1 0;
  min-width: 0;
  color: var(--cds-color-primary-light-foreground);
  font-weight: var(--cds-font-weight-semibold);
  display: block;
  white-space: nowrap;
  text-overflow: ellipsis;
  overflow: hidden;
}

.reason-box {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.feed-actions.is-prominent {
  gap: 2px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  flex-wrap: nowrap;
  justify-items: stretch;
}

.feed-actions.is-prominent .cta-sm {
  width: 100%;
  min-height: 32px;
  padding: 0 var(--spacing-6);
  font-size: var(--cds-font-size-12);
  line-height: 32px;
}

.feed-actions.is-prominent .feed-secondary-action {
  justify-self: end;
  width: auto;
  min-height: auto;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  box-shadow: none;
  padding: 2px 0 0;
  text-decoration: none;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-12);
  line-height: var(--cds-line-height-18);
}

.feed-actions.is-inline {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  gap: var(--spacing-12);
  min-height: 24px;
}

.feed-actions.is-inline > * {
  flex: 0 0 auto;
}

.feed-inline-reaction {
  width: auto;
  min-width: 44px;
  min-height: 36px;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
  padding: 0 var(--spacing-10, 10px);
  color: var(--cds-color-brand-primary-dark);
  font-size: var(--cds-font-size-12);
  line-height: 34px;
  font-weight: var(--cds-font-weight-semibold);
  text-decoration: none;
}

.feed-inline-reaction::after {
  content: " ›";
}

.feed-inline-reaction.is-done {
  color: var(--cds-color-text-tertiary);
}

.feed-actions.is-inline .feed-secondary-action {
  color: var(--cds-color-text-tertiary);
}

.feed-actions .feed-secondary-action::after {
  content: " ›";
}

.preset-box {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.preset-box {
  background: var(--cds-color-primary-light);
  color: var(--cds-color-primary-light-foreground);
  font-weight: var(--cds-font-weight-semibold);
}

.empty-card {
  text-align: center;
  justify-items: center;
  padding: var(--spacing-28) var(--spacing-20);
}

.empty-icon {
  border-radius: var(--cds-radius-full);
}

.tool-card {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) auto;
  gap: var(--spacing-8);
  align-items: center;
  min-height: 66px;
  padding: var(--spacing-8);
}

.context-strip {
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  padding: var(--spacing-12);
  display: grid;
  gap: 2px;
}

.context-strip span {
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.context-strip strong {
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.tool-icon {
  width: 32px;
  height: 32px;
  border-radius: var(--cds-radius-full);
}

.tool-card h3,
.tool-card p {
  margin: 0;
}

.tool-card h3 {
  font-size: var(--cds-font-size-15);
  line-height: var(--cds-line-height-20);
}

.tool-card .row-affordance {
  max-width: 48px;
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.tool-preview {
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.analysis-funnel-strip {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-6);
  overflow: visible;
}

.analysis-step {
  min-width: 0;
  min-height: 54px;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  padding: var(--spacing-8) var(--spacing-12);
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) auto;
  gap: 2px var(--spacing-8);
  align-items: center;
  position: relative;
}

.analysis-step::after {
  display: none;
}

.analysis-step.is-warning {
  border-color: color-mix(in srgb, var(--cds-color-semantic-warning) 12%, var(--cds-color-border-default));
  background: var(--cds-color-surface-raised);
}

.analysis-step-index {
  width: 22px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  grid-column: 1;
  grid-row: 1;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-surface-secondary);
  color: var(--cds-color-text-secondary);
  font-family: var(--cds-font-family-numeric);
  font-size: var(--app-type-caption-size);
  font-weight: var(--cds-font-weight-bold);
}

.analysis-step-copy {
  min-width: 0;
  display: grid;
  gap: 1px;
}

.analysis-step-label {
  min-width: 0;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-6);
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
}

.analysis-step-label em {
  flex: 0 0 auto;
  font-style: normal;
  width: fit-content;
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-semantic-warning) 8%, transparent);
  color: color-mix(in srgb, var(--cds-color-semantic-warning) 70%, var(--cds-color-text-secondary));
  padding: 0 var(--spacing-4);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.analysis-step strong {
  grid-column: 3;
  grid-row: 1;
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: clamp(var(--app-type-row-size), 4.2vw, var(--app-type-section-size));
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.analysis-step.is-warning strong {
  color: var(--cds-color-text-primary);
}

.analysis-step small {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.analysis-revenue-row {
  min-height: 48px;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-8) var(--spacing-12);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 2px var(--spacing-8);
  align-items: center;
}

.analysis-revenue-block {
  margin-top: var(--spacing-12);
  padding-top: var(--spacing-12);
  border-top: 1px solid var(--cds-color-border-subtle);
  display: grid;
  gap: var(--spacing-6);
}

.analysis-revenue-block > span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.scope-note {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-12);
  display: grid;
  gap: 2px;
}

.scope-note span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.scope-note strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.certification-signal-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-8);
}

.certification-signal-summary > div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-raised);
  padding: var(--spacing-12);
}

.certification-signal-summary > div.is-primary-signal {
  border-color: color-mix(in srgb, var(--cds-color-primary) 28%, var(--cds-color-border-default));
  background: var(--cds-color-primary-background);
}

.certification-signal-summary span,
.certification-signal-summary small {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
}

.certification-signal-summary strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
}

.certification-signal-summary .is-primary-signal strong {
  color: var(--cds-color-brand-primary-dark);
}

.analysis-revenue-row span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.analysis-revenue-row strong {
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.analysis-revenue-row small {
  grid-column: 1 / -1;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
}

.stage-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
  margin-top: var(--spacing-4);
}

.stage-chip-row span {
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  padding: 0 6px;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  white-space: nowrap;
}

.stage-chip-row span.is-cp {
  flex-basis: 100%;
  width: max-content;
  max-width: 100%;
}

.stage-chip-row em {
  font-style: normal;
  font-weight: var(--cds-font-weight-medium);
}

.stage-chip-row strong {
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-weight: var(--cds-font-weight-bold);
}

.funnel-chart {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-6);
}

.funnel-card {
  padding: 0;
  gap: var(--spacing-8);
  display: grid;
}

.funnel-card .section-header {
  display: grid;
  gap: 2px;
  margin-bottom: var(--spacing-4);
}

.funnel-card .section-header span,
.funnel-card .section-header h2 {
  min-width: 0;
}

.funnel-card .section-header h2 {
  font-size: var(--cds-font-size-17);
  line-height: var(--cds-line-height-26);
  text-align: left;
  white-space: normal;
}

.funnel-stage,
.list-line,
.guide-list > div {
  min-height: 48px;
  border: 1px solid var(--cds-color-border-subtle);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  padding: var(--spacing-12);
}

.funnel-stage {
  display: grid;
  min-height: 56px;
  padding: var(--spacing-8);
  gap: 4px;
}

.funnel-stage.is-focus-weak,
.funnel-stage.is-bottleneck {
  border-color: color-mix(in srgb, var(--cds-color-semantic-warning) 12%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-semantic-warning) 3%, var(--cds-color-surface-raised));
}

.funnel-stage.is-focus-weak .funnel-fill,
.funnel-stage.is-bottleneck .funnel-fill {
  background: color-mix(in srgb, var(--cds-color-semantic-warning) 48%, var(--cds-color-primary));
}

.funnel-stage.is-focus-positive {
  border-color: color-mix(in srgb, var(--cds-color-primary) 28%, transparent);
  background: var(--cds-color-primary-background);
}

.funnel-stage.is-focus-positive .funnel-fill {
  background: var(--cds-color-primary);
}

.funnel-stage.is-baseline .funnel-fill {
  background: var(--cds-color-border-strong);
}

.funnel-stage.is-baseline .funnel-stage-foot {
  display: none;
}

.funnel-stage:not(.is-focus-weak):not(.is-focus-positive):not(.is-bottleneck) .funnel-stage-foot {
  display: none;
}

.funnel-stage-head,
.funnel-stage-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-6);
}

.funnel-stage-head > div {
  min-width: 0;
  display: grid;
  gap: 0;
}

.funnel-stage-head span {
  min-width: 0;
  display: inline-flex;
  align-items: baseline;
  gap: var(--spacing-4);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  white-space: nowrap;
}

.funnel-stage-head strong,
.list-line b {
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.funnel-stage-head small {
  display: block;
  margin-top: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-11);
  line-height: var(--cds-line-height-16);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.funnel-track {
  position: relative;
  height: 5px;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-surface-secondary);
}

.funnel-fill {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--value, 0%);
  min-width: 4px;
  border-radius: inherit;
  background: var(--cds-color-primary);
}

.funnel-benchmark {
  position: absolute;
  top: -4px;
  bottom: -4px;
  left: var(--benchmark, 0%);
  border-left: 1px dashed var(--cds-color-border-strong);
}

.funnel-stage-foot {
  min-height: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-11);
  line-height: var(--cds-line-height-16);
}

.funnel-stage-foot span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.funnel-stage.is-focus-weak .funnel-stage-foot span:first-child,
.funnel-stage.is-bottleneck .funnel-stage-foot span:first-child {
  color: color-mix(in srgb, var(--cds-color-semantic-warning) 68%, var(--cds-color-text-secondary));
  font-weight: var(--cds-font-weight-medium);
}

.funnel-stage.is-focus-positive .funnel-stage-foot span:first-child {
  color: var(--cds-color-brand-primary-dark);
  font-weight: var(--cds-font-weight-semibold);
}

.preview-card {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: var(--spacing-14, 14px);
  align-items: center;
}

.preview-art {
  width: 76px;
  height: 92px;
  border-radius: var(--cds-radius-card);
}

.preview-card p,
.preview-card span {
  margin: 4px 0 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.split-card {
  grid-template-columns: minmax(0, 1fr);
}

.detail-action-list {
  display: grid;
  gap: var(--spacing-10, 10px);
}

.detail-action-row {
  min-height: 66px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--spacing-8);
  align-items: center;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-8) var(--spacing-12);
}

.detail-action-row.is-focus-row {
  border-color: rgba(0, 204, 97, .34);
  background: color-mix(in srgb, var(--cds-color-primary-background) 38%, var(--cds-color-surface-primary));
}

.detail-action-row h3 {
  margin: 0;
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
}

.detail-action-row span:not(.row-affordance):not(.row-meta),
.detail-action-row .row-meta {
  display: block;
}

.detail-action-row div > span:last-child {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.row-affordance.is-primary-affordance {
  color: var(--cds-color-brand-primary-dark);
}

.form-section {
  display: grid;
  gap: var(--spacing-8);
}

.form-field,
.select-like-row,
.trigger-row,
.message-preview-card {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-12);
  box-shadow: var(--cds-shadow-card);
}

.form-field {
  display: grid;
  gap: var(--spacing-6);
}

.form-field span,
.select-like-row span,
.trigger-row span,
.message-preview-card small {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.form-field input,
.form-field textarea {
  width: 100%;
  min-width: 0;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  color: var(--cds-color-text-primary);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
}

.form-field textarea {
  resize: vertical;
}

.form-field small {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.select-like-row,
.trigger-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--spacing-12);
  align-items: center;
}

.select-like-row strong,
.trigger-row strong,
.message-preview-head strong {
  display: block;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.select-like-row em {
  color: var(--cds-color-text-tertiary);
  font-style: normal;
  font-size: var(--app-type-section-size);
}

.form-message {
  margin: 0;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  padding: var(--spacing-12);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.trigger-list {
  display: grid;
  gap: var(--spacing-6);
}

.message-preview-card {
  display: grid;
  gap: var(--spacing-8);
}

.message-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-8);
  min-width: 0;
}

.message-bubble {
  width: min(100%, 282px);
  border-radius: 18px 18px 18px 6px;
  background: var(--cds-color-primary-light);
  color: var(--cds-color-primary-light-foreground);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  display: grid;
  gap: var(--spacing-4);
}

.message-bubble span {
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.message-bubble p {
  margin: 0;
  color: inherit;
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  font-weight: var(--cds-font-weight-medium);
}

.task-editor-card {
  display: grid;
  gap: var(--spacing-12);
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-12);
  box-shadow: var(--cds-shadow-card);
}

.task-editor-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--spacing-8);
  padding-bottom: var(--spacing-10, 10px);
  border-bottom: 1px solid var(--cds-color-border-default);
}

.task-editor-head strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.task-editor-head span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.task-day-chip-row {
  display: flex;
  gap: var(--spacing-8);
  overflow-x: auto;
  overflow-y: hidden;
  padding: var(--spacing-4) 0;
  scrollbar-width: none;
}

.task-day-chip-row::-webkit-scrollbar {
  display: none;
}

.task-day-chip {
  flex: 0 0 auto;
  min-width: var(--spacing-64);
  min-height: var(--spacing-32);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--cds-color-border-strong);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-secondary);
  padding: 0 var(--spacing-12);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
  white-space: nowrap;
}

.task-day-chip.is-active {
  border-color: var(--cds-color-primary);
  background: var(--cds-color-primary);
  color: var(--cds-color-primary-foreground);
  font-weight: var(--cds-font-weight-semibold);
}

.task-day-chip.is-done {
  border-color: var(--cds-color-border-default);
  background: var(--cds-color-surface-secondary);
  color: var(--cds-color-text-tertiary);
  text-decoration: line-through;
}

.task-visual-preview {
  position: relative;
  min-height: 176px;
  overflow: hidden;
  border-radius: var(--cds-radius-card);
  border: 1px solid color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-border-default));
  background:
    radial-gradient(circle at 18% 12%, color-mix(in srgb, var(--cds-color-primary-light) 74%, transparent) 0 22%, transparent 48%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary-background) 76%, var(--cds-color-surface-primary)) 0%, color-mix(in srgb, var(--cds-color-brand-primary-dark) 30%, var(--cds-color-surface-primary)) 100%);
  color: var(--cds-color-text-primary);
  display: flex;
  align-items: flex-end;
  padding: var(--spacing-16);
}

.task-visual-preview::after {
  content: "";
  position: absolute;
  inset: auto 0 0;
  height: 48%;
  background: linear-gradient(to top, color-mix(in srgb, var(--cds-color-text-primary) 24%, transparent), transparent);
  pointer-events: none;
}

.task-preview-time,
.task-preview-action,
.task-preview-play,
.task-preview-copy {
  position: relative;
  z-index: 1;
}

.task-preview-time {
  position: absolute;
  top: var(--spacing-12);
  left: var(--spacing-12);
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-text-primary) 24%, transparent);
  color: var(--cds-color-primary-foreground);
  padding: var(--spacing-4) var(--spacing-8);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
  font-variant-numeric: tabular-nums;
}

.task-preview-action {
  position: absolute;
  top: var(--spacing-12);
  right: var(--spacing-12);
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-surface-primary) 88%, transparent);
  color: var(--cds-color-text-primary);
  padding: var(--spacing-4) var(--spacing-10, 10px);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.task-preview-play {
  position: absolute;
  inset: 50% auto auto 50%;
  transform: translate(-50%, -50%);
  color: color-mix(in srgb, var(--cds-color-primary-foreground) 72%, transparent);
  font-size: var(--app-type-hero-size);
  line-height: var(--app-type-hero-line);
}

.task-preview-copy {
  display: grid;
  gap: var(--spacing-4);
  color: var(--cds-color-primary-foreground);
}

.task-preview-copy strong {
  color: inherit;
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-semibold);
}

.task-preview-copy span {
  color: color-mix(in srgb, var(--cds-color-primary-foreground) 82%, transparent);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.task-add-row {
  min-height: var(--spacing-48);
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px dashed var(--cds-color-border-strong);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.edit-submit-bar {
  position: absolute;
  left: var(--grid-mobile-margin);
  right: var(--grid-mobile-margin);
  bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-10, 10px));
  z-index: 2;
  margin-top: var(--spacing-4);
  padding: var(--spacing-8);
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-lg);
  background: color-mix(in srgb, var(--cds-color-surface-primary) 97%, transparent);
  box-shadow: var(--cds-shadow-card);
  backdrop-filter: blur(8px);
}

.edit-submit-bar::before {
  content: "";
  position: absolute;
  left: -1px;
  right: -1px;
  top: -36px;
  height: 36px;
  background: linear-gradient(to top, var(--cds-color-page-background), transparent);
  pointer-events: none;
}

.edit-submit-bar .cta-primary,
.edit-submit-bar .cta-secondary {
  min-height: 48px;
  line-height: 48px;
}

.settlement-hero {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--spacing-8);
}

.settlement-hero > div {
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-primary-background);
  padding: var(--spacing-8) var(--spacing-10, 10px);
  display: grid;
  gap: 2px;
}

.settlement-hero > .revenue-receivable {
  grid-column: 1 / -1;
  background: var(--cds-color-surface-raised);
}

.settlement-hero .status-rail,
.settlement-hero .cta-primary {
  grid-column: 1 / -1;
}

.settlement-hero .cta-primary {
  min-height: 44px;
  font-size: var(--cds-font-size-14);
  line-height: 44px;
}

.metric-label-with-action {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-6);
}

.info-dot {
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--cds-color-border-strong);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-12);
  font-weight: var(--cds-font-weight-bold);
  line-height: 1;
  cursor: pointer;
}

.settlement-hero strong {
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
}

.list-line > div {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.revenue-guide-card .guide-list {
  margin-top: var(--spacing-4);
}

.revenue-guide-card > p {
  display: none;
}

.guide-list > div {
  display: grid;
  align-items: flex-start;
  gap: var(--spacing-4);
}

.guide-list > div strong,
.guide-list > div span {
  display: block;
}

.revenue-guide-card .guide-list {
  gap: var(--spacing-6);
}

.revenue-guide-card .guide-list > div {
  min-height: 40px;
  grid-template-columns: minmax(0, 1fr);
  align-items: flex-start;
  gap: 2px;
  padding: var(--spacing-8) var(--spacing-12);
}

.revenue-guide-card .guide-list > div strong,
.revenue-guide-card .guide-list > div span {
  min-width: 0;
  overflow: visible;
  text-overflow: clip;
  white-space: normal;
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.revenue-guide-card .guide-list > div span {
  text-align: left;
}

.sheet-backdrop {
  position: absolute;
  inset: 0;
  z-index: 10;
  background: rgba(22, 22, 22, .28);
  display: flex;
  align-items: flex-end;
  padding-bottom: max(var(--spacing-20), env(safe-area-inset-bottom));
}

.bottom-sheet {
  width: 100%;
  max-height: min(82%, calc(100% - 36px));
  overflow: hidden;
  border-radius: var(--cds-radius-lg) var(--cds-radius-lg) 0 0;
  background: var(--cds-color-surface-primary);
  padding: 0;
  display: flex;
  flex-direction: column;
  box-shadow: var(--cds-shadow-elevation-1);
}

.sheet-handle {
  flex: 0 0 auto;
  width: 44px;
  height: 4px;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-border-strong);
  margin: var(--spacing-12) auto var(--spacing-8);
}

.sheet-content {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding: 0 var(--spacing-20) var(--spacing-16);
  display: grid;
  gap: var(--spacing-12);
  overscroll-behavior: contain;
}

.bottom-sheet h2 {
  margin: 0;
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
}

.bottom-sheet p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.sheet-preview {
  display: grid;
  gap: var(--spacing-8);
}

.sheet-preview span {
  display: block;
}

.sheet-preview--message {
  border-color: color-mix(in srgb, var(--cds-color-primary) 16%, var(--cds-color-border-default));
  background: var(--cds-color-primary-light);
  color: var(--cds-color-primary-light-foreground);
}

.sheet-preview--message span {
  color: inherit;
}

.settlement-confirm-list {
  display: grid;
  gap: var(--spacing-8);
}

.bottom-sheet .settlement-confirm-list .list-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2px;
  align-items: flex-start;
}

.bottom-sheet .settlement-confirm-list .sheet-line {
  min-height: 52px;
  border: 1px solid var(--cds-color-border-subtle);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  padding: var(--spacing-12);
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 2px;
  align-items: flex-start;
}

.bottom-sheet .settlement-confirm-list .sheet-line.is-long {
  grid-template-columns: minmax(0, 1fr);
}

.bottom-sheet .settlement-confirm-list .sheet-line > div {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.bottom-sheet .settlement-confirm-list .sheet-line strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.bottom-sheet .settlement-confirm-list .sheet-line span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.bottom-sheet .settlement-confirm-list .sheet-line b {
  min-width: 0;
  max-width: 100%;
  justify-self: start;
  text-align: left;
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: normal;
  overflow-wrap: anywhere;
}

.bottom-sheet .settlement-confirm-list .sheet-line.is-long b {
  justify-self: start;
  text-align: left;
  white-space: normal;
  overflow-wrap: anywhere;
}

.bottom-sheet .settlement-confirm-list .list-line > div {
  min-width: 0;
}

.bottom-sheet .settlement-confirm-list .list-line strong {
  white-space: normal;
  overflow: visible;
  text-overflow: clip;
}

.bottom-sheet .settlement-confirm-list .list-line b {
  min-width: 0;
  justify-self: start;
  text-align: left;
  white-space: normal;
  overflow-wrap: anywhere;
  line-height: var(--app-type-row-line);
}

.cta-sm[disabled],
.cta-sm[aria-disabled="true"],
.cta-primary[disabled],
.cta-secondary[disabled] {
  cursor: default;
  opacity: .72;
}

.sheet-field {
  display: grid;
  gap: var(--spacing-6);
}

.sheet-field span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.sheet-field textarea {
  width: 100%;
  resize: none;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  color: var(--cds-color-text-primary);
  padding: var(--spacing-12);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
}

.sheet-actions {
  flex: 0 0 auto;
  margin-top: auto;
  position: sticky;
  bottom: 0;
  z-index: 2;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--spacing-8);
  align-items: center;
  border-top: 1px solid var(--cds-color-border-subtle);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-12) var(--spacing-20) calc(var(--spacing-16) + env(safe-area-inset-bottom));
}

.sheet-actions.single-action {
  grid-template-columns: minmax(0, 1fr);
}

.sheet-actions .cta-primary {
  min-width: 0;
}

.sheet-actions .cta-primary,
.sheet-actions .cta-secondary {
  min-height: 48px;
  font-size: var(--cds-font-size-14);
  line-height: 48px;
}

.sheet-actions .cta-secondary {
  min-width: 58px;
  padding-inline: var(--spacing-12);
  border-color: var(--cds-color-border-subtle);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-secondary);
  box-shadow: none;
}

.cta-primary,
.cta-secondary,
.cta-ghost {
  line-height: 48px;
  white-space: nowrap;
}

.cta-block {
  width: 100%;
}

@media (min-width: 430px) {
  .device-shell {
    align-items: center;
    padding: 24px 0;
  }

  .phone {
    width: auto;
    height: min(var(--app-phone-height), calc(100vh - 48px));
    height: min(var(--app-phone-height), calc(100dvh - 48px));
    max-width: calc(100vw - 32px);
    aspect-ratio: 390 / 844;
    min-height: 0;
    border-radius: 34px;
    box-shadow:
      0 24px 60px rgba(15, 23, 42, .16),
      0 0 0 1px var(--cds-color-border-default);
  }

  .entry-shell {
    width: auto;
    height: min(var(--app-phone-height), calc(100vh - 48px));
    height: min(var(--app-phone-height), calc(100dvh - 48px));
    max-width: calc(100vw - 32px);
    aspect-ratio: 390 / 844;
    margin: 24px auto;
    border-radius: 34px;
    box-shadow:
      0 24px 60px rgba(15, 23, 42, .16),
      0 0 0 1px var(--cds-color-border-default);
  }
}

@media (max-width: 360px) {
  .screen-scroll {
    padding-left: var(--spacing-12);
    padding-right: var(--spacing-12);
  }

  .metric-cell {
    padding: var(--spacing-8);
  }

  .mini-card strong {
    font-size: var(--app-type-row-size);
  }

  .challenge-row,
  .tool-card {
    grid-template-columns: 48px minmax(0, 1fr);
  }

  .challenge-row .row-affordance,
  .tool-card .row-affordance {
    grid-column: 1 / -1;
    width: 100%;
    justify-content: flex-start;
  }
}

/* Research-backed compact hierarchy: label/badge/row before paragraph copy. */
.compact-entry {
  padding-bottom: calc(var(--spacing-36) + var(--spacing-8));
}

.compact-hero,
.compact-card {
  gap: var(--spacing-12);
}

.status-rail,
.reason-chip-row {
  display: flex;
  gap: var(--spacing-6);
  flex-wrap: wrap;
  align-items: center;
}

.status-rail span,
.reason-chip-row span {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  padding: 0 10px;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-12);
  font-weight: var(--cds-font-weight-semibold);
  line-height: var(--cds-line-height-18);
}

.reason-chip-row span:first-child,
.status-rail span:first-child {
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
}

.action-list {
  display: grid;
  gap: var(--spacing-8);
}

.action-line {
  min-height: 42px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-12);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  padding: 9px 12px;
}

.action-line span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.action-line strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  text-align: right;
}

.mini-card small {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
}

.compact-card > p:not(.eyebrow),
.compact-hero > p:not(.eyebrow) {
  display: none;
}

.compact-card.revenue-guide-hero > p,
.compact-card.free-revenue-signal-card > p {
  display: block;
}

/* 2026-05-31 layout repair: keep mobile first viewport stable before visual polish. */
.certification-chip-row {
  width: calc(100% + var(--grid-mobile-margin));
  max-width: calc(100% + var(--grid-mobile-margin));
  padding-right: calc(var(--grid-mobile-margin) + var(--spacing-24));
  mask-image: linear-gradient(to right, #000 calc(100% - 28px), transparent);
  scroll-snap-type: x proximity;
}

.certification-chip-row .chip {
  scroll-snap-align: start;
}

.feed-actions.is-prominent {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-4);
  align-items: stretch;
}

.feed-actions.is-prominent .feed-secondary-action {
  justify-self: start;
  min-height: 36px;
  padding: 0 2px;
  line-height: 36px;
}

.analysis-handoff-panel {
  padding-top: var(--spacing-12);
}

.detail-hero-slim {
  padding: var(--spacing-12);
  gap: var(--spacing-6);
  border-radius: var(--cds-radius-card);
}

.detail-hero-slim .status-rail {
  gap: var(--spacing-4);
}

.detail-hero-slim .status-rail span {
  min-height: 22px;
  padding: 0 var(--spacing-8);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.diagnosis-card {
  gap: var(--spacing-8);
}

.diagnosis-card .action-list {
  gap: var(--spacing-6);
}

.diagnosis-card .action-line {
  min-height: 36px;
  padding: var(--spacing-8) var(--spacing-12);
}

.compact-funnel-card {
  gap: var(--spacing-6);
}

.compact-funnel-card .section-header {
  margin-bottom: 0;
}

.compact-funnel-card .funnel-chart {
  gap: var(--spacing-5, 5px);
}

.compact-funnel-card .funnel-stage {
  min-height: 50px;
  padding: var(--spacing-6) var(--spacing-8);
  gap: 3px;
}

.detail-action-list {
  gap: var(--spacing-6);
}

.detail-action-row {
  min-height: 58px;
  padding: var(--spacing-8) var(--spacing-12);
}

.detail-action-row div > span:last-child {
  -webkit-line-clamp: 1;
}

.list-more-row.is-challenge-more {
  border-style: solid;
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-primary);
}

.list-more-row.is-passive {
  min-height: 34px;
  border-style: solid;
  background: var(--cds-color-surface-raised);
  justify-content: center;
  text-align: center;
  pointer-events: none;
}

.list-more-row.is-passive span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settlement-hero {
  padding: var(--spacing-12);
  gap: var(--spacing-6);
}

.settlement-hero > div {
  padding: var(--spacing-6) var(--spacing-8);
  border-radius: var(--cds-radius-sm);
}

.settlement-hero .status-rail {
  gap: var(--spacing-4);
}

.settlement-hero .status-rail span {
  min-height: 22px;
  padding: 0 var(--spacing-8);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.settlement-hero .cta-primary {
  min-height: 40px;
  line-height: 40px;
}

.compact-cp-list .list-line {
  min-height: 44px;
  padding: var(--spacing-8) var(--spacing-12);
}

.revenue-guide-actions .text-link-action {
  min-height: 40px;
  display: inline-flex;
  align-items: center;
}

/* 2026-05-31 layout repair 2: resolve detail-depth overlap and metric/feed density. */
.phone.has-drilldown .screen-scroll {
  margin-bottom: 0;
  padding-bottom: var(--spacing-32);
  scroll-padding-bottom: var(--spacing-32);
}

.phone.has-drilldown .screen-scroll:has(.edit-submit-bar) {
  --edit-submit-bar-height: 66px;
  --edit-submit-bar-gap: var(--spacing-16);
  margin-bottom: calc(var(--edit-submit-bar-height) + var(--edit-submit-bar-gap));
  padding-bottom: var(--spacing-32);
  scroll-padding-bottom: calc(var(--edit-submit-bar-height) + var(--spacing-32));
}

.phone.has-drilldown .edit-submit-bar {
  bottom: var(--spacing-10, 10px);
  z-index: 5;
}

.phone.has-drilldown .appbar-actions {
  min-width: var(--spacing-36);
}

.phone.has-drilldown .appbar-action {
  display: none;
}

/* Stage metrics use vertical rows so label/value/context/benchmark do not compete in a 2x2 grid. */
.analysis-funnel-strip,
.funnel-chart {
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) !important;
  gap: var(--spacing-6) !important;
}

.analysis-step {
  min-height: 48px;
  grid-template-columns: 22px minmax(0, 1fr) minmax(56px, auto);
  border-radius: var(--cds-radius-sm);
  padding: var(--spacing-8) var(--spacing-12);
}

.analysis-step-index {
  width: 20px;
  height: 20px;
}

.analysis-step-copy {
  min-width: 0;
}

.analysis-step-label {
  max-width: 100%;
}

.analysis-step-label em {
  max-width: 76px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.analysis-step small {
  display: block;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.analysis-benchmark-note {
  margin: var(--spacing-6) 0 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
  word-break: keep-all;
}

.analysis-step strong {
  justify-self: end;
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
}

.funnel-stage {
  min-height: 52px;
  padding: var(--spacing-8) var(--spacing-12);
  gap: var(--spacing-4);
}

.funnel-stage-head strong {
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
}

.funnel-stage-foot {
  display: flex;
}

/* Certification feed: keep the first item rich, then turn repeated items into compact rows. */
.feed-list {
  gap: var(--spacing-8);
}

.feed-card.is-compact-feed {
  min-height: 88px;
  grid-template-columns: 32px minmax(0, 1fr);
  padding: var(--spacing-8);
}

.feed-card.is-compact-feed .feed-content {
  gap: 1px;
}

.feed-card.is-compact-feed h3,
.feed-card.is-compact-feed p {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.feed-card.is-compact-feed p {
  display: block;
  -webkit-line-clamp: unset;
}

.feed-card.is-compact-feed .feed-actions.is-inline {
  min-height: 36px;
  margin-top: var(--spacing-2, 2px);
}

.feed-card.is-compact-feed .feed-inline-reaction {
  min-height: 36px;
  line-height: 34px;
}

.feed-actions.is-prominent {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-4);
  align-items: stretch;
}

.feed-actions.is-prominent .feed-secondary-action {
  justify-self: start;
  min-height: 24px;
  padding: 0 2px;
  line-height: 24px;
}

/* Detail operation rows should scan like setting rows, not tall cards. */
.detail-action-list {
  gap: var(--spacing-6);
}

.detail-action-row {
  min-height: 56px;
  padding: var(--spacing-8) var(--spacing-12);
  border-radius: var(--cds-radius-sm);
}

.detail-action-row h3 {
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
}

.detail-action-row div > span:last-child {
  -webkit-line-clamp: 1;
}

.detail-action-row .row-affordance {
  max-width: 84px;
}

/* Settlement list should not expose a partial third data row in the first viewport. */
.compact-cp-list {
  gap: var(--spacing-6);
}

.compact-cp-list .list-line {
  min-height: 54px;
  padding: var(--spacing-8) var(--spacing-12);
}

.compact-cp-list .list-more-row.is-passive {
  min-height: 36px;
  color: var(--cds-color-text-secondary);
}

/* Editing screens: the fixed CTA is a footer, not a layer covering fields. */
.form-section:last-of-type {
  margin-bottom: var(--spacing-20);
}

.phone.has-drilldown .form-section:last-of-type {
  margin-bottom: var(--spacing-64);
}

/* Bottom sheets keep action fixed while only content scrolls. */
.bottom-sheet {
  max-height: min(80dvh, calc(100% - 36px), 680px);
}

.sheet-content {
  overflow-y: auto;
}

/* Entry cards are selection rows; keep them compact enough for all scenarios. */
.scenario-card {
  min-height: 104px;
  padding: var(--spacing-12);
}

/* 2026-05-31 layout repair 3: tighten mobile rhythm after contact-sheet review. */
.screen-scroll {
  padding-bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-56));
  scroll-padding-bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-44));
}

.screen-scroll > section:last-child {
  margin-bottom: var(--spacing-12);
}

.phone.has-drilldown .screen-scroll {
  padding-bottom: var(--spacing-44);
  scroll-padding-bottom: var(--spacing-44);
}

.phone.has-drilldown .screen-scroll:has(.edit-submit-bar) {
  --edit-submit-bar-height: 68px;
  --edit-submit-bar-gap: var(--spacing-12);
  margin-bottom: calc(var(--edit-submit-bar-height) + var(--edit-submit-bar-gap));
  padding-bottom: var(--spacing-20);
  scroll-padding-bottom: calc(var(--edit-submit-bar-height) + var(--spacing-28));
}

/* 2026-06-01 feedback loop: keep operation chooser above the bottom tab. */
.phone[data-tab="operation"][data-route="main"] .screen-scroll {
  gap: var(--spacing-14, 14px);
  padding-top: var(--spacing-14, 14px);
}

.phone[data-tab="operation"][data-route="main"] .section-header {
  margin-bottom: var(--spacing-8);
}

.phone[data-tab="operation"][data-route="main"] .reaction-card.is-operation-summary {
  padding: var(--spacing-12);
}

.phone[data-tab="operation"][data-route="main"] .reaction-card.is-operation-summary .cta-primary {
  min-height: 40px;
  line-height: 40px;
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list {
  gap: var(--spacing-4);
}

.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target {
  min-height: 52px;
  padding: 4px var(--spacing-8);
}

.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target .row-meta {
  display: none;
}

.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target .row-signal span {
  -webkit-line-clamp: 1;
}

.phone[data-tab="operation"][data-route="main"] .operation-more-challenges {
  display: grid;
  gap: var(--spacing-6);
}

.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .section-header {
  margin-bottom: 0;
}

/* Minor fresh-eye repair: keep right-side summaries from feeling clipped. */
.reaction-card {
  grid-template-columns: minmax(0, 1fr) 52px;
  padding-right: var(--spacing-12);
}

.reaction-number {
  min-width: 0;
}

.feed-card {
  padding-right: var(--spacing-10, 10px);
}

.feed-topline span:last-child {
  flex: 0 0 auto;
  margin-right: 2px;
}

.edit-submit-bar,
.phone.has-drilldown .edit-submit-bar {
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 6;
  margin: 0;
  padding: var(--spacing-10, 10px) var(--grid-mobile-margin) calc(var(--spacing-10, 10px) + env(safe-area-inset-bottom));
  border: 0;
  border-top: 1px solid var(--cds-color-border-default);
  border-radius: 0;
  background: var(--cds-color-surface-primary);
  box-shadow: none;
  backdrop-filter: none;
}

.edit-submit-bar::before {
  top: -24px;
  height: 24px;
  background: linear-gradient(to top, var(--cds-color-page-background), transparent);
}

.edit-submit-bar .cta-primary,
.edit-submit-bar .cta-secondary {
  min-height: 46px;
  line-height: 46px;
}

.phone.has-drilldown .form-section:last-of-type {
  margin-bottom: var(--spacing-48);
}

.compact-hero {
  padding: var(--spacing-12);
  gap: var(--spacing-6);
}

.compact-hero h2 {
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
}

.challenge-row.is-recent {
  min-height: 58px;
  padding: var(--spacing-6) var(--spacing-8);
}

.challenge-row.is-recent .stage-text-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  column-gap: var(--spacing-4);
}

.challenge-row.is-recent .stage-text-row span {
  max-width: none;
}

.challenge-row.is-recent .row-affordance {
  max-width: 72px;
}

.stage-text-row {
  gap: var(--spacing-4);
}

.stage-text-row span {
  max-width: 72px;
}

.analysis-step {
  min-height: 44px;
  padding: var(--spacing-6) var(--spacing-8);
}

.analysis-step small,
.analysis-step-label em {
  max-width: 96px;
}

.analysis-step small {
  max-width: 100%;
}

.funnel-card {
  gap: var(--spacing-6);
}

.funnel-stage,
.compact-funnel-card .funnel-stage {
  min-height: 48px;
  padding: var(--spacing-6) var(--spacing-8);
  gap: 3px;
}

.funnel-track {
  height: 4px;
}

.funnel-stage-foot {
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.diagnosis-card .action-line {
  min-height: 34px;
}

.analysis-detail-handoff {
  gap: var(--spacing-8);
}

.analysis-detail-handoff .action-list {
  gap: var(--spacing-6);
}

.analysis-detail-handoff .button-row {
  margin-top: 0;
}

.feed-card {
  padding: var(--spacing-12);
}

.feed-card.is-compact-feed {
  min-height: 70px;
  grid-template-columns: 30px minmax(0, 1fr);
  padding: var(--spacing-7, 7px) var(--spacing-8);
}

.feed-card.is-compact-feed .feed-image {
  width: 30px;
  height: 30px;
}

.feed-card.is-compact-feed .feed-topline .badge {
  max-width: 74px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.feed-card.is-compact-feed .feed-actions.is-inline {
  margin-top: 0;
  justify-content: flex-start;
}

.feed-inline-reaction {
  min-width: 44px;
  min-height: 36px;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-brand-primary-dark);
  padding: 0 var(--spacing-10, 10px);
  font-size: var(--app-type-caption-size);
  line-height: 34px;
  font-weight: var(--cds-font-weight-semibold);
}

.feed-inline-reaction.is-done,
.feed-inline-reaction[disabled] {
  color: var(--cds-color-text-tertiary);
}

.detail-action-row {
  grid-template-columns: minmax(0, 1fr) minmax(40px, auto);
}

.detail-action-row .row-affordance,
.tool-card .row-affordance,
.challenge-row .row-affordance {
  max-width: 58px;
  overflow: hidden;
}

.detail-action-row .row-affordance span:first-child,
.tool-card .row-affordance span:first-child,
.challenge-row .row-affordance span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tool-card {
  min-height: 58px;
  padding: var(--spacing-8) var(--spacing-12);
  border-radius: var(--cds-radius-sm);
}

.tool-icon {
  width: 34px;
  height: 34px;
  border-radius: 12px;
}

.tool-preview {
  -webkit-line-clamp: 1;
}

.handoff-card {
  padding: var(--spacing-12);
  gap: var(--spacing-8);
}

.settlement-hero {
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-6);
}

.settlement-hero > div,
.settlement-hero > .revenue-receivable {
  grid-column: 1 / -1;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  background: var(--cds-color-surface-raised);
}

.settlement-hero > .revenue-receivable {
  border: 1px solid color-mix(in srgb, var(--cds-color-primary) 24%, var(--cds-color-border-default));
  background: var(--cds-color-primary-background);
}

.settlement-hero > div span,
.settlement-hero > div strong {
  min-width: 0;
}

.compact-cp-list .list-line {
  min-height: 48px;
}

.sheet-backdrop {
  background: rgba(22, 22, 22, .36);
}

.bottom-sheet {
  max-height: min(78dvh, calc(100% - 36px), 660px);
}

.sheet-content {
  padding: 0 var(--spacing-20) var(--spacing-16);
  gap: var(--spacing-12);
}

.sheet-actions {
  padding: var(--spacing-10, 10px) var(--spacing-20) calc(var(--spacing-12) + env(safe-area-inset-bottom));
}

.sheet-actions .cta-primary,
.sheet-actions .cta-secondary {
  min-height: 46px;
  line-height: 46px;
}

.sheet-preview {
  gap: var(--spacing-6);
}

.bottom-sheet .settlement-confirm-list {
  gap: var(--spacing-6);
}

.bottom-sheet .settlement-confirm-list .sheet-line {
  min-height: 46px;
  padding: var(--spacing-8) var(--spacing-12);
}

.certification-chip-row {
  position: relative;
  padding-right: var(--spacing-20);
  scroll-padding-inline: var(--grid-mobile-margin);
  -webkit-mask-image: linear-gradient(to right, var(--cds-color-text-primary) calc(100% - 24px), transparent 100%);
  mask-image: linear-gradient(to right, var(--cds-color-text-primary) calc(100% - 24px), transparent 100%);
}

.certification-chip-row::after {
  content: "";
  position: sticky;
  right: 0;
  flex: 0 0 var(--spacing-20);
  width: var(--spacing-20);
  margin-left: calc(var(--spacing-20) * -1);
  background: linear-gradient(to right, transparent, var(--cds-color-page-background));
  pointer-events: none;
}

/* 2026-05-31 layout repair 4: apply the feedback loop fixes without changing product meaning. */
.bottom-sheet.is-mid {
  height: auto;
  max-height: min(62dvh, calc(100% - 36px), 540px);
}

.bottom-sheet.is-tall {
  height: auto;
  max-height: min(78dvh, calc(100% - 36px), 660px);
}

.bottom-sheet.is-tall .sheet-content,
.bottom-sheet.is-mid .sheet-content {
  min-height: 0;
  padding: 0 var(--grid-mobile-margin) var(--spacing-20, 20px);
  align-content: start;
}

.bottom-sheet.is-tall .sheet-actions,
.bottom-sheet.is-mid .sheet-actions {
  box-shadow: 0 -10px 18px rgba(0, 0, 0, .04);
}

.diagnosis-card {
  gap: var(--spacing-8);
}

.diagnosis-card .action-list {
  gap: var(--spacing-5, 5px);
}

.diagnosis-card .action-line {
  min-height: 30px;
  padding-block: var(--spacing-6);
}

.analysis-inline-action {
  width: 100%;
  min-height: 38px;
  border: 0;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  color: var(--cds-color-brand-primary-dark);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.analysis-detail-handoff .action-line {
  min-height: 32px;
}

.detail-action-row {
  grid-template-columns: minmax(0, 1fr) 52px;
}

.detail-action-row .row-affordance {
  max-width: 52px;
  justify-content: flex-end;
  gap: 2px;
}

.detail-action-row .row-affordance span:first-child {
  max-width: 38px;
}

/* Loop 8: keep operation-detail rows readable in a 390px viewport.
   The highlighted handoff row should read as eyebrow → title → meta,
   without the eyebrow visually colliding with the title. */
.detail-action-row > div {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.detail-action-row.is-focus-row {
  min-height: 76px;
  padding-block: var(--spacing-16);
}

.detail-action-row .row-meta {
  align-self: end;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.detail-action-row h3 {
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.detail-action-row div > span:last-child {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-regular);
  display: -webkit-box;
  -webkit-line-clamp: 1;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.feed-card.is-compact-feed {
  min-height: 60px;
  border: 0;
  border-top: 1px solid var(--cds-color-border-subtle);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: var(--spacing-8) var(--spacing-12);
}

.feed-card.is-compact-feed:first-child {
  border-top: 0;
}

.feed-card.is-compact-feed .feed-image {
  width: 28px;
  height: 28px;
}

.feed-card.is-compact-feed .feed-topline {
  min-height: 18px;
}

.feed-card.is-compact-feed .feed-topline span:last-child {
  white-space: nowrap;
}

.batch-card.preview-panel {
  box-shadow: none;
  border-style: dashed;
  background: var(--cds-color-surface-raised);
}

.batch-card.preview-panel.is-secondary-preview {
  margin-top: var(--spacing-20);
}


.home-revenue-card {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-lg);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-16);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--spacing-8) var(--spacing-12);
  align-items: center;
  box-shadow: var(--cds-shadow-card);
  cursor: pointer;
}

.home-revenue-block {
  display: grid;
  gap: var(--spacing-6);
}

.home-revenue-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.home-revenue-card h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-semibold);
  letter-spacing: -.15px;
  word-break: keep-all;
}

.home-revenue-note {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  word-break: keep-all;
}

.home-revenue-guide-card {
  border-color: color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-border-default));
  background: var(--app-simple-surface);
}

.home-revenue-guide-card .row-affordance {
  color: var(--cds-color-brand-primary-dark);
  font-weight: var(--cds-font-weight-semibold);
}

.home-revenue-core-card {
  min-height: 112px;
  align-items: start;
  border-style: solid;
  border-color: color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-border-default));
  background: var(--app-simple-surface);
}

.home-revenue-core-card .row-affordance {
  min-height: var(--spacing-32);
  padding: 0 var(--spacing-10, 10px);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  font-weight: var(--cds-font-weight-semibold);
}

.home-revenue-core-card.home-revenue-metric-card {
  grid-template-columns: minmax(0, 1fr);
}

.home-revenue-core-card.home-revenue-metric-card .home-revenue-copy,
.home-revenue-core-card.home-revenue-metric-card .row-affordance {
  grid-column: 1;
}

.home-revenue-core-card .is-core-revenue-value {
  grid-column: auto;
  font-size: clamp(30px, 9vw, 36px);
  line-height: 1.08;
  letter-spacing: -.7px;
}

.home-revenue-metric-card {
  min-height: 88px;
  padding: var(--spacing-14, 14px) var(--spacing-16);
  border-color: color-mix(in srgb, var(--cds-color-primary) 16%, var(--cds-color-border-default));
  background:
    radial-gradient(circle at 8% 0%, color-mix(in srgb, var(--cds-color-primary-background) 76%, transparent) 0 32%, transparent 54%),
    linear-gradient(180deg, color-mix(in srgb, var(--cds-color-primary-background) 44%, var(--cds-color-surface-primary)) 0%, var(--cds-color-surface-primary) 100%);
  grid-template-columns: minmax(0, 1fr) 14px;
  gap: var(--spacing-4) var(--spacing-8);
  align-items: center;
}

.home-revenue-core-card.home-revenue-guide-card,
.home-revenue-core-card.home-revenue-metric-card,
.home-revenue-core-card.is-first-participant {
  min-height: 112px;
  padding: var(--spacing-16);
  grid-template-columns: minmax(0, 1fr) auto;
  border-style: solid;
  border-color: color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-border-default));
  background: var(--app-simple-surface);
  box-shadow: var(--cds-shadow-card);
}

.home-revenue-label {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.home-revenue-period {
  justify-self: end;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  font-weight: var(--cds-font-weight-semibold);
  line-height: var(--app-type-caption-line);
  white-space: nowrap;
}

.home-revenue-value {
  grid-column: 1;
  min-width: 0;
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: clamp(var(--cds-font-size-20), 5.8vw, var(--cds-font-size-22));
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.45px;
  white-space: nowrap;
}

.home-revenue-chevron {
  grid-column: 2;
  grid-row: 1 / span 2;
  justify-self: end;
  align-self: center;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-semibold);
}

.home-revenue-card .row-affordance {
  grid-column: 1 / -1;
  justify-self: end;
}

.home-revenue-card:focus-visible {
  outline: var(--cds-button-focus-ring);
  outline-offset: 2px;
}

.free-zero-metrics-hero {
  gap: var(--spacing-10, 10px);
}

.free-zero-metric-note {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
  word-break: keep-all;
}


[data-scenario="free-zero"] .reaction-card.is-empty-reaction {
  border-style: dashed;
  box-shadow: none;
}


.settlement-hero > .revenue-receivable strong {
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
}

/* 2026-06-01 layout repair: remove avoidable overflow and duplicate CTA weight. */
.certification-chip-row {
  width: 100%;
  max-width: 100%;
  margin-right: 0;
  padding-right: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: start;
  align-items: center;
  overflow: visible;
  min-height: 34px;
  scroll-snap-type: none;
  -webkit-mask-image: none;
  mask-image: none;
}

.certification-chip-row:has(.chip:nth-child(4)) {
  min-height: 72px;
}

.certification-chip-row::after {
  display: none;
}

.batch-preview-row {
  width: 100%;
  margin-top: var(--spacing-16);
  border: 1px dashed var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-raised);
  box-shadow: none;
  padding: var(--spacing-12);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: var(--spacing-8);
  align-items: center;
  text-align: left;
  cursor: pointer;
}

.batch-preview-row > div {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.batch-preview-row strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.batch-preview-row div > span:not(.badge) {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.certification-auto-reaction-entry small {
  min-width: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-11);
  line-height: var(--cds-line-height-16);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.certification-auto-reaction-note {
  margin-top: var(--spacing-16);
}

.batch-preview-row .row-affordance {
  max-width: 70px;
}

.feed-actions.is-prominent .cta-sm {
  min-height: 40px;
  line-height: 40px;
}

.feed-actions.is-prominent .feed-secondary-action {
  min-height: 36px;
  line-height: 36px;
}

.list-more-row.is-challenge-more {
  min-height: 44px;
}

.analysis-detail-handoff .diagnosis-actions .cta-secondary {
  min-height: 40px;
}

.bottom-sheet.is-mid .settlement-confirm-list {
  gap: var(--spacing-5, 5px);
}

.bottom-sheet.is-mid .settlement-confirm-list .list-line {
  min-height: 42px;
  padding: var(--spacing-8) var(--spacing-12);
}

.tool-card .row-affordance {
  max-width: 72px;
}

.tool-card .row-affordance span:first-child {
  max-width: 60px;
}

.challenge-row.is-analysis-target .row-affordance {
  max-width: 82px;
}

/* 2026-06-01 feedback loop: keep trailing affordances readable by using short labels. */
.challenge-row.is-recent .row-affordance {
  max-width: 68px;
}

.challenge-row.is-operation-target {
  min-height: 68px;
}

.challenge-row.is-operation-target .row-signal {
  display: flex;
}

.challenge-row.is-operation-target .row-affordance {
  max-width: 72px;
}

.challenge-row.is-operation-target .row-affordance span:first-child {
  max-width: 60px;
}

/* 2026-06-01 experience loop: keep small trailing controls visually one-line. */
.appbar-action {
  line-height: 36px;
}

.row-affordance {
  min-height: 24px;
  line-height: 24px;
}

.row-affordance span {
  line-height: inherit;
}

.list-more-row > span:first-child {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* 2026-06-01 experience loop: keep list continuation rows visually one-line. */
.list-more-row {
  line-height: 38px;
}

.list-more-row > span,
.list-more-row strong {
  line-height: inherit;
}
.sheet-backdrop.is-modal {
  align-items: center;
  justify-content: center;
  padding: var(--spacing-16);
  padding-bottom: max(var(--spacing-16), env(safe-area-inset-bottom));
}

.exit-confirm-modal {
  width: min(100%, 320px);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: var(--cds-shadow-elevation-1);
  padding: var(--spacing-20);
  display: grid;
  gap: var(--spacing-12);
}

.exit-confirm-modal h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  font-weight: var(--cds-font-weight-semibold);
  word-break: keep-all;
}

.exit-confirm-modal p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  word-break: keep-all;
}

.exit-modal-actions {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--spacing-8);
  margin-top: var(--spacing-4);
}

.exit-modal-actions .cta-primary,
.exit-modal-actions .cta-secondary {
  min-width: 0;
  min-height: 48px;
  line-height: 48px;
}

/* Reaction encouragement: use achievement-like progress as a reward, not a task checklist. */
.reaction-complete-card {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: linear-gradient(135deg, var(--cds-color-primary-background), var(--cds-color-surface-primary));
  padding: var(--spacing-12);
  display: grid;
  gap: var(--spacing-6);
  box-shadow: var(--cds-shadow-soft);
}

.reaction-complete-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-8);
}

.reaction-complete-head strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
}

.reaction-complete-card p,
.reaction-complete-card small {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.reaction-progress {
  height: 6px;
  border-radius: 999px;
  background: var(--cds-color-surface-secondary);
  overflow: hidden;
}

.reaction-progress span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--cds-color-primary);
}

.feed-moment-reason {
  display: block;
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.bulk-sample-list {
  margin-top: var(--spacing-8);
  display: grid;
  gap: var(--spacing-6);
}

.bulk-sample-title {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-semibold);
}

.bulk-sample-row {
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
  padding: var(--spacing-8);
  display: grid;
  gap: var(--spacing-2, 2px);
}

.bulk-sample-row span,
.bulk-sample-list small {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.bulk-sample-row strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

/* 2026-06-01 sheet layout repair: keep long confirmation content above the fixed footer. */
.bottom-sheet.is-mid,
.bottom-sheet.is-tall {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
}

.bottom-sheet.is-mid .sheet-content,
.bottom-sheet.is-tall .sheet-content {
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  overscroll-behavior: contain;
  -webkit-overflow-scrolling: touch;
  padding-bottom: var(--spacing-32);
  contain: paint;
}

.bottom-sheet.is-mid .sheet-actions,
.bottom-sheet.is-tall .sheet-actions {
  position: relative;
  bottom: auto;
  margin-top: 0;
}

.bulk-sample-list {
  padding-bottom: var(--spacing-4);
}

/* 2026-06-01 sheet layout repair follow-up: mid sheets with sample previews need enough body room above the footer. */
.bottom-sheet.is-mid {
  max-height: min(70dvh, calc(100% - 36px), 580px);
}

/* 2026-06-01 full-loop repair: keep certification suggestion copy readable without horizontal truncation. */
.feed-suggestion {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  align-items: start;
  gap: var(--spacing-4);
  padding: var(--spacing-8);
}

.feed-suggestion span,
.feed-suggestion strong {
  flex: none;
  width: 100%;
  min-width: 0;
  white-space: normal;
  text-overflow: clip;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.feed-suggestion span {
  -webkit-line-clamp: 1;
}

.feed-suggestion strong {
  -webkit-line-clamp: 2;
}

/* 2026-06-01 full-loop repair: keep lower operation rows above the bottom tabs. */
.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .section-header {
  margin-bottom: var(--spacing-4);
}

.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .challenge-row.is-operation-target {
  min-height: 40px;
  padding: 2px var(--spacing-8);
}

.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .challenge-row.is-operation-target .thumb,
.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .challenge-row.is-operation-target .row-meta {
  display: none;
}

.phone[data-tab="operation"][data-route="main"] .operation-more-summary {
  min-height: 36px;
  line-height: 36px;
}

/* 2026-06-01 spacing hardening: repeated rounded rows must own enough inner padding. */
.challenge-row.is-recent,
.challenge-row.is-analysis-target,
.challenge-row.is-operation-target,
.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target,
.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .challenge-row.is-operation-target {
  padding: var(--spacing-8) var(--spacing-12);
}

.challenge-row.is-recent {
  min-height: 64px;
}

.challenge-row.is-analysis-target {
  min-height: 72px;
}

.challenge-row.is-operation-target,
.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target {
  min-height: 60px;
}

.phone[data-tab="operation"][data-route="main"] .operation-more-challenges .challenge-row.is-operation-target {
  min-height: 48px;
}

.analysis-step,
.funnel-stage,
.compact-funnel-card .funnel-stage {
  padding: var(--spacing-8) var(--spacing-12);
}

.list-more-row,
.list-more-row.is-challenge-more,
.list-more-row.is-passive,
.phone[data-tab="operation"][data-route="main"] .operation-more-summary {
  min-height: 42px;
  padding: var(--spacing-8) var(--spacing-12);
  line-height: var(--app-type-meta-line);
}

.list-more-row > span,
.list-more-row strong {
  line-height: var(--app-type-meta-line);
}

.phone[data-tab="operation"][data-route="main"] .screen-scroll {
  gap: var(--spacing-8);
  padding-bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-64));
  scroll-padding-bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-56));
}

.phone[data-tab="operation"][data-route="main"] .operation-more-summary {
  min-height: 34px;
  margin-bottom: var(--spacing-24);
}

/* 2026-06-01 operation repair: show all challenge targets and split tool entries. */
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list {
  gap: var(--spacing-6);
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card {
  min-height: 60px;
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-preview {
  -webkit-line-clamp: 1;
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .row-affordance {
  max-width: 82px;
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .row-affordance span:first-child {
  max-width: 72px;
}

.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target .row-affordance {
  max-width: 88px;
}

.phone[data-tab="operation"][data-route="main"] .challenge-row.is-operation-target .row-affordance span:first-child {
  max-width: 78px;
}

.diagnosis-actions .text-link-action {
  width: 100%;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-button);
  background: var(--cds-color-surface-primary);
  padding: 0 var(--spacing-12);
  text-align: center;
  text-decoration: none;
}

/* 2026-06-02 visual polish pass: keep the existing contracts, but raise product-like depth and hierarchy. */
:root {
  --app-polish-border: color-mix(in srgb, var(--cds-color-border-default) 72%, transparent);
  --app-polish-border-strong: color-mix(in srgb, var(--cds-color-border-strong) 78%, transparent);
  --app-polish-surface: linear-gradient(180deg, var(--cds-color-surface-primary) 0%, color-mix(in srgb, var(--cds-color-surface-raised) 72%, var(--cds-color-surface-primary)) 100%);
  --app-polish-page: radial-gradient(circle at 16% -6%, color-mix(in srgb, var(--cds-color-primary-background) 78%, transparent) 0 28%, transparent 48%),
    linear-gradient(180deg, color-mix(in srgb, var(--cds-color-surface-raised) 68%, var(--cds-color-surface-primary)) 0%, var(--cds-color-page-background) 52%);
  --app-polish-shadow-soft: 0 10px 28px color-mix(in srgb, var(--cds-color-text-primary) 7%, transparent);
  --app-polish-shadow-lifted: 0 16px 36px color-mix(in srgb, var(--cds-color-primary) 10%, transparent), 0 3px 10px color-mix(in srgb, var(--cds-color-text-primary) 6%, transparent);
  --app-polish-shadow-row: 0 6px 14px color-mix(in srgb, var(--cds-color-text-primary) 5%, transparent);
}

html,
body {
  background:
    radial-gradient(circle at 50% -16%, color-mix(in srgb, var(--cds-color-primary-background) 64%, transparent) 0 30%, transparent 55%),
    var(--cds-color-bg-page);
}

.phone,
.entry-shell {
  background: var(--app-polish-page);
}

.screen-scroll {
  background: transparent;
}

.screen-scroll > * {
  flex-shrink: 0;
}

.appbar {
  background: color-mix(in srgb, var(--cds-color-surface-primary) 90%, transparent);
  border-bottom-color: color-mix(in srgb, var(--cds-color-border-default) 56%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.root-exit-action,
.back-action,
.appbar-action {
  background: color-mix(in srgb, var(--cds-color-surface-primary) 72%, transparent);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-border-default) 68%, transparent);
}

.appbar.drilldown .back-action {
  background: transparent;
  box-shadow: none;
}

.bottom-tabs {
  border-top: 0;
  background: color-mix(in srgb, var(--cds-color-surface-primary) 93%, transparent);
  box-shadow: 0 -12px 28px color-mix(in srgb, var(--cds-color-text-primary) 7%, transparent);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.bottom-tab {
  border-radius: var(--cds-radius-card);
}

.bottom-tab span {
  width: 30px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: var(--cds-radius-full);
  transition: background-color .16s ease, transform .16s ease;
}

.bottom-tab.is-active span {
  background: var(--cds-color-primary-background);
  transform: translateY(-1px);
}

.entry-hero,
.scenario-card,
.hero-card,
.detail-hero,
.settlement-hero,
.card,
.batch-card,
.empty-card,
.tool-card,
.preview-card,
.mini-card,
.reaction-card,
.secondary-panel,
.locked-panel,
.analysis-summary,
.scope-note,
.form-section,
.message-preview-card {
  border-color: var(--app-polish-border);
  background: var(--app-polish-surface);
  box-shadow: var(--app-polish-shadow-row);
}

.entry-hero,
.hero-card,
.detail-hero,
.settlement-hero {
  position: relative;
  overflow: hidden;
  border-color: color-mix(in srgb, var(--cds-color-primary) 18%, var(--app-polish-border));
  background:
    radial-gradient(circle at 92% 2%, color-mix(in srgb, var(--cds-color-primary-background) 82%, transparent) 0 30%, transparent 52%),
    linear-gradient(180deg, var(--cds-color-surface-primary) 0%, color-mix(in srgb, var(--cds-color-primary-background) 28%, var(--cds-color-surface-primary)) 100%);
  box-shadow: var(--app-polish-shadow-lifted);
}

.entry-hero::after,
.hero-card::after,
.detail-hero::after,
.settlement-hero::after {
  content: "";
  position: absolute;
  top: var(--spacing-12);
  right: var(--spacing-12);
  width: 54px;
  height: 54px;
  border-radius: var(--cds-radius-full);
  background:
    radial-gradient(circle, color-mix(in srgb, var(--cds-color-primary) 28%, transparent) 0 34%, transparent 35%),
    radial-gradient(circle at 68% 68%, color-mix(in srgb, var(--cds-color-primary) 16%, transparent) 0 24%, transparent 25%);
  pointer-events: none;
}

.entry-hero > *,
.hero-card > *,
.detail-hero > *,
.settlement-hero > * {
  position: relative;
  z-index: 1;
}

.brand-mark,
.scenario-tier,
.badge {
  background: color-mix(in srgb, var(--cds-color-primary-background) 82%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 16%, transparent);
}

.section-header > span,
.eyebrow,
.row-meta {
  letter-spacing: -.05px;
}

.metric-strip {
  gap: var(--spacing-6);
}

.metric-cell {
  border-color: var(--app-polish-border);
  background: linear-gradient(180deg, var(--cds-color-surface-primary), color-mix(in srgb, var(--cds-color-surface-raised) 76%, var(--cds-color-surface-primary)));
  box-shadow: inset 0 1px 0 color-mix(in srgb, var(--cds-color-neutral-white) 78%, transparent);
}

.metric-cell strong,
.hero-metric-row strong,
.analysis-step strong,
.funnel-stage-head strong,
.list-line b,
.settlement-hero strong {
  letter-spacing: -.35px;
}

.hero-metric-row span,
.stage-chip-row span,
.chip,
.reason-chip-row span,
.status-rail span {
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 72%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-border-default) 52%, transparent);
}

.cta-primary:not([disabled]):not([aria-disabled="true"]) {
  border-color: color-mix(in srgb, var(--cds-color-primary) 84%, var(--cds-color-brand-primary-dark));
  background: linear-gradient(180deg, color-mix(in srgb, var(--cds-color-primary-hover) 74%, var(--cds-color-primary)) 0%, var(--cds-color-primary) 100%);
  color: var(--cds-color-text-inverse);
  box-shadow: 0 10px 22px color-mix(in srgb, var(--cds-color-primary) 20%, transparent);
}

.cta-secondary:not([disabled]):not([aria-disabled="true"]),
.text-link-action {
  border-color: var(--app-polish-border-strong);
  background: color-mix(in srgb, var(--cds-color-surface-primary) 92%, var(--cds-color-surface-raised));
  box-shadow: 0 5px 12px color-mix(in srgb, var(--cds-color-text-primary) 4%, transparent);
}

.scenario-card,
.interactive-row,
.tool-card,
.feed-card,
.detail-action-row,
.list-more-row {
  transition:
    transform .16s ease,
    border-color .16s ease,
    box-shadow .16s ease,
    background-color .16s ease;
}

.scenario-card:hover,
.interactive-row:hover,
.tool-card:hover,
.feed-card:hover,
.detail-action-row:hover,
.list-more-row:hover {
  border-color: color-mix(in srgb, var(--cds-color-primary) 20%, var(--cds-color-border-default));
  box-shadow: var(--app-polish-shadow-soft);
}

.scenario-card:active,
.interactive-row:active,
.tool-card:active,
.feed-card:active,
.detail-action-row:active,
.list-more-row:active {
  transform: translateY(1px) scale(.997);
}

.thumb,
.tool-icon,
.empty-icon,
.preview-art {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary-background) 88%, var(--cds-color-surface-primary)) 0%, color-mix(in srgb, var(--cds-color-primary) 22%, var(--cds-color-primary-background)) 100%);
  box-shadow:
    inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 18%, transparent),
    0 5px 12px color-mix(in srgb, var(--cds-color-primary) 8%, transparent);
}

.row-list .challenge-row:nth-child(2n) .thumb,
.feed-list .feed-card:nth-child(2n) .feed-image {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-secondary) 78%, var(--cds-color-surface-primary)) 0%, color-mix(in srgb, var(--cds-color-semantic-info) 22%, var(--cds-color-secondary)) 100%);
  color: var(--cds-color-semantic-info);
}

.challenge-row,
.analysis-revenue-row,
.funnel-stage,
.list-line,
.guide-list > div,
.detail-action-row,
.select-like-row,
.trigger-row,
.bottom-sheet .settlement-confirm-list .list-line,
.bottom-sheet .settlement-confirm-list .sheet-line {
  border-color: var(--app-polish-border);
  background: var(--app-polish-surface);
  box-shadow: var(--app-polish-shadow-row);
}

.row-affordance {
  min-height: 28px;
  padding: 0 var(--spacing-8);
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-surface-raised) 70%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-border-default) 56%, transparent);
}

.challenge-row.is-recent .row-affordance,
.challenge-row.is-analysis-target .row-affordance,
.challenge-row.is-operation-target .row-affordance {
  padding-inline: var(--spacing-6);
}

.reaction-card.is-primary-action {
  border-color: color-mix(in srgb, var(--cds-color-primary) 32%, var(--cds-color-border-default));
  background:
    radial-gradient(circle at 92% 8%, color-mix(in srgb, var(--cds-color-primary-background) 88%, transparent) 0 30%, transparent 55%),
    var(--app-polish-surface);
  box-shadow: var(--app-polish-shadow-lifted);
}

.reaction-number {
  background: linear-gradient(180deg, color-mix(in srgb, var(--cds-color-primary-background) 90%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-primary) 13%, var(--cds-color-primary-background)));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 20%, transparent);
}

.feed-card {
  overflow: hidden;
}

.feed-image {
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-neutral-white) 36%, transparent);
}

.feed-suggestion,
.reason-box,
.preset-box,
.sheet-preview {
  border-color: color-mix(in srgb, var(--cds-color-primary) 14%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-primary-background) 66%, var(--cds-color-surface-primary));
}

.analysis-step {
  border-color: var(--app-polish-border);
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--cds-color-primary-background) 55%, transparent) 0 3px, transparent 3px),
    var(--app-polish-surface);
  box-shadow: var(--app-polish-shadow-row);
}

.analysis-step-index {
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 20%, transparent);
}

.analysis-step.is-warning {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--cds-color-semantic-warning) 22%, transparent) 0 3px, transparent 3px),
    var(--app-polish-surface);
}

.analysis-step.is-warning .analysis-step-index {
  background: color-mix(in srgb, var(--cds-color-semantic-warning) 12%, var(--cds-color-surface-primary));
  color: color-mix(in srgb, var(--cds-color-semantic-warning) 76%, var(--cds-color-text-primary));
}

.funnel-track {
  height: 6px;
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 82%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-border-default) 52%, transparent);
}

.funnel-fill {
  background: linear-gradient(90deg, var(--cds-color-primary), var(--cds-color-brand-primary-dark));
}

.funnel-stage.is-baseline .funnel-fill {
  background: linear-gradient(90deg, var(--cds-color-border-strong), color-mix(in srgb, var(--cds-color-border-strong) 68%, var(--cds-color-text-tertiary)));
}

.funnel-benchmark {
  border-left-color: color-mix(in srgb, var(--cds-color-text-secondary) 56%, transparent);
}

.tool-card.operation-tool-entry .tool-icon {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-surface-secondary) 70%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-primary-background) 78%, var(--cds-color-surface-primary)));
}

.locked-panel {
  border-color: color-mix(in srgb, var(--cds-color-border-default) 72%, transparent);
  background:
    repeating-linear-gradient(135deg, transparent 0 12px, color-mix(in srgb, var(--cds-color-surface-secondary) 46%, transparent) 12px 13px),
    var(--app-polish-surface);
}

.bottom-sheet {
  border-color: var(--app-polish-border);
  background: linear-gradient(180deg, var(--cds-color-surface-primary), color-mix(in srgb, var(--cds-color-surface-raised) 42%, var(--cds-color-surface-primary)));
  box-shadow: 0 -22px 44px color-mix(in srgb, var(--cds-color-text-primary) 14%, transparent);
}

.sheet-handle {
  background: color-mix(in srgb, var(--cds-color-border-strong) 80%, var(--cds-color-text-tertiary));
}

.sheet-actions {
  background: linear-gradient(to top, var(--cds-color-surface-primary), color-mix(in srgb, var(--cds-color-surface-primary) 84%, transparent));
}

/* 2026-06-02 simplification pass: reduce decorative emphasis while keeping the screen contracts intact. */
:root {
  --app-simple-border: color-mix(in srgb, var(--cds-color-border-default) 86%, transparent);
  --app-simple-surface: var(--cds-color-surface-primary);
  --app-simple-raised: color-mix(in srgb, var(--cds-color-surface-raised) 60%, var(--cds-color-surface-primary));
}

html,
body {
  background: var(--cds-color-bg-page);
}

.phone,
.entry-shell {
  background: linear-gradient(180deg, var(--cds-color-page-background) 0%, var(--app-simple-raised) 100%);
}

.appbar {
  background: color-mix(in srgb, var(--cds-color-surface-primary) 94%, transparent);
  border-bottom-color: var(--app-simple-border);
  box-shadow: none;
}

.bottom-tabs {
  border-top: 1px solid var(--app-simple-border);
  box-shadow: 0 -6px 16px color-mix(in srgb, var(--cds-color-text-primary) 5%, transparent);
}

.bottom-tab span {
  width: 28px;
  height: 22px;
}

.bottom-tab.is-active span {
  background: color-mix(in srgb, var(--cds-color-primary-background) 72%, var(--cds-color-surface-primary));
  transform: none;
}

.entry-hero,
.hero-card,
.detail-hero,
.settlement-hero {
  border-color: var(--app-simple-border);
  background: var(--app-simple-surface);
  box-shadow: var(--cds-shadow-card);
}

.entry-hero::after,
.hero-card::after,
.detail-hero::after,
.settlement-hero::after {
  display: none;
}

.scenario-card,
.card,
.batch-card,
.empty-card,
.tool-card,
.preview-card,
.mini-card,
.reaction-card,
.secondary-panel,
.locked-panel,
.analysis-summary,
.scope-note,
.form-section,
.message-preview-card,
.challenge-row,
.analysis-revenue-row,
.funnel-stage,
.list-line,
.guide-list > div,
.detail-action-row,
.select-like-row,
.trigger-row,
.bottom-sheet .settlement-confirm-list .list-line,
.bottom-sheet .settlement-confirm-list .sheet-line {
  border-color: var(--app-simple-border);
  background: var(--app-simple-surface);
  box-shadow: var(--cds-shadow-card);
}

.scenario-card:hover,
.interactive-row:hover,
.tool-card:hover,
.feed-card:hover,
.detail-action-row:hover,
.list-more-row:hover {
  border-color: var(--app-simple-border);
  box-shadow: var(--cds-shadow-card);
}

.brand-mark,
.scenario-tier,
.badge {
  background: color-mix(in srgb, var(--cds-color-primary-background) 66%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 10%, transparent);
}

.hero-metric-row span,
.stage-chip-row span,
.chip,
.reason-chip-row span,
.status-rail span,
.metric-cell {
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 58%, var(--cds-color-surface-primary));
  box-shadow: none;
}

.thumb,
.tool-icon,
.empty-icon,
.preview-art,
.row-list .challenge-row:nth-child(2n) .thumb,
.feed-list .feed-card:nth-child(2n) .feed-image,
.tool-card.operation-tool-entry .tool-icon {
  background: color-mix(in srgb, var(--cds-color-primary-background) 76%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 12%, transparent);
  color: var(--cds-color-brand-primary-dark);
}

.row-affordance {
  min-height: auto;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-tertiary);
}

.reaction-card.is-primary-action {
  border-color: color-mix(in srgb, var(--cds-color-primary) 24%, var(--cds-color-border-default));
  background: var(--app-simple-surface);
  box-shadow: var(--cds-shadow-card);
}

.reaction-number {
  background: color-mix(in srgb, var(--cds-color-primary-background) 74%, var(--cds-color-surface-primary));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-primary) 14%, transparent);
}

.cta-primary:not([disabled]):not([aria-disabled="true"]) {
  background: var(--cds-color-primary);
  border-color: var(--cds-color-primary);
  box-shadow: 0 5px 12px color-mix(in srgb, var(--cds-color-primary) 14%, transparent);
}

.cta-secondary:not([disabled]):not([aria-disabled="true"]),
.text-link-action {
  border-color: var(--app-simple-border);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.analysis-step {
  border-color: var(--app-simple-border);
  background: var(--app-simple-surface);
  box-shadow: var(--cds-shadow-card);
}

.analysis-step-index {
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 72%, var(--cds-color-surface-primary));
  color: var(--cds-color-text-secondary);
  box-shadow: none;
}

.analysis-step.is-warning {
  border-color: color-mix(in srgb, var(--cds-color-semantic-warning) 32%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-semantic-warning) 7%, var(--cds-color-surface-primary));
}

.analysis-step.is-warning .analysis-step-index {
  background: color-mix(in srgb, var(--cds-color-semantic-warning) 12%, var(--cds-color-surface-primary));
  color: color-mix(in srgb, var(--cds-color-semantic-warning) 76%, var(--cds-color-text-primary));
}

.funnel-track {
  height: 5px;
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 72%, var(--cds-color-surface-primary));
  box-shadow: none;
}

.funnel-fill {
  background: var(--cds-color-primary);
}

.reason-box,
.sheet-preview:not(.sheet-preview--message) {
  border-color: var(--app-simple-border);
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 52%, var(--cds-color-surface-primary));
}

.feed-suggestion,
.preset-box,
.sheet-preview--message {
  border-color: color-mix(in srgb, var(--cds-color-primary) 16%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-primary-light) 88%, var(--cds-color-surface-primary));
  color: var(--cds-color-primary-light-foreground);
}

.feed-suggestion span,
.feed-suggestion strong,
.preset-box,
.sheet-preview--message span {
  color: var(--cds-color-primary-light-foreground);
}

.locked-panel {
  background: var(--app-simple-surface);
}

.bottom-sheet {
  border-color: var(--app-simple-border);
  background: var(--cds-color-surface-primary);
  box-shadow: 0 -12px 28px color-mix(in srgb, var(--cds-color-text-primary) 10%, transparent);
}

/* 2026-06-02 subagent layout repair: bottom sheets should own safe-area padding internally, not leave dimmed backdrop below the sheet. */
.sheet-backdrop:not(.is-modal) {
  padding-bottom: 0;
}

.sheet-handle {
  background: color-mix(in srgb, var(--cds-color-border-strong) 58%, var(--cds-color-text-tertiary));
}

.sheet-actions {
  background: linear-gradient(to top, var(--cds-color-surface-primary), color-mix(in srgb, var(--cds-color-surface-primary) 90%, transparent));
}

/* 2026-06-02 layout density repair: demote repeated cards into compact rows/lists. */
.hero-metric-row {
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-sm);
  overflow: hidden;
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 38%, var(--cds-color-surface-primary));
}

.hero-metric-row > span {
  border-radius: 0;
  border: 0;
  background: transparent;
  padding: var(--spacing-8) var(--spacing-6);
}

.hero-metric-row > span:not(:last-child) {
  border-right: 1px solid var(--app-simple-border);
}

/* 2026-06-03 home metric panel: one surface, period as meta, numbers as the cue. */
.phone[data-tab="home"][data-route="main"] .screen-scroll {
  gap: var(--spacing-16);
  padding-top: var(--spacing-14, 14px);
}

.home-metric-block {
  display: grid;
  gap: var(--spacing-6);
}

.home-metric-panel {
  display: grid;
  gap: var(--spacing-8);
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.home-metric-period {
  justify-self: end;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  font-weight: var(--cds-font-weight-semibold);
  line-height: var(--app-type-caption-line);
}

button.home-metric-period {
  appearance: none;
  width: 100%;
  border: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  text-align: left;
}

.home-metric-panel .hero-metric-row {
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-raised);
}

.home-metric-cell {
  appearance: none;
  min-width: 0;
  min-height: var(--spacing-64);
  display: grid;
  align-content: center;
  gap: var(--spacing-4);
  border: 0;
  border-right: 1px solid var(--cds-color-border-default);
  border-radius: 0;
  background: transparent;
  color: inherit;
  cursor: pointer;
  font: inherit;
  padding: var(--spacing-10, 10px) var(--spacing-12);
  text-align: left;
  transition:
    background-color .16s ease,
    transform .16s ease;
}

.home-metric-cell:last-child {
  border-right: 0;
}

.home-metric-cell:hover {
  background: color-mix(in srgb, var(--cds-color-primary-background) 48%, var(--cds-color-surface-raised));
}

.home-metric-cell:focus-visible {
  outline: 0;
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--cds-color-primary) 52%, var(--cds-color-border-default));
}

.home-metric-cell:active {
  background: color-mix(in srgb, var(--cds-color-primary-background) 56%, var(--cds-color-surface-primary));
  transform: translateY(1px);
}

.home-metric-cell em {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.home-metric-cell strong {
  font-size: clamp(var(--cds-font-size-20), 5.8vw, var(--cds-font-size-22));
  line-height: var(--cds-line-height-28);
  letter-spacing: -.45px;
}

.home-metric-cell strong.is-signal-value {
  color: var(--cds-color-brand-primary-dark);
}

.home-metric-cell strong.is-negative-value {
  color: var(--cds-color-semantic-error);
}

.home-metric-cell strong.is-neutral-value {
  color: var(--cds-color-text-primary);
}

.home-metric-panel .free-zero-metric-note {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  word-break: keep-all;
}

@media (max-width: 360px) {
  .home-metric-panel {
    padding: 0;
  }

  .home-metric-cell {
    padding: var(--spacing-6);
  }

  .home-metric-cell strong {
    font-size: clamp(var(--cds-font-size-20), 5.8vw, var(--cds-font-size-22));
  }
}

/* 2026-06-03 home lower density: section action + grouped recent rows + compact empty reaction. */
.section-header.is-with-action {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: var(--spacing-12);
}

.section-header.is-with-action > div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.section-link-action {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  min-height: var(--spacing-32);
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
}

.recent-challenge-card {
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.recent-challenge-item {
  min-height: 84px;
  display: grid;
  align-items: center;
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: var(--spacing-14, 14px) var(--spacing-16);
  cursor: pointer;
}

.recent-challenge-item:last-child {
  border-bottom: 0;
}

.recent-challenge-item:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--cds-color-primary) 72%, transparent);
  outline-offset: calc(var(--spacing-4) * -1);
}

.recent-challenge-content {
  min-width: 0;
  display: grid;
  grid-template-columns: var(--spacing-44) minmax(0, 1fr) var(--spacing-20);
  align-items: center;
  gap: var(--spacing-12);
}

.challenge-thumb {
  position: relative;
  width: var(--spacing-44);
  height: var(--spacing-44);
  overflow: hidden;
  border-radius: var(--cds-radius-sm);
  display: grid;
  place-items: center;
  color: var(--cds-color-brand-primary-dark);
  background:
    radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--cds-color-neutral-white) 72%, transparent) 0 18%, transparent 42%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary-background) 88%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-primary) 22%, var(--cds-color-primary-background)));
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--cds-color-border-default) 58%, transparent);
}

.challenge-thumb::after {
  content: "";
  position: absolute;
  right: calc(var(--spacing-6) * -1);
  bottom: calc(var(--spacing-6) * -1);
  width: var(--spacing-24);
  height: var(--spacing-24);
  border-radius: var(--cds-radius-full);
  background: color-mix(in srgb, var(--cds-color-primary) 18%, transparent);
}

.challenge-thumb span {
  position: relative;
  z-index: 1;
  font-size: var(--app-type-row-title-size);
  line-height: var(--app-type-row-title-line);
  font-weight: var(--cds-font-weight-bold);
}

.challenge-thumb.is-blue {
  color: var(--cds-color-semantic-info);
  background:
    radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--cds-color-neutral-white) 72%, transparent) 0 18%, transparent 42%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-secondary) 82%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-semantic-info) 18%, var(--cds-color-secondary)));
}

.challenge-thumb.is-orange {
  color: color-mix(in srgb, var(--cds-color-semantic-warning) 82%, var(--cds-color-text-primary));
  background:
    radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--cds-color-neutral-white) 72%, transparent) 0 18%, transparent 42%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-warning) 18%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-warning) 28%, var(--cds-color-surface-secondary)));
}

.challenge-thumb.is-purple {
  color: color-mix(in srgb, var(--cds-color-semantic-info) 70%, var(--cds-color-brand-primary-dark));
  background:
    radial-gradient(circle at 72% 18%, color-mix(in srgb, var(--cds-color-neutral-white) 72%, transparent) 0 18%, transparent 42%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary-background) 56%, var(--cds-color-secondary)), color-mix(in srgb, var(--cds-color-semantic-info) 12%, var(--cds-color-primary-background)));
}

.recent-challenge-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.recent-challenge-copy > strong {
  min-width: 0;
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-title-size);
  line-height: var(--app-type-row-title-line);
  font-weight: var(--cds-font-weight-semibold);
  letter-spacing: -.2px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.recent-inline-metrics {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: var(--spacing-4);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  white-space: nowrap;
}

.recent-inline-metrics span {
  display: inline-flex;
  align-items: baseline;
  gap: 3px;
}

.recent-inline-metrics em,
.recent-inline-metrics i {
  color: var(--cds-color-text-secondary);
  font-style: normal;
}

.recent-inline-metrics strong {
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-weight: var(--cds-font-weight-bold);
}

.recent-inline-metrics strong.is-signal-value {
  color: var(--cds-color-brand-primary-dark);
}

.recent-inline-metrics strong.is-neutral-value {
  color: var(--cds-color-text-primary);
}

.recent-challenge-item .row-affordance {
  align-self: center;
  justify-self: end;
  width: var(--spacing-20);
  justify-content: center;
  padding: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-28);
}

.recent-challenge-item .row-affordance.is-chevron-only {
  min-height: var(--spacing-32);
}

.reaction-empty-section {
  display: grid;
}

.reaction-empty-section.is-home-reaction-summary {
  margin-top: 0;
}

.reaction-empty-card {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  align-items: center;
  gap: var(--spacing-12);
  border: 1px solid color-mix(in srgb, var(--cds-color-primary) 14%, var(--cds-color-border-default));
  border-radius: var(--cds-radius-lg);
  background:
    radial-gradient(circle at 0% 0%, color-mix(in srgb, var(--cds-color-primary-background) 74%, transparent) 0 34%, transparent 56%),
    linear-gradient(180deg, color-mix(in srgb, var(--cds-color-primary-background) 34%, var(--cds-color-surface-primary)), var(--cds-color-surface-primary));
  box-shadow: var(--cds-shadow-card);
  padding: var(--spacing-16) var(--spacing-20);
}

.reaction-empty-section.is-home-reaction-summary .reaction-empty-card {
  grid-template-columns: 48px minmax(0, 1fr);
}

.reaction-empty-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-none);
}

.reaction-empty-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.reaction-empty-copy h3,
.reaction-empty-copy p {
  margin: 0;
  min-width: 0;
  word-break: keep-all;
}

.reaction-empty-copy h3 {
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.reaction-empty-copy p {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

@media (max-width: 360px) {
  .recent-challenge-item {
    padding: var(--spacing-12) var(--spacing-16);
  }

  .reaction-empty-card {
    grid-template-columns: 44px minmax(0, 1fr);
    padding: var(--spacing-14, 14px) var(--spacing-16);
  }

  .reaction-empty-section.is-home-reaction-summary .reaction-empty-card {
    grid-template-columns: 44px minmax(0, 1fr);
  }

  .reaction-empty-icon {
    width: 44px;
    height: 44px;
  }
}

.analysis-funnel-strip {
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  overflow: hidden;
}

.analysis-step {
  border: 0;
  border-radius: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  min-height: 42px;
  padding: var(--spacing-6) var(--spacing-12);
  box-shadow: none;
}

.analysis-step:last-child {
  border-bottom: 0;
}

.list-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-8);
}

.list-line b {
  justify-self: end;
  text-align: right;
}

.phone[data-tab="analysis"][data-route="main"] .challenge-row.is-analysis-target {
  min-height: 66px;
  grid-template-columns: 26px minmax(0, 1fr) auto;
  padding: var(--spacing-6) var(--spacing-10, 10px);
}

.phone[data-tab="analysis"][data-route="main"] .challenge-row.is-analysis-target .thumb {
  width: 26px;
  height: 26px;
}

.phone[data-tab="analysis"][data-route="main"] .challenge-row.is-analysis-target .row-affordance {
  max-width: 72px;
}

.phone[data-tab="analysis"][data-route="main"] .challenge-row.is-analysis-target .row-meta {
  display: none;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-challenge-list {
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  overflow: hidden;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-challenge-list .challenge-row.is-analysis-target {
  border: 0;
  border-radius: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  box-shadow: none;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-challenge-list .challenge-row.is-analysis-target:last-child {
  border-bottom: 0;
}

.phone[data-tab="operation"][data-route="main"] .screen-scroll {
  gap: var(--spacing-14, 14px);
}

.phone[data-tab="operation"][data-route="main"] .reaction-card.is-operation-summary {
  padding: var(--spacing-10, 10px);
  gap: var(--spacing-4);
}

.phone[data-tab="operation"][data-route="main"] .reaction-card.is-operation-summary .reaction-number {
  padding: var(--spacing-6) var(--spacing-4);
}

.phone[data-tab="operation"][data-route="main"] .reaction-card.is-operation-summary .cta-primary {
  min-height: 38px;
  line-height: 38px;
}

.analysis-revenue-block {
  margin-top: var(--spacing-8);
  padding-top: var(--spacing-8);
  gap: var(--spacing-4);
}

.analysis-revenue-row {
  min-height: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
  grid-template-columns: minmax(0, 1fr) auto;
}

.analysis-revenue-row small {
  grid-column: 1 / -1;
}

/* 2026-06-02 rerun layout repair: keep Analysis 1-depth clear of the bottom tab. */
.phone[data-tab="analysis"][data-route="main"] .screen-scroll {
  gap: var(--spacing-16);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-step {
  min-height: 38px;
  padding: var(--spacing-4) var(--spacing-12);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-step-index {
  width: 20px;
  height: 20px;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-revenue-block {
  margin-top: var(--spacing-8);
  padding-top: var(--spacing-8);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-revenue-row {
  min-height: 34px;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-challenge-list .challenge-row.is-analysis-target {
  min-height: 58px;
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list,
.compact-cp-list {
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  overflow: hidden;
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card.operation-tool-entry,
.compact-cp-list .list-line {
  border: 0;
  border-radius: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  box-shadow: none;
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target:last-child,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card.operation-tool-entry:last-child,
.compact-cp-list .list-line:last-child {
  border-bottom: 0;
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target {
  min-height: 54px;
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list .thumb,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-icon {
  width: 28px;
  height: 28px;
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 74%, var(--cds-color-surface-primary));
  color: var(--cds-color-text-secondary);
  box-shadow: none;
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card.operation-tool-entry {
  min-height: 50px;
  padding: var(--spacing-6) var(--spacing-10, 10px);
  grid-template-columns: 24px minmax(0, 1fr) auto;
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .row-meta {
  display: none;
}

.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-icon {
  width: 24px;
  height: 24px;
  font-size: var(--app-type-caption-size);
}

.compact-cp-list .list-line {
  min-height: 56px;
  padding: var(--spacing-8) var(--spacing-10, 10px);
  grid-template-columns: minmax(0, 1fr) auto;
}

.compact-cp-list .list-line > div {
  gap: 0;
}

.bottom-sheet .settlement-confirm-list {
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  overflow: hidden;
}

.bottom-sheet .settlement-confirm-list .sheet-line,
.bottom-sheet .settlement-confirm-list .list-line {
  min-height: 44px;
  border: 0;
  border-radius: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  box-shadow: none;
  padding: var(--spacing-8) var(--spacing-12);
}

.bottom-sheet .settlement-confirm-list .sheet-line:last-child,
.bottom-sheet .settlement-confirm-list .list-line:last-child {
  border-bottom: 0;
}

.bottom-sheet .settlement-confirm-list .sheet-line:not(.is-long) {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.bottom-sheet .settlement-confirm-list .sheet-line:not(.is-long) b {
  justify-self: end;
  text-align: right;
  white-space: nowrap;
}

.bottom-sheet .settlement-confirm-list .list-line {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-8);
}

.bottom-sheet .settlement-confirm-list .list-line b {
  justify-self: end;
  text-align: right;
  white-space: nowrap;
  overflow-wrap: normal;
}

.bulk-sample-row {
  border-color: var(--app-simple-border);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

/* 2026-06-02 audit repair: keep compact labels and recent metrics readable at 375px. */
.diagnosis-card .action-line > span,
.action-line > span {
  flex: 0 0 auto;
  min-width: max-content;
  white-space: nowrap;
}

.diagnosis-card .action-line > strong,
.action-line > strong {
  min-width: 0;
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.stage-text-row {
  max-width: 100%;
  flex-wrap: wrap;
  overflow: visible;
  white-space: normal;
}

.stage-text-row span {
  flex: 0 0 auto;
  min-width: 0;
  max-width: 100%;
}

.stage-text-row em,
.stage-text-row strong {
  display: inline-block;
  min-width: 0;
  overflow: visible;
  text-overflow: clip;
}

.stage-text-row em {
  min-width: 22px;
}

/* Analysis tab IA implementation: overview / participation / certification. */
.analysis-tabs {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--spacing-4);
  padding: var(--spacing-4);
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
}

.analysis-tab {
  min-height: 34px;
  border: 0;
  border-radius: var(--cds-radius-sm);
  background: transparent;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.analysis-tab.is-active {
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-text-primary);
  box-shadow: var(--cds-shadow-card);
}

.analysis-tab:focus-visible,
.analysis-metric-card:focus-visible,
.analysis-overview-metric-row:focus-visible,
.analysis-topic-metric.is-interactive:focus-visible,
.participation-core-row:focus-visible,
.analysis-chart-link:focus-visible,
.analysis-handoff-link:focus-visible,
.precision-action:focus-visible {
  outline: 0;
  box-shadow: var(--cds-button-focus-ring);
}

.analysis-period-strip {
  min-height: 34px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-12);
  padding: 0 var(--spacing-4);
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.analysis-period-strip strong {
  color: var(--cds-color-text-secondary);
  font-weight: var(--cds-font-weight-semibold);
}

.analysis-metric-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--cds-color-brand-primary) 18%, var(--cds-color-border-default));
  border-radius: var(--cds-radius-card);
  background: color-mix(in srgb, var(--cds-color-brand-primary) 2%, var(--cds-color-surface-primary));
  box-shadow: var(--cds-shadow-card);
}

.analysis-metric-grid.is-empty {
  border-color: var(--cds-color-border-default);
  background: var(--cds-color-surface-primary);
}

.analysis-metric-grid.is-overview {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.analysis-metric-card {
  position: relative;
  min-width: 0;
  min-height: 88px;
  border: 0;
  border-right: 1px solid var(--app-simple-border);
  border-bottom: 1px solid var(--app-simple-border);
  border-radius: 0;
  background: transparent;
  padding: var(--spacing-12) var(--spacing-16);
  display: grid;
  align-content: start;
  gap: var(--spacing-4);
  text-align: left;
  box-shadow: none;
  cursor: pointer;
}

.analysis-metric-card:nth-child(2n) {
  border-right: 0;
}

.analysis-metric-card:nth-child(n + 3) {
  border-bottom: 0;
}

.analysis-metric-grid.is-overview .analysis-metric-card {
  min-height: 104px;
  border-right: 1px solid var(--app-simple-border);
  border-bottom: 0;
  padding: var(--spacing-12) var(--spacing-8);
}

.analysis-metric-grid.is-overview .analysis-metric-card:nth-child(2n) {
  border-right: 1px solid var(--app-simple-border);
}

.analysis-metric-grid.is-overview .analysis-metric-card:nth-child(3n) {
  border-right: 0;
}

.analysis-metric-card.has-signal {
  background: transparent;
}

.analysis-metric-card span,
.analysis-topic-metrics span,
.analysis-target-metrics em,
.metric-change-list span,
.precision-row-list span,
.precision-definition span,
.precision-card span,
.analysis-topic-head span,
.analysis-chart-head span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  font-style: normal;
}

.analysis-metric-card strong {
  margin-top: var(--spacing-4);
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.4px;
  white-space: nowrap;
}

.analysis-metric-card.has-signal strong,
.analysis-target-metrics b,
.metric-detail-value strong {
  color: var(--cds-color-brand-primary-dark);
}

.analysis-metric-card.has-negative-signal strong,
.metric-detail-hero.has-negative-signal .metric-detail-value strong {
  color: var(--cds-color-semantic-error);
}

.analysis-metric-card small,
.analysis-metric-card em,
.analysis-target-copy small {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  font-style: normal;
}

.analysis-metric-card em {
  color: var(--cds-color-text-tertiary);
}

.analysis-metric-card.is-compact-delta em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.analysis-metric-card b {
  position: absolute;
  top: var(--spacing-12);
  right: var(--spacing-12);
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-26);
}

.analysis-overview-metric-list {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--cds-color-brand-primary) 18%, var(--cds-color-border-default));
  border-radius: var(--cds-radius-card);
  background: color-mix(in srgb, var(--cds-color-brand-primary) 2%, var(--cds-color-surface-primary));
  box-shadow: var(--cds-shadow-card);
}

.analysis-overview-metric-list.is-empty {
  border-color: var(--cds-color-border-default);
  background: var(--cds-color-surface-primary);
}

.analysis-overview-metric-row {
  appearance: none;
  min-width: 0;
  min-height: 76px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 82px 18px;
  align-items: center;
  gap: var(--spacing-8);
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  color: inherit;
  font: inherit;
  padding: var(--spacing-10, 10px) var(--spacing-12);
  text-align: left;
  cursor: pointer;
}

.analysis-overview-metric-row:last-child {
  border-bottom: 0;
}

.analysis-overview-metric-row:active {
  background: var(--cds-color-surface-secondary);
}

.analysis-overview-metric-copy {
  min-width: 0;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  align-items: baseline;
  column-gap: var(--spacing-10, 10px);
  row-gap: var(--spacing-2, 2px);
}

.analysis-overview-metric-copy span {
  grid-column: 1 / -1;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.analysis-overview-metric-copy strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-30);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.45px;
  white-space: nowrap;
}

.analysis-overview-metric-row.has-signal .analysis-overview-metric-copy strong {
  color: var(--cds-color-brand-primary-dark);
}

.analysis-overview-metric-row.has-negative-signal .analysis-overview-metric-copy strong {
  color: var(--cds-color-semantic-error);
}

.analysis-overview-metric-copy em {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  font-style: normal;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.analysis-overview-metric-row > b {
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-26);
  text-align: right;
}

.analysis-overview-mini-trend {
  height: 38px;
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: end;
  gap: var(--spacing-3, 3px);
  padding: var(--spacing-4);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
}

.analysis-overview-mini-trend i {
  display: block;
  height: var(--bar-height);
  min-height: 5px;
  border-radius: var(--cds-radius-full) var(--cds-radius-full) var(--cds-radius-xs) var(--cds-radius-xs);
  background: color-mix(in srgb, var(--cds-color-brand-primary) 72%, var(--cds-color-surface-primary));
}

.analysis-overview-mini-trend.is-empty i {
  background: color-mix(in srgb, var(--cds-color-border-default) 74%, var(--cds-color-surface-primary));
}

.analysis-chart-card,
.analysis-topic-card,
.metric-change-card,
.metric-detail-hero,
.precision-card,
.precision-summary,
.precision-table-card,
.precision-definition {
  display: grid;
  gap: var(--spacing-12);
}

.analysis-chart-head,
.analysis-topic-head {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--spacing-12);
}

.analysis-chart-head strong,
.analysis-chart-link,
.analysis-topic-head strong,
.precision-card strong,
.precision-definition strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
  text-align: right;
}

.analysis-topic-head strong,
.precision-definition strong {
  text-align: left;
}

.analysis-chart-link {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--cds-color-brand-primary-dark);
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--spacing-4);
  cursor: pointer;
  padding: 0;
  white-space: nowrap;
}

.analysis-trend-chart {
  height: 96px;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  align-items: end;
  gap: var(--spacing-6);
  padding: var(--spacing-8);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
}

.analysis-trend-chart i {
  display: block;
  width: 100%;
  height: var(--bar-height);
  min-height: 4px;
  border-radius: var(--cds-radius-full) var(--cds-radius-full) var(--cds-radius-xs) var(--cds-radius-xs);
  background: linear-gradient(180deg, var(--cds-color-brand-primary), color-mix(in srgb, var(--cds-color-brand-primary) 52%, var(--cds-color-surface-primary)));
}

.analysis-chart-axis {
  display: flex;
  justify-content: space-between;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
}

.analysis-topic-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  overflow: hidden;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-raised);
}

.analysis-topic-metric {
  appearance: none;
  min-width: 0;
  display: grid;
  gap: 2px;
  border: 0;
  border-right: 1px solid var(--cds-color-border-default);
  background: transparent;
  color: inherit;
  font: inherit;
  padding: var(--spacing-8);
  text-align: left;
}

.analysis-topic-metric:last-child {
  border-right: 0;
}

.analysis-topic-metric.is-interactive {
  cursor: pointer;
}

.analysis-topic-metric.is-interactive:active {
  background: var(--cds-color-surface-primary);
}

.analysis-topic-metrics strong {
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.analysis-topic-metrics small {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.participation-core-section,
.participation-source-section,
.participation-support-section {
  display: grid;
  gap: var(--spacing-8);
}

.participation-core-list,
.participation-support-list {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: var(--cds-shadow-card);
}

.participation-support-list {
  box-shadow: none;
}

.participation-source-section {
  padding: var(--spacing-12);
  box-shadow: none;
}

.participation-source-heading {
  display: grid;
  gap: var(--spacing-2, 2px);
}

.participation-source-heading span {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
}

.participation-source-heading small,
.participation-source-empty {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.compact-card > p.participation-source-empty {
  display: block;
}

.participation-source-list {
  display: grid;
  gap: var(--spacing-10, 10px);
}

.participation-source-row {
  display: grid;
  gap: var(--spacing-6);
}

.participation-source-row-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-12);
}

.participation-source-row-head span {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.participation-source-row-head strong {
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-bold);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.participation-source-track {
  height: var(--spacing-6);
  overflow: hidden;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-surface-secondary);
}

.participation-source-track i {
  display: block;
  width: var(--bar-width);
  min-width: var(--spacing-4);
  height: 100%;
  border-radius: inherit;
  background: color-mix(in srgb, var(--cds-color-brand-primary) 68%, var(--cds-color-surface-primary));
}

.participation-core-row {
  appearance: none;
  min-width: 0;
  min-height: 76px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 76px auto;
  align-items: center;
  gap: var(--spacing-8);
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  color: inherit;
  font: inherit;
  padding: var(--spacing-10, 10px) var(--spacing-12);
  text-align: left;
  cursor: pointer;
}

.participation-core-row:last-child {
  border-bottom: 0;
}

.participation-core-row:active {
  background: var(--cds-color-surface-secondary);
}

.participation-core-row.has-signal .participation-core-copy strong {
  color: var(--cds-color-brand-primary-dark);
}

.participation-core-row.has-negative-signal .participation-core-copy strong {
  color: var(--cds-color-semantic-error);
}

.participation-core-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-2, 2px);
}

.participation-core-copy span,
.participation-support-row span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.participation-core-copy strong,
.participation-support-row strong {
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.participation-support-row strong {
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.participation-core-copy em,
.participation-core-row small,
.participation-support-row small {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  font-style: normal;
}

.participation-core-row small {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--spacing-4);
  color: var(--cds-color-brand-primary-dark);
  white-space: nowrap;
}

.participation-core-row small b {
  font-size: var(--cds-font-size-16);
  line-height: var(--cds-line-height-22);
}

.participation-mini-trend {
  height: 38px;
  min-width: 0;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: end;
  gap: var(--spacing-3, 3px);
  padding: var(--spacing-4);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
}

.participation-mini-trend i {
  display: block;
  height: var(--bar-height);
  min-height: 5px;
  border-radius: var(--cds-radius-full) var(--cds-radius-full) var(--cds-radius-xs) var(--cds-radius-xs);
  background: color-mix(in srgb, var(--cds-color-brand-primary) 72%, var(--cds-color-surface-primary));
}

.participation-mini-trend.is-empty i {
  background: color-mix(in srgb, var(--cds-color-border-default) 74%, var(--cds-color-surface-primary));
}

.certification-core-section {
  display: grid;
  gap: var(--spacing-8);
}

.certification-rate-card {
  display: grid;
  gap: var(--spacing-12);
  padding: var(--spacing-14, 14px) var(--spacing-16);
  box-shadow: none;
}

.certification-rate-card-head,
.certification-rate-card-value {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--spacing-12);
}

.certification-rate-card-head .metric-label-with-action {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  font-weight: var(--cds-font-weight-semibold);
}

.info-dot.is-inline {
  width: var(--spacing-24);
  height: var(--spacing-24);
  border-color: var(--cds-color-border-default);
  background: var(--cds-color-surface-raised);
}

.certification-rate-card-value {
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
}

.certification-rate-card-value strong {
  color: var(--cds-color-primary);
  font-family: var(--cds-font-family-numeric);
  font-size: var(--app-type-hero-size);
  line-height: var(--app-type-hero-line);
  font-variant-numeric: tabular-nums;
}

.certification-rate-card-value span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  white-space: nowrap;
}

.certification-analysis-card {
  display: grid;
  gap: var(--spacing-12);
  padding: var(--spacing-12);
  box-shadow: none;
}

.certification-rate-list,
.certification-time-list {
  display: grid;
  gap: var(--spacing-8);
}

.certification-time-heading {
  display: grid;
  gap: var(--spacing-2, 2px);
}

.certification-time-heading span {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
}

.certification-time-heading small,
.certification-empty-note {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.compact-card > p.certification-empty-note {
  display: block;
}

.certification-rate-row,
.certification-time-row {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 42px;
  align-items: center;
  gap: var(--spacing-8);
  min-height: 30px;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.certification-time-row {
  grid-template-columns: minmax(92px, 1fr) minmax(0, 1fr) 42px;
}

.certification-rate-row strong,
.certification-time-row strong {
  justify-self: end;
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-variant-numeric: tabular-nums;
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.certification-rate-track,
.certification-time-track {
  height: var(--spacing-8);
  overflow: hidden;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-surface-secondary);
}

.certification-rate-track i,
.certification-time-track i {
  display: block;
  width: var(--bar-width);
  min-width: var(--spacing-4);
  height: 100%;
  border-radius: inherit;
  background: var(--cds-color-primary);
}

.certification-analysis-card.is-empty .certification-rate-track i,
.certification-analysis-card.is-empty .certification-time-track i {
  background: var(--cds-color-border-strong);
}

.participation-support-row {
  min-height: 54px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  border-bottom: 1px solid var(--app-simple-border);
}

.participation-support-row:last-child {
  border-bottom: 0;
}

.participation-support-row div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-2, 2px);
}

.analysis-handoff-link {
  min-height: 38px;
  border: 0;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--spacing-4);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.analysis-priority-section {
  display: grid;
  gap: var(--spacing-8);
}

.analysis-target-list {
  display: grid;
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  overflow: hidden;
}

.analysis-target-list.is-full-list {
  margin-top: var(--spacing-4);
}

.analysis-target-row {
  min-height: 72px;
  display: grid;
  grid-template-columns: var(--spacing-44) minmax(0, 1fr) 20px;
  gap: var(--spacing-10, 10px);
  align-items: center;
  padding: var(--spacing-10, 10px) var(--spacing-12);
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.analysis-target-row:last-child {
  border-bottom: 0;
}

.analysis-target-row .challenge-thumb,
.challenge-row.is-operation-target .challenge-thumb,
.settlement-source-row .challenge-thumb {
  width: var(--spacing-44);
  height: var(--spacing-44);
}

.analysis-target-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.analysis-target-copy > strong {
  min-width: 0;
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.analysis-target-metrics {
  min-width: 0;
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-6);
}

.analysis-target-metrics span {
  min-width: 0;
  display: inline-flex;
  align-items: baseline;
  gap: var(--spacing-4);
  color: var(--cds-color-text-secondary);
}

.analysis-target-metrics b {
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.metric-detail-hero h2,
.precision-summary h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-hero-size);
  line-height: var(--app-type-hero-line);
  letter-spacing: -.3px;
}

.metric-detail-value {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: var(--spacing-12);
}

.metric-detail-value strong {
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: 28px;
  line-height: 34px;
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.6px;
  white-space: nowrap;
}

.metric-detail-value span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  text-align: right;
}

.metric-change-list,
.precision-row-list {
  display: grid;
  gap: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-sm);
  overflow: hidden;
}

.metric-change-list div,
.precision-row-list div {
  min-height: 42px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-8);
  padding: var(--spacing-8) var(--spacing-12);
  border-bottom: 1px solid var(--app-simple-border);
  background: var(--cds-color-surface-primary);
}

.metric-change-list div:last-child,
.precision-row-list div:last-child {
  border-bottom: 0;
}

.metric-change-list strong,
.precision-row-list strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  text-align: right;
}

.precision-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

.precision-card.is-disabled {
  opacity: .72;
}

.precision-action {
  min-height: 34px;
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-brand-primary-dark);
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  padding: 0 var(--spacing-12);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  cursor: pointer;
}

.precision-summary .status-rail {
  margin-top: 0;
}

.precision-definition {
  gap: var(--spacing-4);
}

.analysis-context-strip {
  margin-top: calc(var(--spacing-8) * -1);
}

.phone[data-tab="analysis"] .screen-scroll {
  gap: var(--spacing-16);
}

.challenge-analysis-hero .status-rail span {
  max-width: 100%;
}

.challenge-analysis-tabs {
  margin-top: var(--spacing-4);
}

.challenge-detail-metric-section {
  display: grid;
  gap: var(--spacing-8);
}

.challenge-detail-metric-row {
  min-height: 88px;
}

.challenge-metric-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.challenge-metric-card {
  min-height: 104px;
  cursor: default;
}

.challenge-metric-card strong {
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
}

.challenge-chart-card {
  overflow: hidden;
}

.challenge-insight-card {
  display: grid;
  gap: var(--spacing-12);
}

.challenge-insight-card.is-positive {
  border-color: color-mix(in srgb, var(--cds-color-brand-primary) 28%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-brand-primary) 5%, var(--cds-color-surface-primary));
}

.challenge-signal-list {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
}

.challenge-signal-row {
  min-height: 42px;
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr);
  align-items: center;
  gap: var(--spacing-8);
  padding: var(--spacing-8) var(--spacing-12);
  border-bottom: 1px solid var(--app-simple-border);
}

.challenge-signal-row:last-child {
  border-bottom: 0;
}

.challenge-signal-row span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.challenge-signal-row strong {
  min-width: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
  overflow-wrap: anywhere;
  word-break: keep-all;
}

.challenge-insight-card .analysis-handoff-link {
  margin-top: var(--spacing-4);
}

.challenge-funnel-card {
  gap: var(--spacing-12);
}

@media (max-width: 360px) {
  .analysis-metric-card {
    min-height: 84px;
    padding: var(--spacing-8) var(--spacing-12);
  }

  .analysis-metric-card strong {
    font-size: var(--cds-font-size-18);
    line-height: var(--cds-line-height-26);
  }

  .analysis-topic-metric {
    padding: var(--spacing-8) var(--spacing-6);
  }

  .analysis-overview-metric-row {
    grid-template-columns: minmax(0, 1fr) 68px 16px;
    gap: var(--spacing-8);
    min-height: 82px;
    padding: var(--spacing-10, 10px) var(--spacing-12);
  }

  .analysis-overview-metric-copy strong {
    font-size: var(--cds-font-size-20);
    line-height: var(--cds-line-height-28);
  }

  .analysis-overview-mini-trend {
    height: 38px;
  }

  .participation-core-row {
    grid-template-columns: minmax(0, 1fr) 64px 18px;
    gap: var(--spacing-8);
    padding: var(--spacing-10, 10px) var(--spacing-12);
  }

  .participation-core-row small {
    font-size: 0;
    gap: 0;
  }

  .participation-core-row small b {
    font-size: var(--cds-font-size-16);
    line-height: var(--cds-line-height-22);
  }

  .participation-mini-trend {
    height: 38px;
  }

  .analysis-target-row {
    min-height: 80px;
    padding: var(--spacing-10, 10px) var(--spacing-12);
  }
}

/* 2026-06-03 row/list grammar pass: keep repeated objects as rows, reserve card weight for summaries. */
.recent-challenge-item:hover,
.analysis-target-row:hover,
.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target:hover,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card.operation-tool-entry:hover,
.phone[data-tab="settlement"][data-route="main"] .simple-list .list-line:hover,
.detail-action-list .detail-action-row:hover,
.bottom-sheet .settlement-confirm-list .sheet-line:hover,
.bottom-sheet .settlement-confirm-list .list-line:hover {
  box-shadow: none;
  background: color-mix(in srgb, var(--cds-color-surface-raised) 54%, var(--cds-color-surface-primary));
}

.recent-challenge-item .row-affordance,
.analysis-target-row .row-affordance,
.phone[data-tab="operation"][data-route="main"] .operation-target-list .row-affordance,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .row-affordance,
.detail-action-list .row-affordance {
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-tertiary);
}

.detail-action-list .row-affordance span:first-child,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .row-affordance span:first-child {
  color: var(--cds-color-text-secondary);
}

.analysis-target-list,
.phone[data-tab="operation"][data-route="main"] .operation-target-list,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list,
.phone[data-tab="settlement"][data-route="main"] .simple-list,
.detail-action-list {
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.analysis-target-row,
.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card.operation-tool-entry,
.phone[data-tab="settlement"][data-route="main"] .simple-list .settlement-source-row,
.phone[data-tab="settlement"][data-route="main"] .simple-list .list-line,
.detail-action-list .detail-action-row {
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.analysis-target-row:last-child,
.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target:last-child,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .tool-card.operation-tool-entry:last-child,
.phone[data-tab="settlement"][data-route="main"] .simple-list .settlement-source-row:last-child,
.phone[data-tab="settlement"][data-route="main"] .simple-list .list-line:last-child,
.detail-action-list .detail-action-row:last-child {
  border-bottom: 0;
}

.detail-action-list .detail-action-row {
  min-height: var(--spacing-64);
  padding: var(--spacing-10, 10px) var(--spacing-12);
}

.detail-action-list .detail-action-row.is-focus-row {
  border-bottom-color: color-mix(in srgb, var(--cds-color-primary) 18%, var(--app-simple-border));
  background: color-mix(in srgb, var(--cds-color-primary-background) 42%, var(--cds-color-surface-primary));
}

.phone[data-tab="settlement"][data-route="main"] .simple-list .list-line {
  min-height: var(--spacing-56);
  padding: var(--spacing-10, 10px) var(--spacing-12);
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target {
  min-height: var(--spacing-64);
  grid-template-columns: var(--spacing-44) minmax(0, 1fr) auto;
  gap: var(--spacing-12);
  padding: var(--spacing-10, 10px) var(--spacing-12);
}

.phone[data-tab="operation"][data-route="main"] .operation-target-list .challenge-row.is-operation-target .challenge-thumb {
  width: var(--spacing-40, 40px);
  height: var(--spacing-40, 40px);
}

.operation-challenge-list {
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.operation-challenge-list .challenge-row.is-operation-target,
.operation-challenge-list .operation-challenge-more {
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.operation-challenge-list .challenge-row.is-operation-target:last-child,
.operation-challenge-list .operation-challenge-more:last-child {
  border-bottom: 0;
}

.operation-challenge-list .challenge-row.is-operation-target {
  min-height: var(--spacing-64);
  grid-template-columns: var(--spacing-44) minmax(0, 1fr) var(--spacing-20);
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-10, 10px) var(--spacing-12);
}

.operation-challenge-list .challenge-row.is-operation-target .challenge-thumb {
  width: var(--spacing-40, 40px);
  height: var(--spacing-40, 40px);
}

.operation-challenge-list .challenge-row.is-operation-target .row-body {
  min-width: 0;
  gap: var(--spacing-4);
}

.operation-challenge-list .challenge-row.is-operation-target .row-affordance.is-chevron-only,
.phone[data-tab="operation"][data-route="main"] .operation-root-tool-list .row-affordance.is-chevron-only {
  justify-self: end;
  width: var(--spacing-20);
  justify-content: center;
  padding: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-28);
}

.operation-challenge-list .operation-challenge-more {
  min-height: var(--spacing-44);
  padding: 0 var(--spacing-12);
  border-style: solid;
  color: var(--cds-color-text-secondary);
}

.settlement-source-row {
  min-width: 0;
  min-height: var(--spacing-64);
  display: grid;
  grid-template-columns: var(--spacing-44) minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-10, 10px) var(--spacing-12);
}

.settlement-source-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-2, 2px);
}

.settlement-source-copy strong {
  min-width: 0;
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settlement-source-copy span {
  min-width: 0;
  overflow: hidden;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settlement-source-row b {
  justify-self: end;
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.settlement-section-more {
  min-height: var(--spacing-44);
  border-style: solid;
  border-color: transparent;
  background: transparent;
  color: var(--cds-color-text-secondary);
  box-shadow: none;
}

.settlement-section-more:hover {
  border-color: var(--cds-color-border-default);
  background: var(--cds-color-surface-raised);
  box-shadow: none;
}

.is-detail-list {
  margin-top: var(--spacing-12);
}

.bottom-sheet .settlement-confirm-list {
  box-shadow: none;
}

/* 2026-06-03 settlement hierarchy pass: receivable amount first, CP details as calculation evidence. */
.phone[data-tab="settlement"][data-route="main"] .settlement-hero {
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-12);
  padding: var(--spacing-16);
}

.phone[data-tab="settlement"][data-route="main"] .settlement-hero > div {
  padding: 0;
  border-radius: 0;
  background: transparent;
}

.settlement-hero-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.settlement-hero-copy span {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.settlement-hero-copy strong {
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--cds-font-size-28);
  line-height: var(--cds-line-height-36);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.6px;
  white-space: nowrap;
}

.settlement-hero-basis {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.settlement-hero > .settlement-status-copy {
  min-width: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-4);
  padding-top: var(--spacing-12) !important;
  border-top: 1px solid color-mix(in srgb, var(--cds-color-primary) 18%, var(--app-simple-border));
}

.settlement-status-copy strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size) !important;
  line-height: var(--app-type-row-line) !important;
  font-family: var(--cds-font-family-base);
  font-feature-settings: normal;
  font-variant-numeric: normal;
  font-weight: var(--cds-font-weight-semibold);
  letter-spacing: -.2px;
  white-space: normal;
}

.settlement-status-copy span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.phone[data-tab="settlement"][data-route="main"] .settlement-hero .status-rail {
  margin: 0;
}

.phone[data-tab="settlement"][data-route="main"] .settlement-hero .cta-primary {
  min-height: 48px;
  line-height: 48px;
  font-size: var(--cds-font-size-15);
}

.settlement-calculation-row {
  min-height: 58px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-12) var(--spacing-16);
  border: 1px solid var(--cds-color-border-default);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-raised);
  text-align: left;
}

.settlement-calculation-row > div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-4);
}

.settlement-calculation-row strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.settlement-calculation-row span {
  min-width: 0;
  overflow: hidden;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.settlement-calculation-row b {
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
}

.settlement-trust-section {
  display: grid;
  gap: 0;
}

.settlement-trust-list {
  display: grid;
  gap: 0;
  overflow: hidden;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
}

.settlement-trust-row {
  appearance: none;
  min-width: 0;
  min-height: 58px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  border: 0;
  border-bottom: 1px solid var(--app-simple-border);
  background: transparent;
  color: inherit;
  font: inherit;
  padding: var(--spacing-12) var(--spacing-16);
  text-align: left;
}

.settlement-trust-row:last-child {
  border-bottom: 0;
}

.settlement-trust-row > div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-2, 2px);
}

.settlement-trust-row strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.settlement-trust-row span,
.settlement-trust-row small {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
  word-break: keep-all;
}

.settlement-trust-row small {
  color: var(--cds-color-text-tertiary);
}

.settlement-trust-row b {
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-28);
}

.settlement-basis-card {
  padding: 0;
  overflow: hidden;
}

.settlement-flow-list {
  display: grid;
  gap: 0;
}

.settlement-flow-row {
  min-width: 0;
  min-height: 56px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-12);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  border-bottom: 1px solid var(--app-simple-border);
}

.settlement-flow-row > div {
  min-width: 0;
  display: grid;
  gap: var(--spacing-2, 2px);
}

.settlement-flow-row small {
  min-width: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
}

.settlement-flow-row strong {
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-variant-numeric: var(--cds-font-variant-numeric);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.settlement-flow-row.is-minus strong,
.settlement-source-list .list-line.is-exclusion b,
.bottom-sheet .settlement-confirm-list .list-line.is-exclusion b {
  color: var(--cds-color-text-secondary);
}

.settlement-flow-row.is-result {
  background: color-mix(in srgb, var(--cds-color-primary-background) 34%, var(--cds-color-surface-primary));
}

.settlement-flow-row.is-result strong,
.settlement-flow-row.is-won strong {
  color: var(--cds-color-brand-primary-dark);
}

.settlement-flow-row.is-won {
  border-bottom-color: color-mix(in srgb, var(--cds-color-primary) 20%, var(--app-simple-border));
  background: color-mix(in srgb, var(--cds-color-primary-background) 52%, var(--cds-color-surface-primary));
}

.settlement-flow-row.is-support {
  min-height: 50px;
  background: var(--cds-color-surface-primary);
}

.settlement-flow-row.is-support strong {
  color: var(--cds-color-text-secondary);
}

.settlement-flow-row .metric-label-with-action {
  min-width: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.settlement-flow-row .info-dot {
  width: 22px;
  height: 22px;
  font-size: var(--cds-font-size-11);
}

.settlement-info-row {
  appearance: none;
  min-width: 0;
  width: 100%;
  min-height: 50px;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--spacing-10, 10px);
  border: 0;
  background: var(--cds-color-surface-secondary);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  text-align: left;
  cursor: pointer;
}

.settlement-info-row span,
.settlement-info-row strong {
  min-width: 0;
  grid-column: 1;
}

.settlement-info-row span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.settlement-info-row strong {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
}

.settlement-info-row b {
  grid-column: 2;
  grid-row: 1 / span 2;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-26);
}

.settlement-source-list .list-line b,
.settlement-history-list .list-line b {
  white-space: nowrap;
}

.settlement-history-list .list-line b {
  color: var(--cds-color-text-secondary);
}

.settlement-source-list .list-line.is-exclusion,
.bottom-sheet .settlement-confirm-list .list-line.is-exclusion {
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 56%, var(--cds-color-surface-primary));
}

@media (max-width: 360px) {
  .settlement-hero-copy strong {
    font-size: var(--cds-font-size-24);
    line-height: var(--cds-line-height-32);
  }

  .settlement-flow-row {
    grid-template-columns: minmax(0, 1fr);
    align-items: start;
    gap: var(--spacing-4);
  }

  .settlement-flow-row strong {
    justify-self: start;
  }
}

/* Operation detail hub: selected challenge identity, home-level metric summary, relation signals. */
.challenge-operation-identity {
  min-width: 0;
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr);
  align-items: center;
  gap: var(--spacing-12);
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  padding: var(--spacing-14, 14px);
  box-shadow: none;
}

.challenge-operation-identity .challenge-thumb {
  width: 52px;
  height: 52px;
}

.challenge-operation-identity-copy {
  min-width: 0;
  display: grid;
  gap: var(--spacing-5, 5px);
}

.challenge-operation-identity-copy h2 {
  min-width: 0;
  margin: 0;
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-section-title-size);
  line-height: var(--app-type-section-title-line);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.2px;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.challenge-operation-identity-copy .status-rail {
  gap: var(--spacing-5, 5px);
}

.challenge-operation-identity-copy .status-rail span {
  min-height: 22px;
  padding: 0 var(--spacing-8);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.operation-stage-summary {
  min-width: 0;
  display: grid;
  gap: var(--spacing-6);
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-secondary);
  padding: var(--spacing-12);
  box-shadow: none;
}

.operation-stage-summary .stage-text-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  color: var(--cds-color-text-secondary);
}

.operation-stage-summary .stage-text-row span {
  min-width: 0;
  display: grid;
  gap: 1px;
  padding: 0 var(--spacing-10, 10px);
  border-left: 1px solid var(--app-simple-border);
}

.operation-stage-summary .stage-text-row span:first-child {
  padding-left: 0;
  border-left: 0;
}

.operation-stage-summary .stage-text-row.is-interactive {
  overflow: hidden;
  border-radius: var(--cds-radius-sm);
}

.operation-stage-summary .operation-stage-metric {
  min-width: 0;
  display: grid;
  gap: 1px;
  padding: var(--spacing-6) var(--spacing-10, 10px);
  border: 0;
  border-left: 1px solid var(--app-simple-border);
  background: transparent;
  color: inherit;
  text-align: left;
  cursor: pointer;
  appearance: none;
}

.operation-stage-summary .operation-stage-metric:first-child {
  padding-left: var(--spacing-4);
  border-left: 0;
}

.operation-stage-summary .operation-stage-metric:hover,
.operation-stage-summary .operation-stage-metric:active {
  background: color-mix(in srgb, var(--cds-color-surface-primary) 72%, transparent);
}

.operation-stage-summary .operation-stage-metric:focus-visible {
  outline: 2px solid color-mix(in srgb, var(--cds-color-primary) 48%, transparent);
  outline-offset: -2px;
  background: color-mix(in srgb, var(--cds-color-surface-primary) 78%, transparent);
}

.operation-stage-summary .stage-text-row strong {
  overflow: hidden;
  color: var(--cds-color-text-primary);
  text-overflow: ellipsis;
}

.detail-action-row .row-affordance.is-chevron-only {
  justify-self: end;
  width: var(--spacing-20);
  max-width: var(--spacing-20);
  justify-content: center;
  padding: 0;
  color: var(--cds-color-text-tertiary);
  font-size: var(--cds-font-size-18);
}

.operation-reaction-signal-list {
  display: grid;
  gap: 0;
  overflow: hidden;
  margin: 0;
  padding: 0;
  border: 1px solid var(--app-simple-border);
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  list-style: none;
  box-shadow: none;
}

.operation-reaction-signal-list li {
  min-width: 0;
  min-height: 54px;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  align-items: center;
  gap: var(--spacing-8);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  border-bottom: 1px solid var(--app-simple-border);
}

.operation-reaction-signal-list li:last-child {
  border-bottom: 0;
}

.operation-reaction-signal-list li > span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-primary-background);
  color: var(--cds-color-brand-primary-dark);
  font-weight: var(--cds-font-weight-bold);
}

.operation-reaction-signal-list div {
  min-width: 0;
  display: grid;
  gap: 2px;
}

.operation-reaction-signal-list strong,
.operation-reaction-signal-list small {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.operation-reaction-signal-list strong {
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
}

.operation-reaction-signal-list small {
  color: var(--cds-color-text-tertiary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.operation-reaction-signal-list li.is-empty strong {
  color: var(--cds-color-text-secondary);
}

/* 2026-06-04 entrypoint purpose-fit pass: each representative root answers its user-story question first. */
.purpose-step-row,
.home-health-signal-grid {
  display: flex;
  flex-wrap: wrap;
  gap: var(--spacing-6);
  margin-top: var(--spacing-4);
}

.purpose-step-row span,
.home-health-signal {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  border-radius: var(--cds-radius-sm);
  border: 1px solid color-mix(in srgb, var(--cds-color-primary) 14%, var(--cds-color-border-default));
  background: color-mix(in srgb, var(--cds-color-primary-background) 62%, var(--cds-color-surface-primary));
  padding: 0 var(--spacing-8);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  white-space: nowrap;
}

.home-health-signal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.home-health-signal {
  justify-content: space-between;
  min-width: 0;
  border-radius: var(--cds-radius-card);
}

.home-health-signal em {
  color: var(--cds-color-text-tertiary);
  font-style: normal;
}

.home-health-signal strong {
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-feature-settings: var(--cds-font-feature-numeric);
  font-size: var(--cds-font-size-14);
  line-height: var(--cds-line-height-20);
  white-space: nowrap;
}

.home-revenue-core-card.is-admin-value,
.home-revenue-core-card.home-health-core-card {
  grid-template-columns: minmax(0, 1fr);
}

.home-revenue-core-card.is-admin-value .row-affordance,
.home-revenue-core-card.home-health-core-card .row-affordance {
  grid-column: 1;
  justify-self: end;
}

.analysis-diagnosis-card {
  display: grid;
  gap: var(--spacing-12);
  border-color: color-mix(in srgb, var(--cds-color-semantic-warning) 18%, var(--cds-color-border-default));
}

.analysis-diagnosis-card.is-positive {
  border-color: color-mix(in srgb, var(--cds-color-primary) 24%, var(--cds-color-border-default));
}

.analysis-diagnosis-card.is-neutral {
  border-color: var(--cds-color-border-default);
}

.diagnostic-summary {
  display: grid;
  gap: var(--spacing-6);
}

.diagnostic-summary h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-section-size);
  line-height: var(--app-type-section-line);
  letter-spacing: -.3px;
  word-break: keep-all;
}

.diagnostic-summary p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  word-break: keep-all;
}

.analysis-diagnosis-card .funnel-chart {
  gap: var(--spacing-8);
}

.analysis-diagnosis-card .cta-secondary {
  justify-self: stretch;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card {
  gap: var(--spacing-10, 10px);
  padding: var(--spacing-12);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card .diagnostic-summary {
  gap: var(--spacing-4);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card .diagnostic-summary h2 {
  font-size: var(--cds-font-size-16);
  line-height: var(--cds-line-height-22);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card .funnel-chart {
  gap: var(--spacing-6);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card .funnel-stage {
  min-height: 44px;
  padding: var(--spacing-6) var(--spacing-8);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card .funnel-track {
  height: var(--spacing-4);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-diagnosis-card .cta-secondary {
  min-height: var(--spacing-44);
}

.phone[data-tab="analysis"][data-route="main"] .analysis-action-handoff .detail-action-list {
  gap: 0;
}

.phone[data-tab="analysis"][data-route="main"] .analysis-action-handoff .detail-action-row {
  min-height: 58px;
  padding: var(--spacing-8) var(--spacing-12);
}

.analysis-action-handoff,
.operation-growth-section {
  display: grid;
  gap: var(--spacing-12);
}

.operation-action-choice-list .detail-action-row:first-child {
  border-color: color-mix(in srgb, var(--cds-color-primary) 26%, var(--cds-color-border-default));
  background:
    radial-gradient(circle at 94% 0%, color-mix(in srgb, var(--cds-color-primary-background) 82%, transparent) 0 32%, transparent 56%),
    var(--app-polish-surface);
}

.operation-action-choice-list .detail-action-row h3,
.analysis-action-handoff .detail-action-row h3 {
  letter-spacing: -.2px;
}

/* 2026-06-04 Figma visual reference pass.
   Keep the user-story structure, but adopt the lighter Challify app grammar:
   white sections, thin separators, full-width green CTA, metric strip, media row, 64px object rows. */
:root {
  --app-figma-separator: color-mix(in srgb, var(--cds-color-border-default) 78%, var(--cds-color-primary-background));
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .screen-scroll,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .screen-scroll,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .screen-scroll {
  gap: 0;
  padding: 0 0 calc(var(--app-bottom-tabs-height) + var(--spacing-32));
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero,
.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-block,
.phone.is-admin-root[data-route="main"][data-tab="home"] .reaction-card.is-home-reaction-summary,
.phone.is-admin-root[data-route="main"][data-tab="home"] .reaction-empty-section.is-home-reaction-summary,
.phone.is-admin-root[data-route="main"][data-tab="home"] .recent-published-section,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .screen-scroll > section,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-calculation-row,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .screen-scroll > section {
  border-top: var(--spacing-8) solid var(--app-figma-separator);
}

.home-action-hero {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-16);
  padding: var(--spacing-16);
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: var(--cds-radius-none);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
  text-align: center;
}

.home-hero-dismiss {
  position: absolute;
  top: var(--spacing-12);
  right: var(--spacing-12);
  z-index: 1;
  width: var(--spacing-32);
  height: var(--spacing-32);
  border: 0;
  border-radius: var(--cds-radius-full);
  background: transparent;
  color: var(--cds-color-text-tertiary);
  display: grid;
  place-items: center;
  padding: 0;
  cursor: pointer;
}

.home-hero-dismiss span {
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-18);
  font-weight: var(--cds-font-weight-semibold);
}

.home-hero-dismiss:focus-visible {
  outline: 0;
  box-shadow: var(--cds-button-focus-ring);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero.home-revenue-core-card,
.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero.home-revenue-core-card.home-revenue-metric-card,
.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero.home-revenue-core-card.is-admin-value,
.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero.home-revenue-core-card.home-health-core-card {
  min-height: 0;
  grid-template-columns: minmax(0, 1fr);
  align-items: stretch;
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: var(--cds-radius-none);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.home-action-copy {
  display: grid;
  justify-items: center;
  gap: var(--spacing-8);
}

.home-action-hero h2 {
  max-width: 100%;
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-32);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.45px;
  word-break: keep-all;
}

.home-action-hero p {
  margin: 0;
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  word-break: keep-all;
}

.home-action-hero .purpose-step-row,
.home-action-hero .home-health-signal-grid {
  display: none;
}

.home-action-hero.is-revenue-affordance .purpose-step-row {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: var(--spacing-6);
}

.home-action-hero.is-revenue-affordance .purpose-step-row span {
  min-height: var(--spacing-28);
  padding: 0 var(--spacing-10, 10px);
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-secondary);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.home-action-hero .home-revenue-value {
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-32);
  font-feature-settings: var(--cds-font-feature-numeric);
}

.home-action-hero .cta-primary,
.reaction-card.is-simple-reaction .cta-primary,
.settlement-hero .cta-primary {
  width: 100%;
  grid-column: 1;
  justify-self: stretch;
  min-height: var(--spacing-56);
  border-radius: var(--cds-radius-full);
  font-size: var(--cds-font-size-17);
  line-height: var(--cds-line-height-22);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.35px;
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-block {
  margin: 0;
  padding: 0;
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-period {
  display: flex;
  width: 100%;
  justify-content: space-between;
  align-items: center;
  padding: var(--spacing-16) var(--spacing-16) var(--spacing-4);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-period i {
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-20);
  line-height: var(--cds-line-height-24);
  font-style: normal;
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-panel {
  margin: 0;
  padding: var(--spacing-12) var(--spacing-16) var(--spacing-14, 14px);
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--spacing-16);
  overflow: visible;
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell {
  min-width: 0;
  min-height: 0;
  padding: 0;
  border: 0;
  border-right: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  box-shadow: none;
  text-align: left;
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell em {
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-14);
  line-height: var(--cds-line-height-20);
  font-weight: var(--cds-font-weight-medium);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell strong {
  margin-top: var(--spacing-4);
  color: var(--cds-color-text-primary);
  font-family: var(--cds-font-family-numeric);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  font-feature-settings: var(--cds-font-feature-numeric);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .free-zero-metric-note {
  margin-top: var(--spacing-8);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.reaction-card.is-simple-reaction {
  display: grid;
  gap: var(--spacing-16);
  margin: 0;
  padding: var(--spacing-16);
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: var(--cds-radius-none);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.reaction-card.is-simple-reaction h2 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-28);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.25px;
}

.reaction-card.is-simple-reaction .helper-text {
  margin-top: var(--spacing-6);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  word-break: keep-all;
}

.reaction-card.is-home-reaction-summary .home-reaction-head {
  position: relative;
  display: block;
}

.reaction-card.is-home-reaction-summary .home-reaction-copy {
  min-width: 0;
}

.home-reaction-new-badge {
  position: absolute;
  top: 0;
  right: 0;
  display: inline-flex;
  min-height: var(--spacing-24);
  flex: 0 0 auto;
  align-items: center;
  padding: 0 var(--spacing-8);
  border: 1px solid color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-border-default));
  border-radius: var(--cds-radius-full);
  background: color-mix(in srgb, var(--cds-color-primary-background) 72%, var(--cds-color-surface-primary));
  color: var(--cds-color-brand-primary-dark);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.cert-preview-strip {
  display: flex;
  gap: var(--spacing-4);
  overflow-x: auto;
  padding-bottom: var(--spacing-4);
  scrollbar-width: none;
  overscroll-behavior-x: contain;
}

.cert-preview-strip::-webkit-scrollbar {
  display: none;
}

.cert-preview-thumb {
  position: relative;
  width: 110px;
  height: 112px;
  flex: 0 0 110px;
  overflow: hidden;
  border-radius: var(--cds-radius-xs);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary-background) 72%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-text-primary) 18%, var(--cds-color-surface-secondary)));
}

.cert-preview-thumb.is-blue {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-semantic-info) 28%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-text-primary) 20%, var(--cds-color-surface-secondary)));
}

.cert-preview-thumb.is-orange {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-semantic-warning) 28%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-text-primary) 18%, var(--cds-color-surface-secondary)));
}

.cert-preview-thumb.is-purple {
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-semantic-info) 22%, var(--cds-color-surface-secondary)));
}

.cert-preview-thumb em {
  position: absolute;
  top: var(--spacing-6);
  right: var(--spacing-6);
  max-width: calc(100% - var(--spacing-8));
  overflow: hidden;
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-text-primary) 56%, transparent);
  padding: var(--spacing-3, 3px) var(--spacing-6);
  color: var(--cds-color-neutral-white);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-weight: var(--cds-font-weight-medium);
  font-style: normal;
  text-overflow: ellipsis;
  white-space: nowrap;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

.cert-preview-thumb b {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: color-mix(in srgb, var(--cds-color-neutral-white) 92%, transparent);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-32);
}

.reaction-empty-section.is-home-reaction-summary {
  margin: 0;
  padding: var(--spacing-16);
  background: var(--cds-color-surface-primary);
}

.reaction-empty-section.is-home-reaction-summary .reaction-empty-card {
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  padding: 0;
  box-shadow: none;
}

.recent-published-section {
  margin: 0;
  padding-bottom: var(--spacing-16);
  background: var(--cds-color-surface-primary);
}

.recent-published-section .section-header {
  margin: 0;
  padding: var(--spacing-16) var(--spacing-16) var(--spacing-8);
}

.recent-published-section .section-header h2 {
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-28);
}

.recent-published-section .recent-challenge-card {
  margin: 0;
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  box-shadow: none;
}

.recent-published-section .recent-challenge-item {
  min-height: 96px;
  padding: 0 var(--spacing-16);
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  box-shadow: none;
}

.recent-published-section .recent-challenge-content {
  min-height: 96px;
  display: grid;
  grid-template-columns: 64px minmax(0, 1fr) 32px;
  align-items: center;
  gap: var(--spacing-12);
  padding: 0;
}

.recent-published-section .challenge-thumb,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-thumb {
  width: var(--spacing-64);
  height: var(--spacing-64);
  border-radius: var(--cds-radius-sm);
}

.recent-published-section .recent-challenge-copy {
  min-width: 0;
  gap: var(--spacing-4);
}

.recent-published-section .recent-challenge-copy strong {
  overflow: hidden;
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-16);
  line-height: var(--cds-line-height-22);
  font-weight: var(--cds-font-weight-bold);
  text-overflow: ellipsis;
  white-space: nowrap;
}

.recent-published-section .row-meta,
.recent-published-section .recent-inline-metrics {
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
}

.recent-published-section .row-affordance.is-chevron-only,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .row-affordance.is-chevron-only {
  color: var(--cds-color-text-secondary);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .screen-scroll > section {
  margin: 0;
  padding: var(--spacing-16);
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .section-header {
  margin: 0 0 var(--spacing-16);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-growth-section .detail-action-list,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list {
  overflow: hidden;
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-action-choice-list .detail-action-row,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-row.is-operation-target {
  min-height: 72px;
  border: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  padding: var(--spacing-10, 10px) 0;
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-action-choice-list .detail-action-row + .detail-action-row,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-row.is-operation-target + .challenge-row.is-operation-target {
  border-top: 1px solid var(--cds-color-border-default);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-action-choice-list .detail-action-row:first-child {
  background: transparent;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero {
  display: grid;
  gap: var(--spacing-16);
  margin: 0;
  padding: var(--spacing-16);
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: var(--cds-radius-none);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero-copy {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: var(--spacing-8);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero-copy span {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-body-size);
  line-height: var(--app-type-body-line);
  font-weight: var(--cds-font-weight-semibold);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero-copy strong {
  color: var(--cds-color-brand-primary-dark);
  font-family: var(--cds-font-family-numeric);
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-32);
  font-weight: var(--cds-font-weight-bold);
  font-feature-settings: var(--cds-font-feature-numeric);
  white-space: nowrap;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero-basis {
  grid-column: 1 / -1;
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-16);
  line-height: var(--cds-line-height-22);
  font-weight: var(--cds-font-weight-semibold);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-status-copy {
  padding-top: var(--spacing-16);
  border-top: 1px solid color-mix(in srgb, var(--cds-color-primary) 24%, var(--cds-color-border-default));
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-calculation-row,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .screen-scroll > section {
  margin: 0;
  border-right: 0;
  border-bottom: 0;
  border-left: 0;
  border-radius: var(--cds-radius-none);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-calculation-row {
  padding: var(--spacing-16);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .screen-scroll > section {
  padding: var(--spacing-16);
}

/* 2026-06-04 Figma first-page alignment for Analysis / Operation / Revenue.
   These selectors intentionally sit after the previous root-tab passes so the
   Figma frames become the visual reference for the first pages the user called out. */
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .screen-scroll {
  gap: var(--spacing-16);
  padding: var(--spacing-16) var(--grid-mobile-margin) calc(var(--app-bottom-tabs-height) + var(--spacing-32));
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-overview-metric-list,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-target-list,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .participation-core-list,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .participation-support-list,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .certification-rate-card,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .certification-analysis-card {
  border-color: var(--cds-color-border-default);
  background: var(--cds-color-surface-primary);
  box-shadow: var(--cds-shadow-card);
}

.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-overview-metric-list.has-signal,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-overview-metric-list.is-empty {
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-target-row .row-affordance,
.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-overview-metric-row > b {
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-tertiary);
}

.phone.is-admin-root[data-route="main"][data-tab="analysis"] .analysis-priority-section .section-header {
  margin: 0;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .screen-scroll {
  gap: var(--spacing-14, 14px);
  padding: var(--spacing-14, 14px) var(--grid-mobile-margin) calc(var(--app-bottom-tabs-height) + var(--spacing-32));
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .screen-scroll > section {
  margin: 0;
  padding: 0;
  border-top: 0;
  background: transparent;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-empty-section.is-operation-summary .reaction-empty-card {
  min-height: 96px;
  border: 0;
  border-radius: var(--cds-radius-lg);
  background: var(--cds-color-surface-primary);
  box-shadow: var(--cds-shadow-card);
  padding: var(--spacing-16) var(--spacing-20);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary {
  margin: 0;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-my-challenges-section,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-settings-section {
  display: grid;
  gap: var(--spacing-8);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-my-challenges-section .section-header,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-settings-section .section-header {
  margin: 0;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-root-setting-list {
  overflow: hidden;
  border: 0;
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-row.is-operation-target {
  min-height: 70px;
  grid-template-columns: var(--spacing-40, 40px) minmax(0, 1fr) var(--spacing-20);
  padding: var(--spacing-10, 10px) var(--spacing-12);
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-row.is-operation-target .challenge-thumb {
  width: var(--spacing-40, 40px);
  height: var(--spacing-40, 40px);
  border-radius: var(--cds-radius-sm);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-row.is-operation-target .row-affordance,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-setting-row .row-affordance {
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-tertiary);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .challenge-row.is-operation-target + .challenge-row.is-operation-target,
.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-setting-row + .operation-setting-row {
  border-top: 1px solid var(--cds-color-border-default);
}

.operation-setting-row {
  min-width: 0;
  min-height: 52px;
  display: grid;
  grid-template-columns: var(--spacing-24) minmax(0, 1fr) var(--spacing-20);
  align-items: center;
  gap: var(--spacing-8);
  border: 0;
  background: transparent;
  padding: var(--spacing-8) var(--spacing-10, 10px);
  color: inherit;
}

.operation-setting-row .tool-icon {
  width: var(--spacing-24);
  height: var(--spacing-24);
  border-radius: var(--cds-radius-sm);
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-11);
}

.operation-setting-row h3,
.operation-setting-row .tool-preview {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.operation-setting-row h3 {
  margin: 0;
  color: var(--cds-color-text-primary);
  font-size: var(--app-type-row-size);
  line-height: var(--app-type-row-line);
  font-weight: var(--cds-font-weight-semibold);
}

.operation-setting-row .tool-preview {
  display: block;
  margin-top: var(--spacing-2, 2px);
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-medium);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary {
  gap: var(--spacing-10, 10px);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary h2 {
  font-size: var(--cds-font-size-17);
  line-height: var(--cds-line-height-26);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary .helper-text {
  margin-top: var(--spacing-4);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary .cert-preview-strip {
  gap: var(--spacing-4);
  padding-bottom: 0;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary .cert-preview-thumb {
  width: 104px;
  height: 88px;
  flex-basis: 104px;
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary .cert-preview-thumb b {
  font-size: var(--cds-font-size-18);
  line-height: var(--cds-line-height-28);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .reaction-card.is-operation-summary .cta-primary {
  min-height: var(--spacing-44);
  line-height: var(--spacing-44);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .recent-inline-metrics {
  color: var(--cds-color-text-secondary);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .recent-inline-metrics strong.is-signal-value {
  color: var(--cds-color-text-primary);
  font-weight: var(--cds-font-weight-semibold);
}

.phone.is-admin-root[data-route="main"][data-tab="operation"] .operation-target-list .recent-inline-metrics strong.is-neutral-value {
  color: var(--cds-color-text-secondary);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-hero,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .free-revenue-signal-card,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-preview,
.phone[data-route="revenue-guide"] .revenue-guide-hero,
.phone[data-route="revenue-guide"] .free-revenue-signal-card,
.phone[data-route="revenue-guide"] .revenue-guide-preview {
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  padding: 0;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-hero .badge,
.phone[data-route="revenue-guide"] .revenue-guide-hero .badge {
  min-height: 22px;
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-brand-primary-dark);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-preview,
.phone[data-route="revenue-guide"] .revenue-guide-preview {
  gap: 0;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-preview-list,
.phone[data-route="revenue-guide"] .revenue-preview-list {
  border: 0;
  border-radius: var(--cds-radius-card);
  background: var(--cds-color-surface-primary);
  box-shadow: none;
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-preview-row,
.phone[data-route="revenue-guide"] .revenue-preview-row {
  padding-inline: var(--spacing-12);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-actions .cta-primary,
.phone[data-route="revenue-guide"] .revenue-guide-actions .cta-primary {
  min-height: var(--spacing-48);
  border-radius: var(--cds-radius-sm);
  font-size: var(--cds-font-size-15);
  font-weight: var(--cds-font-weight-bold);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-actions,
.phone[data-route="revenue-guide"] .revenue-guide-actions {
  padding: var(--spacing-16);
  background: var(--cds-color-surface-primary);
}

.phone.is-admin-root[data-route="main"][data-tab="settlement"] .revenue-guide-actions .text-link-action,
.phone[data-route="revenue-guide"] .revenue-guide-actions .text-link-action {
  justify-self: start;
  min-height: var(--spacing-40, 40px);
  border: 0;
  background: transparent;
  box-shadow: none;
  color: var(--cds-color-text-secondary);
  text-decoration: underline;
}

.section-link-action:focus-visible {
  outline: 0;
  box-shadow: var(--cds-button-focus-ring);
}

/* 2026-06-05 Figma section full alignment: root nav, entrypoint heroes, metric deltas, share sheet. */
:root {
  --app-figma-separator: color-mix(in srgb, var(--cds-color-border-default) 78%, var(--cds-color-primary-background));
}

.statusbar {
  padding: 0 var(--spacing-32);
}

.statusbar.is-figma-asset {
  flex: 0 0 44px;
  height: 44px;
  display: block;
  padding: 0;
  background: var(--cds-color-surface-primary);
}

.figma-top-bar-asset {
  display: block;
  width: 100%;
  height: 44px;
  object-fit: fill;
  pointer-events: none;
  user-select: none;
}

.status-icons {
  display: inline-flex;
  align-items: center;
  gap: 4px;
}

.status-icons i {
  width: 4px;
  height: 11px;
  border-radius: var(--cds-radius-xs);
  background: var(--cds-color-text-primary);
  transform-origin: bottom;
}

.status-icons i:first-child {
  height: 8px;
}

.status-icons b {
  width: 24px;
  height: 11px;
  border: 1px solid var(--cds-color-text-primary);
  border-radius: var(--cds-radius-xs);
  position: relative;
}

.status-icons b::after {
  content: "";
  position: absolute;
  right: 2px;
  top: 2px;
  bottom: 2px;
  width: 14px;
  border-radius: var(--cds-radius-xs);
  background: var(--cds-color-text-primary);
}

.appbar.root {
  padding: 0 var(--spacing-16);
  justify-content: space-between;
  border-bottom: 0;
}

.appbar.root .title-stack {
  flex: 1 1 auto;
  align-items: flex-start;
}

.appbar.root .title-stack h1 {
  font-size: var(--cds-font-size-17);
  line-height: var(--cds-line-height-26);
  font-weight: var(--cds-font-weight-bold);
}

.appbar.root .appbar-actions {
  width: auto;
  min-width: 0;
  margin-left: var(--spacing-12);
  display: inline-flex;
}

.tier-badge {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  padding: 0 var(--spacing-10, 10px);
  border-radius: var(--cds-radius-sm);
  color: var(--cds-color-primary-foreground);
  background: var(--cds-color-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-bold);
  white-space: nowrap;
}

.tier-badge::before {
  content: "🌿";
  display: inline-block;
  font-size: 12px;
  line-height: 1;
}

.tier-badge--pro {
  background: color-mix(in srgb, var(--cds-color-semantic-info) 58%, var(--cds-color-primary));
}

.tier-badge--pro::before {
  content: "🌟";
}

.tier-badge--image {
  min-height: var(--spacing-24);
  padding: 0;
  border-radius: var(--cds-radius-none);
  background: transparent;
  line-height: 0;
}

.tier-badge--image::before {
  content: none;
}

.tier-badge-image {
  display: block;
  width: auto;
  height: var(--spacing-24);
}

.bottom-tabs {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  padding-inline: 0;
}

.bottom-tab {
  gap: var(--spacing-2, 2px);
}

.bottom-tab span {
  font-size: 23px;
  line-height: 1;
}

.bottom-tab em {
  position: static;
  width: auto;
  height: auto;
  overflow: visible;
  clip: auto;
  white-space: nowrap;
  color: currentColor;
  font-size: var(--cds-font-size-11);
  line-height: var(--cds-line-height-16);
  font-style: normal;
  font-weight: var(--cds-font-weight-semibold);
}

.phone.is-admin-root[data-route="main"] .screen-scroll {
  padding-bottom: calc(var(--app-bottom-tabs-height) + var(--spacing-32));
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero,
.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-block,
.phone.is-admin-root[data-route="main"][data-tab="home"] .reaction-card.is-home-reaction-summary,
.phone.is-admin-root[data-route="main"][data-tab="home"] .reaction-empty-section.is-home-reaction-summary,
.phone.is-admin-root[data-route="main"][data-tab="home"] .recent-published-section,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-hero,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .settlement-calculation-row,
.phone.is-admin-root[data-route="main"][data-tab="settlement"] .screen-scroll > section {
  border-top-width: var(--spacing-10, 10px);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-action-hero {
  padding: var(--spacing-44) var(--spacing-16) var(--spacing-16);
}

.home-action-hero.is-figma-hero .home-revenue-copy {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 128px;
  align-items: center;
  gap: var(--spacing-12);
}

.home-action-hero.is-figma-hero .home-revenue-copy > div:first-child {
  min-width: 0;
  display: grid;
  justify-items: start;
  gap: var(--spacing-8);
  text-align: left;
}

.home-action-hero.is-figma-hero h2 {
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-32);
  letter-spacing: -.55px;
}

.home-action-hero.is-figma-hero .home-revenue-note {
  font-size: var(--cds-font-size-14);
  line-height: var(--cds-line-height-22);
}

.home-hero-art {
  position: relative;
  justify-self: end;
  width: 122px;
  height: 122px;
  display: grid;
  place-items: center;
  overflow: hidden;
}

.home-hero-art span,
.home-hero-art::before,
.home-hero-art::after {
  content: "";
  position: absolute;
  display: block;
}

.home-hero-art.is-flag::before {
  width: 64px;
  height: 12px;
  bottom: 22px;
  left: 24px;
  border-radius: var(--cds-radius-full);
  background: color-mix(in srgb, var(--cds-color-primary) 68%, var(--cds-color-surface-secondary));
  box-shadow: 0 14px 0 color-mix(in srgb, var(--cds-color-primary-background) 70%, var(--cds-color-surface-secondary));
  transform: skewX(-18deg);
}

.home-hero-art.is-flag::after {
  width: 12px;
  height: 72px;
  left: 58px;
  top: 20px;
  border-radius: var(--cds-radius-full);
  background: linear-gradient(180deg, var(--cds-color-surface-primary), color-mix(in srgb, var(--cds-color-text-tertiary) 28%, var(--cds-color-surface-secondary)));
  box-shadow: -32px 48px 0 -2px color-mix(in srgb, var(--cds-color-primary) 38%, var(--cds-color-surface-secondary));
}

.home-hero-art.is-flag span {
  width: 62px;
  height: 38px;
  left: 64px;
  top: 26px;
  border-radius: var(--cds-radius-xs) var(--spacing-20) var(--spacing-20) var(--cds-radius-xs);
  background: linear-gradient(135deg, var(--cds-color-primary), var(--cds-color-brand-primary-dark));
  transform: skewY(-5deg);
}

.home-hero-art.is-chart::before {
  width: 76px;
  height: 76px;
  border-radius: var(--cds-radius-card);
  background: linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary) 28%, var(--cds-color-surface-primary)), var(--cds-color-primary));
  transform: rotate(-12deg);
  box-shadow: 0 10px 18px color-mix(in srgb, var(--cds-color-primary) 16%, transparent);
}

.home-hero-art.is-chart::after {
  width: 56px;
  height: 38px;
  border-left: 9px solid var(--cds-color-primary-foreground);
  border-bottom: 9px solid var(--cds-color-primary-foreground);
  border-radius: var(--cds-radius-xs);
  transform: translateY(2px) rotate(-45deg);
}

.home-hero-art.is-chart span {
  width: 92px;
  height: 92px;
  border-radius: var(--cds-radius-full);
  border: 10px solid color-mix(in srgb, var(--cds-color-primary-background) 80%, var(--cds-color-surface-primary));
}

.home-hero-art.is-celebration::before {
  width: 44px;
  height: 74px;
  border-radius: var(--spacing-24) var(--spacing-24) var(--cds-radius-sm) var(--cds-radius-sm);
  background: linear-gradient(145deg, var(--cds-color-primary), var(--cds-color-brand-primary-dark));
  transform: rotate(32deg);
}

.home-hero-art.is-celebration::after {
  width: 90px;
  height: 90px;
  background:
    radial-gradient(circle at 18% 22%, var(--cds-color-primary) 0 5px, transparent 6px),
    radial-gradient(circle at 78% 22%, var(--cds-color-warning) 0 7px, transparent 8px),
    radial-gradient(circle at 66% 70%, var(--cds-color-primary) 0 4px, transparent 5px),
    radial-gradient(circle at 40% 12%, var(--cds-color-warning) 0 4px, transparent 5px);
}

.home-hero-art.is-celebration span {
  width: 42px;
  height: 42px;
  right: 12px;
  top: 24px;
  clip-path: polygon(50% 0, 62% 36%, 100% 40%, 70% 62%, 80% 100%, 50% 78%, 20% 100%, 30% 62%, 0 40%, 38% 36%);
  background: linear-gradient(135deg, var(--cds-color-warning), color-mix(in srgb, var(--cds-color-warning) 42%, var(--cds-color-surface-primary)));
}

.home-hero-art.is-wallet::before {
  width: 98px;
  height: 70px;
  border-radius: var(--spacing-24) var(--spacing-24) var(--spacing-18, 18px) var(--spacing-18, 18px);
  background: linear-gradient(145deg, color-mix(in srgb, var(--cds-color-primary) 84%, var(--cds-color-primary-background)), var(--cds-color-brand-primary-dark));
  box-shadow: inset 0 -8px 0 color-mix(in srgb, var(--cds-color-brand-primary-dark) 22%, transparent);
}

.home-hero-art.is-wallet::after {
  width: var(--spacing-36);
  height: var(--spacing-24);
  right: var(--spacing-16);
  top: var(--spacing-56);
  border-radius: var(--cds-radius-full);
  background: color-mix(in srgb, var(--cds-color-surface-primary) 88%, var(--cds-color-primary-background));
  box-shadow: inset 0 0 0 2px color-mix(in srgb, var(--cds-color-primary) 18%, var(--cds-color-border-default));
}

.home-hero-art.is-wallet span {
  width: 50px;
  height: 50px;
  top: 10px;
  left: 34px;
  border-radius: var(--cds-radius-full);
  background: linear-gradient(135deg, color-mix(in srgb, var(--cds-color-warning) 42%, var(--cds-color-surface-primary)), var(--cds-color-warning));
  box-shadow: inset 0 0 0 4px color-mix(in srgb, var(--cds-color-warning) 30%, var(--cds-color-surface-primary));
}

.home-hero-art.is-wallet span::after {
  content: "₩";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: color-mix(in srgb, var(--cds-color-warning) 55%, var(--cds-color-text-primary));
  font-weight: var(--cds-font-weight-bold);
}

.home-action-hero.is-hero-wallet .home-revenue-value {
  margin-top: var(--spacing-6);
  color: var(--cds-color-text-primary);
  font-size: clamp(30px, 8vw, 34px);
  line-height: var(--cds-line-height-32);
}

.home-action-hero.is-revenue-affordance h2 {
  line-height: var(--cds-line-height-28);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell-row.is-four-metrics {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  row-gap: var(--spacing-16);
  column-gap: var(--spacing-20);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell {
  display: grid;
  gap: var(--spacing-4);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell strong {
  display: inline-flex;
  align-items: center;
  gap: var(--spacing-4);
  margin-top: var(--spacing-2, 2px);
}

.home-metric-delta {
  color: var(--cds-color-primary);
  font-size: var(--app-type-meta-size);
  line-height: var(--app-type-meta-line);
  font-weight: var(--cds-font-weight-semibold);
}

.home-metric-delta.is-negative-delta,
.home-metric-delta.is-locked-delta,
.home-metric-delta.is-neutral-delta {
  color: var(--cds-color-text-secondary);
}

.metric-icon {
  display: inline-grid;
  place-items: center;
  width: var(--spacing-20);
  height: var(--spacing-20);
  border-radius: var(--cds-radius-full);
  background: color-mix(in srgb, var(--cds-color-warning) 78%, var(--cds-color-surface-primary));
  color: var(--cds-color-neutral-white);
  font-size: var(--cds-font-size-13);
  line-height: var(--cds-line-height-none);
  font-weight: var(--cds-font-weight-bold);
}

.cp-value {
  display: inline-grid;
  grid-auto-flow: column;
  grid-auto-columns: max-content;
  align-items: center;
  gap: var(--spacing-2, 2px);
  justify-content: start;
  white-space: nowrap;
  vertical-align: middle;
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell .cp-value,
.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell .cp-value span {
  padding: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.cp-icon {
  display: block;
  width: auto;
  height: var(--spacing-20);
  flex: 0 0 auto;
  object-fit: contain;
}

.cp-icon--value {
  height: var(--spacing-20);
}

.home-metric-lock-only {
  display: block;
  width: var(--spacing-24);
  height: var(--spacing-24);
  flex: 0 0 auto;
  color: var(--cds-color-text-tertiary);
}

.phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell strong.is-locked-value {
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-20);
}

.reaction-card.is-home-reaction-summary h2 span,
.recent-published-section .section-header h2 span {
  color: var(--cds-color-primary);
}

.home-cert-preview-strip {
  display: flex;
  gap: var(--spacing-4);
  overflow-x: auto;
  margin-right: calc(var(--spacing-16) * -1);
  padding-bottom: var(--spacing-4);
  scrollbar-width: none;
}

.home-cert-preview-strip::-webkit-scrollbar {
  display: none;
}

.home-cert-preview-thumb {
  position: relative;
  width: 109px;
  height: 112px;
  flex: 0 0 109px;
  overflow: hidden;
  border-radius: var(--cds-radius-xs);
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary-background) 76%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-text-primary) 18%, var(--cds-color-surface-secondary)));
}

.home-cert-preview-thumb.is-blue {
  background: linear-gradient(135deg, color-mix(in srgb, var(--cds-color-semantic-info) 24%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-text-primary) 20%, var(--cds-color-surface-secondary)));
}

.home-cert-preview-thumb.is-orange {
  background: linear-gradient(135deg, color-mix(in srgb, var(--cds-color-warning) 25%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-text-primary) 16%, var(--cds-color-surface-secondary)));
}

.home-cert-preview-thumb.is-purple {
  background: linear-gradient(135deg, color-mix(in srgb, var(--cds-color-primary) 20%, var(--cds-color-surface-secondary)), color-mix(in srgb, var(--cds-color-semantic-info) 20%, var(--cds-color-surface-secondary)));
}

.home-cert-preview-thumb b {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: color-mix(in srgb, var(--cds-color-neutral-white) 92%, transparent);
  font-size: var(--cds-font-size-22);
}

.home-cert-preview-thumb em {
  position: absolute;
  top: var(--spacing-4);
  right: var(--spacing-4);
  padding: var(--spacing-4) var(--spacing-6);
  border-radius: var(--cds-radius-sm);
  background: color-mix(in srgb, var(--cds-color-text-primary) 74%, transparent);
  color: var(--cds-color-neutral-white);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-style: normal;
}

.home-cert-preview-thumb.is-new::after {
  content: "";
  position: absolute;
  top: var(--spacing-8);
  right: var(--spacing-8);
  width: var(--spacing-8);
  height: var(--spacing-8);
  border: var(--spacing-2, 2px) solid var(--cds-color-surface-primary);
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-semantic-error);
}

.is-empty-preview .home-cert-preview-thumb {
  filter: blur(1.2px) grayscale(.18);
  opacity: .72;
}

.reaction-empty-section.is-figma-waiting {
  padding: var(--spacing-20) var(--spacing-16) var(--spacing-24);
}

.reaction-empty-section.is-figma-waiting .reaction-empty-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: var(--spacing-18, 18px);
  text-align: center;
}

.reaction-empty-section.is-figma-waiting .reaction-empty-copy {
  justify-items: center;
  gap: var(--spacing-8);
}

.reaction-empty-section.is-figma-waiting .reaction-empty-copy h3 {
  overflow: visible;
  white-space: normal;
  font-size: var(--cds-font-size-22);
  line-height: var(--cds-line-height-32);
  letter-spacing: -.5px;
}

.reaction-empty-section.is-figma-waiting .reaction-empty-copy p {
  font-size: var(--cds-font-size-13);
  line-height: var(--cds-line-height-20);
}

.challenge-thumb.is-photo span,
.challenge-thumb.is-ai span {
  opacity: 0;
}

.challenge-thumb.is-photo {
  background:
    radial-gradient(circle at 58% 42%, color-mix(in srgb, var(--cds-color-warning) 36%, transparent) 0 16%, transparent 18%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-warning) 24%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-text-primary) 16%, var(--cds-color-surface-secondary)));
}

.challenge-thumb.is-photo::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    linear-gradient(145deg, transparent 0 42%, color-mix(in srgb, var(--cds-color-neutral-white) 62%, transparent) 43% 47%, transparent 48%),
    radial-gradient(circle at 44% 56%, color-mix(in srgb, var(--cds-color-text-primary) 34%, transparent) 0 10%, transparent 11%);
}

.challenge-thumb.is-ai {
  color: var(--cds-color-primary-foreground);
  background:
    radial-gradient(circle at 50% 46%, color-mix(in srgb, var(--cds-color-primary) 72%, transparent) 0 18%, transparent 20%),
    linear-gradient(135deg, color-mix(in srgb, var(--cds-color-semantic-info) 70%, var(--cds-color-text-primary)), color-mix(in srgb, var(--cds-color-text-primary) 82%, var(--cds-color-semantic-info)));
}

.challenge-thumb.is-ai::before {
  content: "AI";
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  color: var(--cds-color-primary-foreground);
  font-size: var(--cds-font-size-17);
  font-weight: var(--cds-font-weight-bold);
  letter-spacing: -.2px;
}

/* Figma-like iOS share sheet for the Free0 share CTA. */
.is-share-backdrop {
  align-items: end;
  background: color-mix(in srgb, var(--cds-color-text-primary) 8%, transparent);
}

.native-share-sheet {
  position: relative;
  width: 100%;
  max-height: calc(100% - var(--spacing-16));
  overflow-y: auto;
  border-radius: var(--cds-radius-card) var(--cds-radius-card) 0 0;
  background: color-mix(in srgb, var(--cds-color-surface-secondary) 42%, var(--cds-color-surface-primary));
  padding: var(--spacing-16);
  box-shadow: 0 -12px 32px color-mix(in srgb, var(--cds-color-text-primary) 14%, transparent);
}

.native-share-sheet:has(.figma-share-sheet-frame) {
  max-height: calc(100% - var(--spacing-16));
  overflow: visible;
  border-radius: var(--cds-radius-card) var(--cds-radius-card) 0 0;
  background: transparent;
  padding: 0;
  box-shadow: none;
}

.figma-share-sheet-frame {
  position: relative;
  width: 100%;
  line-height: 0;
}

.figma-share-sheet-asset {
  display: block;
  width: 100%;
  height: auto;
  max-height: calc(100dvh - var(--spacing-16));
  object-fit: contain;
  object-position: bottom center;
  pointer-events: none;
  user-select: none;
}

.figma-share-sheet-close {
  position: absolute;
  top: 2.6%;
  right: 6.7%;
  width: var(--spacing-32);
  height: var(--spacing-32);
  border: 0;
  border-radius: var(--cds-radius-sm);
  background: transparent;
  cursor: pointer;
}

.figma-share-sheet-close:focus-visible {
  outline: 0;
  box-shadow: var(--cds-button-focus-ring);
}

.share-header {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr) 36px;
  align-items: center;
  gap: var(--spacing-12);
  padding-bottom: var(--spacing-16);
}

.share-app-icon,
.share-app-symbol,
.share-avatar {
  display: grid;
  place-items: center;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-primary);
  color: var(--cds-color-primary-foreground);
  font-size: 10px;
  font-weight: var(--cds-font-weight-bold);
}

.share-app-icon {
  width: 36px;
  height: 36px;
}

.share-header strong {
  display: block;
  font-size: var(--cds-font-size-14);
  line-height: var(--cds-line-height-20);
}

.share-header span,
.share-person em,
.share-app em {
  color: var(--cds-color-text-secondary);
  font-size: var(--app-type-caption-size);
  line-height: var(--app-type-caption-line);
  font-style: normal;
}

.share-close {
  width: 32px;
  height: 32px;
  border: 0;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-muted);
  color: var(--cds-color-text-secondary);
  font-size: var(--cds-font-size-22);
  line-height: 1;
}

.share-people-row,
.share-app-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--spacing-12);
  padding: var(--spacing-16) 0;
  border-top: 1px solid var(--cds-color-border-default);
}

.share-person,
.share-app {
  min-width: 0;
  display: grid;
  justify-items: center;
  gap: var(--spacing-6);
  text-align: center;
}

.share-avatar {
  position: relative;
  width: 60px;
  height: 60px;
  border-radius: var(--cds-radius-full);
  background: linear-gradient(135deg, color-mix(in srgb, var(--cds-color-warning) 32%, var(--cds-color-surface-primary)), color-mix(in srgb, var(--cds-color-text-primary) 18%, var(--cds-color-surface-secondary)));
}

.share-avatar::before {
  content: "";
  width: 30px;
  height: 30px;
  border-radius: var(--cds-radius-full);
  background: color-mix(in srgb, var(--cds-color-text-primary) 70%, var(--cds-color-warning));
}

.share-avatar::after,
.share-person b {
  content: "";
  position: absolute;
}

.share-person {
  position: relative;
}

.share-person b {
  right: 6px;
  top: 48px;
  width: 18px;
  height: 18px;
  border: 2px solid var(--cds-color-surface-primary);
  border-radius: var(--cds-radius-full);
  background: var(--cds-color-primary);
}

.share-app-symbol {
  width: 58px;
  height: 58px;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
  color: var(--cds-color-primary);
  border: 1px solid var(--cds-color-border-default);
}

.share-app-symbol::before {
  font-size: 30px;
}

.share-app-symbol.is-airdrop::before { content: "◎"; }
.share-app-symbol.is-messages { background: var(--cds-color-primary); color: var(--cds-color-primary-foreground); }
.share-app-symbol.is-messages::before { content: "●"; }
.share-app-symbol.is-mail { color: var(--cds-color-semantic-info); }
.share-app-symbol.is-mail::before { content: "✉"; }
.share-app-symbol.is-notes { color: var(--cds-color-warning); }
.share-app-symbol.is-notes::before { content: "▤"; }

.share-action-list {
  overflow: hidden;
  border-radius: var(--cds-radius-sm);
  background: var(--cds-color-surface-primary);
}

.share-action-list button {
  width: 100%;
  min-height: 50px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  border: 0;
  border-bottom: 1px solid var(--cds-color-border-default);
  background: transparent;
  padding: 0 var(--spacing-16);
  color: var(--cds-color-text-primary);
  font-size: var(--cds-font-size-16);
  line-height: var(--cds-line-height-22);
}

.share-action-list button:last-child {
  border-bottom: 0;
}

.share-action-list b {
  font-size: var(--cds-font-size-22);
  font-weight: var(--cds-font-weight-regular);
}

@media (max-width: 360px) {
  .home-action-hero.is-figma-hero .home-revenue-copy {
    grid-template-columns: minmax(0, 1fr) 104px;
  }

  .home-hero-art {
    width: 104px;
    height: 104px;
  }

  .phone.is-admin-root[data-route="main"][data-tab="home"] .home-metric-cell-row.is-four-metrics {
    column-gap: var(--spacing-16);
  }
}


/* 2026-06-05 mobile repair: empty certification preview must not create horizontal overflow. */
.is-empty-preview.home-cert-preview-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--spacing-4);
  overflow: hidden;
  margin-right: 0;
  padding-bottom: 0;
}

.is-empty-preview .home-cert-preview-thumb {
  width: auto;
  min-width: 0;
  flex: 1 1 auto;
}
