:root {
  --page: #fbfaf7;
  --paper: #ffffff;
  --paper-soft: #f7f7f4;
  --paper-warm: #f4f0ea;
  --ink: #141414;
  --ink-soft: #312f2c;
  --muted: #5f5b55;
  --muted-2: #7a746c;
  --line: #e8e4dc;
  --line-strong: #d7d0c6;
  --black: #111111;
  --white: #ffffff;
  --blue: #2563eb;
  --blue-soft: #dfe8ff;
  --green: #07c160;
  --green-soft: #daf7e8;
  --orange: #ff8c00;
  --orange-soft: #ffe6cc;
  --purple: #7c3aed;
  --purple-soft: #eadfff;
  --rose: #e67a97;
  --rose-soft: #f8dce4;
  --shadow: 0 24px 80px rgba(35, 31, 25, 0.1);
  --max: 1200px;
  --wide: 1280px;
  --hero-cta-module-gap: 138px;
  --radius-sm: 8px;
  --radius-md: 16px;
  --radius-lg: 28px;
  --radius-xl: 34px;
  --display: "Songti SC", "Noto Serif SC", "STSong", "SimSun", serif;
  --body: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Microsoft YaHei", "Helvetica Neue", Arial, sans-serif;
}

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  background: var(--page);
  color: var(--ink);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.6;
  letter-spacing: 0;
}

body.nav-open {
  overflow: hidden;
}

img,
svg {
  display: block;
  max-width: 100%;
}

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

button,
input,
select,
textarea {
  font: inherit;
}

button {
  cursor: pointer;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(251, 250, 247, 0.92);
  border-bottom: 1px solid var(--line);
  backdrop-filter: blur(18px);
}

.nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: min(var(--wide), calc(100% - 48px));
  min-height: 68px;
  margin: 0 auto;
}

.brand {
  display: inline-flex;
  align-items: flex-end;
  gap: 9px;
  color: var(--ink);
  font-weight: 700;
  white-space: nowrap;
}

.brand-logo {
  display: block;
  width: 34px;
  height: 34px;
  object-fit: contain;
  flex: 0 0 auto;
}

.brand-mark {
  font-family: var(--display);
  font-size: 24px;
  line-height: 1;
  margin-bottom: 5px;
}

.brand-sub {
  color: var(--muted);
  font-size: 13px;
  font-weight: 650;
  line-height: 1;
  margin-bottom: 5px;
}

.nav-links {
  display: flex;
  align-items: center;
  gap: 28px;
  color: var(--muted);
  font-size: 14px;
}

.nav-links a[aria-current="page"],
.nav-links a:hover {
  color: var(--ink);
}

.nav-actions {
  display: flex;
  align-items: center;
  gap: 12px;
}

.nav-toggle {
  display: none;
  width: 42px;
  height: 42px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper);
  color: var(--ink);
}

.nav-toggle span {
  display: block;
  width: 17px;
  height: 2px;
  margin: 4px auto;
  background: currentColor;
}

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 46px;
  padding: 0 22px;
  border: 1px solid transparent;
  border-radius: var(--radius-sm);
  font-weight: 700;
  line-height: 1;
  transition: transform 180ms ease, background 180ms ease, border 180ms ease;
  white-space: nowrap;
}

.btn:hover {
  transform: translateY(-1px);
}

.btn-primary {
  background: var(--black);
  color: var(--white);
}

.btn-secondary {
  background: var(--paper-warm);
  border-color: var(--line-strong);
  color: var(--ink-soft);
}

.btn-light {
  background: var(--paper);
  border-color: var(--line);
  color: var(--ink);
}

.btn-link {
  min-height: auto;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--ink);
}

.main {
  overflow: hidden;
}

.section {
  padding: 124px 0;
}

.section-tight {
  padding: 96px 0;
}

.hero + .section-tight {
  padding-top: 42px;
}

.section:first-child {
  padding-top: 118px;
}

.container {
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
}

.container-wide {
  width: min(var(--wide), calc(100% - 48px));
  margin: 0 auto;
}

.hero {
  padding: 92px 0 76px;
  text-align: center;
}

.hero-narrow {
  width: min(1080px, calc(100% - 48px));
  margin: 0 auto;
}

.hero-kicker,
.section-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 26px;
  color: var(--muted);
  font-size: 14px;
  font-weight: 650;
}

.line-icon {
  width: 48px;
  height: 48px;
  margin: 0 auto 18px;
  color: var(--ink);
}

.line-icon svg {
  width: 100%;
  height: 100%;
  stroke: currentColor;
  stroke-width: 2.6;
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.display-title {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(48px, 5.5vw, 80px);
  font-weight: 650;
  line-height: 1.08;
  letter-spacing: 0;
  text-wrap: balance;
}

.display-title.page-title {
  font-size: clamp(50px, 5.8vw, 86px);
}

.section-title {
  max-width: 1040px;
  margin: 0 auto;
  font-family: var(--display);
  font-size: clamp(36px, 3.9vw, 58px);
  font-weight: 650;
  line-height: 1.14;
  letter-spacing: 0;
  text-align: center;
  text-wrap: balance;
}

.section-title.left {
  margin-left: 0;
  text-align: left;
}

.title-line {
  display: block;
}

.hero-lede,
.section-lede {
  max-width: 780px;
  margin: 22px auto 0;
  color: var(--muted);
  font-size: clamp(18px, 1.45vw, 22px);
  line-height: 1.48;
  text-align: center;
  text-wrap: balance;
}

.split-lede span {
  display: block;
}

.section-lede.small {
  max-width: 680px;
  font-size: 19px;
}

.hero-actions,
.section-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 14px;
  margin-top: 34px;
}

.tag-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 28px;
}

.tag,
.status-badge {
  display: inline-flex;
  align-items: center;
  min-height: 32px;
  padding: 0 13px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: var(--muted);
  font-size: 14px;
  font-weight: 650;
}

.status-badge {
  border-color: rgba(255, 140, 0, 0.24);
  background: #fff3e5;
  color: #a15500;
}

.demo-stage {
  position: relative;
  min-height: 560px;
  margin: 64px auto 0;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: var(--paper-warm);
  box-shadow: var(--shadow);
}

.demo-stage::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.32;
  background:
    radial-gradient(circle at 15% 22%, rgba(255, 255, 255, 0.56) 0 12%, transparent 13%),
    linear-gradient(135deg, transparent 0 44%, rgba(255, 255, 255, 0.38) 45% 46%, transparent 47%),
    linear-gradient(35deg, transparent 0 60%, rgba(255, 255, 255, 0.3) 61% 62%, transparent 63%);
  pointer-events: none;
}

.demo-stage.stage-blue {
  background: #dfe8ff;
}

.demo-stage.stage-green {
  background: #dff7e9;
}

.demo-stage.stage-orange {
  background: #ffe2c4;
}

.demo-stage.stage-purple {
  background: #ebe1ff;
}

.demo-stage.stage-rose {
  background: #f8dce4;
}

.visual-panel {
  position: relative;
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 56px;
  align-items: center;
  min-height: 520px;
  margin-top: 56px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: var(--radius-xl);
  background: var(--paper);
  box-shadow: var(--shadow);
}

.visual-panel.reverse {
  grid-template-columns: 1.18fr 0.82fr;
}

.visual-panel-copy {
  padding: 54px 0 54px 56px;
}

.visual-panel.reverse .visual-panel-copy {
  padding: 54px 56px 54px 0;
}

.visual-panel-copy h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 42px;
  line-height: 1.12;
}

.visual-panel-copy p {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 18px;
}

.mock-visual {
  position: relative;
  min-height: 420px;
  margin: 24px;
  overflow: hidden;
  border-radius: 24px;
  background: linear-gradient(135deg, var(--blue-soft), var(--paper) 45%, var(--green-soft));
}

.mock-visual.orange {
  background: linear-gradient(135deg, var(--orange-soft), var(--paper) 48%, var(--rose-soft));
}

.mock-visual.purple {
  background: linear-gradient(135deg, var(--purple-soft), var(--paper) 48%, var(--blue-soft));
}

.mock-visual.green {
  background: linear-gradient(135deg, var(--green-soft), var(--paper) 48%, var(--orange-soft));
}

.mock-visual::before {
  content: "";
  position: absolute;
  inset: 38px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background:
    linear-gradient(var(--paper) 0 0) 36px 42px / 48% 18px no-repeat,
    linear-gradient(var(--paper) 0 0) 36px 78px / 66% 12px no-repeat,
    linear-gradient(var(--paper) 0 0) 36px 108px / 58% 12px no-repeat,
    linear-gradient(90deg, var(--blue), var(--green), var(--orange), var(--purple)) 36px 156px / 72% 160px no-repeat,
    rgba(255, 255, 255, 0.58);
  box-shadow: 0 24px 70px rgba(30, 25, 20, 0.12);
}

.mock-phone-row {
  position: absolute;
  left: 11%;
  right: 11%;
  bottom: 42px;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.mock-phone {
  min-height: 150px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background:
    linear-gradient(var(--paper-soft) 0 0) 18px 24px / 62% 10px no-repeat,
    linear-gradient(var(--paper-soft) 0 0) 18px 48px / 42% 8px no-repeat,
    linear-gradient(180deg, rgba(255, 255, 255, 0.92), rgba(255, 255, 255, 0.68));
  box-shadow: 0 12px 32px rgba(30, 25, 20, 0.1);
}

.image-under-title {
  margin-top: 48px;
}

.hero-story {
  min-height: 650px;
}

.story-board {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.86fr 1.14fr;
  grid-template-areas:
    "command dashboard"
    "loop dashboard";
  gap: 24px;
  align-items: stretch;
  min-height: inherit;
  padding: 58px 64px;
}

.command-card {
  grid-area: command;
  padding: 30px;
}

.command-card h2 {
  margin: 0 0 16px;
  color: #f8f6f0;
  font-family: var(--display);
  font-size: 36px;
  line-height: 1.08;
}

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

.loop-node {
  min-height: 146px;
  padding: 20px;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 16px 44px rgba(33, 29, 23, 0.12);
}

.loop-node small {
  display: block;
  color: var(--muted-2);
  font-weight: 800;
}

.loop-node strong {
  display: block;
  margin-top: 18px;
  font-family: var(--display);
  font-size: 30px;
  line-height: 1.05;
}

.loop-node span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 14px;
}

.loop-node.blue {
  box-shadow: inset 0 5px 0 var(--blue), 0 16px 44px rgba(33, 29, 23, 0.12);
}

.loop-node.green {
  box-shadow: inset 0 5px 0 var(--green), 0 16px 44px rgba(33, 29, 23, 0.12);
}

.loop-node.orange {
  box-shadow: inset 0 5px 0 var(--orange), 0 16px 44px rgba(33, 29, 23, 0.12);
}

.loop-node.purple {
  box-shadow: inset 0 5px 0 var(--purple), 0 16px 44px rgba(33, 29, 23, 0.12);
}

.story-dashboard {
  grid-area: dashboard;
  align-self: stretch;
}

.challenge-stage {
  min-height: 610px;
}

.challenge-board {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 28px;
  align-items: stretch;
  min-height: inherit;
  padding: 58px 64px;
}

.pain-board {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 340px;
  padding: 30px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  border: 1px solid rgba(20, 20, 20, 0.08);
  box-shadow: 0 18px 60px rgba(33, 29, 23, 0.1);
}

.pain-board h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 36px;
  line-height: 1.12;
}

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

.pain-grid span {
  display: grid;
  place-items: center;
  min-height: 82px;
  padding: 12px;
  border-radius: 16px;
  background: var(--paper);
  color: var(--ink-soft);
  font-weight: 800;
  text-align: center;
}

.flow-board {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 18px;
  align-items: center;
}

.flow-column {
  display: grid;
  gap: 13px;
  align-content: start;
  min-height: 340px;
  padding: 24px;
  border-radius: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.68);
}

.flow-column strong {
  margin-bottom: 8px;
  font-family: var(--display);
  font-size: 28px;
  line-height: 1.1;
}

.flow-column span {
  min-height: 48px;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--paper);
  color: var(--muted);
  font-weight: 750;
}

.flow-column.strong span {
  color: var(--ink);
}

.flow-arrow {
  color: var(--ink);
  font-family: var(--display);
  font-size: 46px;
  line-height: 1;
}

.mini-dashboard {
  grid-column: 1 / -1;
}

.comparison-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  margin-top: 62px;
}

.comparison-pane {
  min-height: 500px;
  padding: 38px;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: var(--shadow);
}

.comparison-pane h3 {
  margin: 22px 0 0;
  font-family: var(--display);
  font-size: 42px;
  line-height: 1.08;
}

.comparison-pane p {
  margin: 24px 0 0;
  color: var(--muted);
  font-size: 18px;
}

.strong-pane {
  background: linear-gradient(135deg, var(--paper), var(--green-soft));
}

.pane-visual {
  display: grid;
  gap: 14px;
  min-height: 190px;
  margin-top: 34px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: var(--paper);
}

.pane-visual span {
  display: grid;
  place-items: center;
  min-height: 46px;
  border-radius: 12px;
  background: var(--paper-soft);
  color: var(--muted);
  font-weight: 800;
}

.system-visual {
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: center;
}

.system-visual span {
  min-height: 112px;
  color: var(--ink);
}

.system-visual span:nth-child(1) {
  background: var(--blue-soft);
}

.system-visual span:nth-child(2) {
  background: var(--green-soft);
}

.system-visual span:nth-child(3) {
  background: var(--orange-soft);
}

.system-visual span:nth-child(4) {
  background: var(--purple-soft);
}

.system-visual span:nth-child(5) {
  background: var(--rose-soft);
}

.method-map {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr auto 1fr;
  gap: 16px;
  align-items: center;
  margin-top: 70px;
}

.method-node {
  min-height: 260px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 18px 54px rgba(33, 29, 23, 0.08);
}

.method-node small {
  display: block;
  color: var(--muted-2);
  font-weight: 850;
}

.method-node strong {
  display: block;
  margin-top: 60px;
  font-family: var(--display);
  font-size: 32px;
  line-height: 1.08;
}

.method-node span {
  display: block;
  margin-top: 14px;
  color: var(--muted);
}

.method-arrow {
  color: var(--muted-2);
  font-family: var(--display);
  font-size: 42px;
}

.flagship-media {
  display: grid;
  grid-template-columns: 1.08fr 0.92fr;
  gap: 34px;
  place-items: stretch;
  padding: 70px;
}

.flagship-media .case-media-content {
  align-self: center;
  width: auto;
}

.case-map {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 16px;
  align-content: center;
}

.case-map div {
  min-height: 108px;
  padding: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  font-family: var(--display);
  font-size: 28px;
  line-height: 1.1;
  box-shadow: 0 16px 46px rgba(33, 29, 23, 0.08);
}

.case-map small {
  display: block;
  margin-top: 10px;
  color: var(--muted);
  font-family: var(--body);
  font-size: 14px;
  font-weight: 650;
}

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

.app-bullets span {
  min-height: 76px;
  padding: 18px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.8);
  color: var(--ink);
  font-weight: 800;
}

.scenario-boards {
  display: grid;
  gap: 30px;
  margin-top: 62px;
}

.scenario-board {
  display: grid;
  grid-template-columns: 0.8fr 1.2fr;
  gap: 44px;
  align-items: center;
  min-height: 330px;
  padding: 48px;
  border: 1px solid var(--line);
  border-radius: 28px;
  background: linear-gradient(135deg, var(--blue-soft), rgba(255, 255, 255, 0.76));
  box-shadow: var(--shadow);
}

.scenario-board.green {
  background: linear-gradient(135deg, var(--green-soft), rgba(255, 255, 255, 0.76));
}

.scenario-board h3 {
  margin: 20px 0 0;
  font-family: var(--display);
  font-size: 42px;
  line-height: 1.08;
}

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

.scenario-flow span {
  display: grid;
  place-items: center;
  min-height: 170px;
  padding: 14px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink-soft);
  font-weight: 850;
  text-align: center;
  box-shadow: 0 14px 38px rgba(33, 29, 23, 0.08);
}

.process-map {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  margin-top: 62px;
}

.process-map div {
  min-height: 250px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.72);
}

.process-map small {
  color: var(--muted-2);
  font-weight: 850;
}

.process-map strong {
  display: block;
  margin-top: 70px;
  font-family: var(--display);
  font-size: 30px;
  line-height: 1.08;
}

.process-map span {
  display: block;
  margin-top: 12px;
  color: var(--muted);
  font-size: 15px;
}

.trust-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-top: 28px;
}

.trust-strip span {
  display: grid;
  place-items: center;
  min-height: 74px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--paper-warm);
  color: var(--ink-soft);
  font-weight: 800;
  text-align: center;
}

body.home .line-icon {
  display: none;
}

body.home .hero {
  padding-top: 76px;
  padding-bottom: 124px;
}

body.home .home-band {
  padding-top: 124px;
  padding-bottom: 124px;
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

body.home .home-band-challenge {
  background: linear-gradient(180deg, #f8fbff 0%, #f4f8ff 54%, #fbfaf7 100%);
}

body.home .home-band-method {
  background: linear-gradient(180deg, #fbfff9 0%, #f4faf2 55%, #fbfaf7 100%);
}

body.home .home-band-case {
  background: linear-gradient(180deg, #fff8f6 0%, #fff2f5 52%, #fbfaf7 100%);
}

body.home .home-band-products {
  background: linear-gradient(180deg, #f7fbff 0%, #f6fff9 54%, #fbfaf7 100%);
}

body.home .home-band-industry {
  background: linear-gradient(180deg, #f7fcf5 0%, #fffaf3 56%, #fbfaf7 100%);
}

body.home .home-band-first-flow {
  background: linear-gradient(180deg, #fffaf2 0%, #f8f5ff 54%, #fbfaf7 100%);
}

body.home .home-band-process {
  background: linear-gradient(180deg, #f8fbff 0%, #fff8ed 56%, #fbfaf7 100%);
}

body.home .home-band-final {
  background: linear-gradient(180deg, #fbfaf7 0%, #f4f0ea 100%);
}

body.home .display-title {
  max-width: 1120px;
  margin-right: auto;
  margin-left: auto;
}

body.home .section-title {
  max-width: 900px;
}

body.home .hero-lede,
body.home .section-lede {
  max-width: 760px;
  text-align: center;
}

body.home .home-hero-title .title-line,
body.home .home-hero-lede span {
  white-space: nowrap;
}

body.home .home-hero-lede {
  max-width: 980px;
}

body.home .container-wide > .demo-stage,
body.home .tabs .demo-stage {
  width: 100%;
  margin-top: 56px;
}

body.home .hero > .container-wide {
  padding-top: var(--hero-cta-module-gap);
}

body.home .container-wide > .hero-image-frame {
  width: 100%;
  margin: 0 auto;
}

body.home .tabs .challenge-image-frame {
  width: 100%;
  margin: 0;
}

body.home .tabs .industry-image-frame {
  width: 100%;
  margin: 0;
}

body.home .container-wide > .method-image-frame {
  width: 100%;
  margin: 56px auto 0;
}

body.home .container-wide > .case-flagship-image-frame {
  width: 100%;
  margin: 56px auto 0;
}

body.home .container-wide > .first-flow-image-frame {
  width: 100%;
  margin: 72px auto 0;
}

body.home .tabs .app-preview-image-frame {
  width: 100%;
  margin: 0;
}

body.home .tabs .app-preview-live-frame {
  width: 100%;
  margin: 0;
}

.hero-image-frame {
  overflow: hidden;
  border-radius: clamp(24px, 2.4vw, 40px);
}

.challenge-image-frame,
.industry-image-frame,
.method-image-frame,
.case-flagship-image-frame,
.first-flow-image-frame,
.app-preview-image-frame {
  overflow: hidden;
  border-radius: clamp(24px, 2.4vw, 40px);
}

.hero-image-frame picture,
.challenge-image-frame picture,
.industry-image-frame picture,
.method-image-frame picture,
.case-flagship-image-frame picture,
.first-flow-image-frame picture,
.app-preview-image-frame picture {
  display: block;
  width: 100%;
}

.hero-image-frame img,
.challenge-image-frame img,
.industry-image-frame img,
.method-image-frame img,
.case-flagship-image-frame img,
.first-flow-image-frame img,
.app-preview-image-frame img {
  display: block;
  width: 100%;
  height: auto;
}

.app-preview-live-frame {
  position: relative;
  aspect-ratio: 2360 / 1320;
  overflow: hidden;
  border-radius: clamp(24px, 2.4vw, 40px);
  background: var(--app-preview-bg);
  container-type: inline-size;
  isolation: isolate;
}

.app-preview-live-frame::before,
.app-preview-live-frame::after {
  position: absolute;
  content: "";
  pointer-events: none;
}

.app-preview-live-frame::before {
  inset: 0;
  z-index: 0;
  background: var(--app-preview-wash);
}

.app-preview-live-frame::after {
  right: -6.78%;
  bottom: -16.67%;
  z-index: 0;
  width: 32.2%;
  aspect-ratio: 1;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.42);
  filter: blur(20px);
}

.app-preview-live-stage {
  position: absolute;
  inset: 2.58% 0.85%;
  z-index: 1;
  overflow: hidden;
  border-radius: 2.63cqw;
  background: rgba(255, 255, 255, 0.08);
}

.app-preview-live-stage::before {
  position: absolute;
  inset: 0;
  opacity: 0.18;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, 0.6) 1px, transparent 1px) 0 0 / 3.73% 6.65%,
    linear-gradient(180deg, rgba(255, 255, 255, 0.54) 1px, transparent 1px) 0 0 / 3.73% 6.65%;
  content: "";
}

.app-preview-live-layout {
  position: absolute;
  inset: 5.75% 2.37% 5.75% 3.73%;
  z-index: 1;
  display: grid;
  grid-template-columns: 18.2% minmax(0, 1fr);
  gap: 3.56%;
  align-items: center;
}

.app-preview-summary {
  display: grid;
  align-content: center;
  gap: 1.02cqw;
}

.app-preview-summary h3 {
  margin: 0;
  color: #171717;
  font-family: var(--display);
  font-size: 3.64cqw;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 0.98;
}

.app-preview-lede {
  max-width: 100%;
  margin: -0.42cqw 0 0.17cqw;
  color: #555f6b;
  font-size: 1.19cqw;
  font-weight: 680;
  line-height: 1.48;
}

.app-preview-key-card {
  display: grid;
  gap: 0.59cqw;
  min-height: 6.86cqw;
  padding: 1.19cqw 1.27cqw;
  border-radius: 1.02cqw;
  background: #111111;
  color: #f8f6f0;
  box-shadow: 0 1.02cqw 2.46cqw rgba(17, 17, 17, 0.18);
}

.app-preview-key-card span {
  display: inline-flex;
  width: fit-content;
  min-height: 1.44cqw;
  align-items: center;
  gap: 0.42cqw;
  color: rgba(255, 255, 255, 0.74);
  font-size: 0.89cqw;
  font-weight: 840;
}

.app-preview-key-card span::before {
  width: 0.42cqw;
  height: 0.42cqw;
  border-radius: 999px;
  background: var(--app-preview-accent);
  content: "";
}

.app-preview-key-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.92);
  font-size: 1.06cqw;
  font-weight: 660;
  line-height: 1.48;
}

.app-preview-capability-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.59cqw;
}

.app-preview-capability-grid span {
  display: flex;
  min-height: 2.54cqw;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(24, 24, 24, 0.06);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
  color: #222222;
  font-size: 0.97cqw;
  font-weight: 850;
  box-shadow: 0 0.76cqw 1.61cqw rgba(45, 52, 70, 0.07);
}

.app-preview-flow-strip {
  display: grid;
  grid-template-columns: auto 1fr auto 1fr auto;
  align-items: center;
  gap: 0.51cqw;
  min-height: 3.14cqw;
  padding: 0.59cqw 0.76cqw;
  border-radius: 0.93cqw;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: inset 0 0 0 1px rgba(24, 24, 24, 0.05);
}

.app-preview-flow-strip span {
  display: inline-flex;
  min-width: 3.73cqw;
  min-height: 1.86cqw;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: var(--app-preview-soft);
  color: var(--app-preview-dark);
  font-size: 0.89cqw;
  font-weight: 900;
}

.app-preview-flow-strip i {
  height: 0.13cqw;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--app-preview-accent), rgba(255, 255, 255, 0.2));
}

.app-preview-screen {
  display: block;
  width: 100%;
  overflow: hidden;
  border-radius: 1.27cqw;
  box-shadow: 0 1.02cqw 2.88cqw rgba(22, 28, 42, 0.14);
}

.app-preview-screen img {
  display: block;
  width: 100%;
  height: auto;
}

.app-preview-growth {
  --app-preview-accent: #2563eb;
  --app-preview-dark: #1d4ed8;
  --app-preview-soft: #dbeafe;
  --app-preview-bg: #dfe8ff;
  --app-preview-wash:
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.58) 0 12%, transparent 13%),
    radial-gradient(circle at 83% 22%, rgba(196, 221, 255, 0.7), transparent 36%),
    linear-gradient(135deg, #dce7ff 0%, #edf4ff 44%, #d9f8ee 100%);
}

.app-preview-fran {
  --app-preview-accent: #10b981;
  --app-preview-dark: #047857;
  --app-preview-soft: #d1fae5;
  --app-preview-bg: #dff6ed;
  --app-preview-wash:
    radial-gradient(circle at 15% 20%, rgba(255, 255, 255, 0.62) 0 12%, transparent 13%),
    radial-gradient(circle at 84% 18%, rgba(191, 243, 213, 0.76), transparent 36%),
    linear-gradient(135deg, #e1f8ed 0%, #f5fbf4 48%, #dfeaff 100%);
}

.app-preview-ops {
  --app-preview-accent: #f97316;
  --app-preview-dark: #c2410c;
  --app-preview-soft: #ffedd5;
  --app-preview-bg: #ffe9d2;
  --app-preview-wash:
    radial-gradient(circle at 16% 19%, rgba(255, 255, 255, 0.62) 0 12%, transparent 13%),
    radial-gradient(circle at 84% 22%, rgba(255, 216, 170, 0.7), transparent 38%),
    linear-gradient(135deg, #ffe3c9 0%, #fff5ed 44%, #dff4ef 100%);
}

.app-preview-train {
  --app-preview-accent: #8b5cf6;
  --app-preview-dark: #6d28d9;
  --app-preview-soft: #ede9fe;
  --app-preview-bg: #efe5ff;
  --app-preview-wash:
    radial-gradient(circle at 15% 20%, rgba(255, 255, 255, 0.62) 0 12%, transparent 13%),
    radial-gradient(circle at 84% 20%, rgba(216, 197, 255, 0.72), transparent 36%),
    linear-gradient(135deg, #efe5ff 0%, #f9f4ff 45%, #ddf7ef 100%);
}

body.home .tabs .demo-stage {
  margin-top: 0;
}

.first-flow-image-frame.first-flow-live-text {
  position: relative;
  display: flex;
  flex-direction: column;
  aspect-ratio: 2360 / 1320;
  overflow: hidden;
  background:
    radial-gradient(circle at 16% 8%, rgba(255, 236, 224, 0.92), transparent 32%),
    radial-gradient(circle at 84% 82%, rgba(220, 248, 234, 0.86), transparent 34%),
    linear-gradient(115deg, #fff7f0 0%, #f8fbff 48%, #eefbf4 100%);
  isolation: isolate;
  user-select: text;
}

.first-flow-image-frame.first-flow-live-text::after {
  position: absolute;
  z-index: 2;
  top: calc(39.5% - 64px);
  right: 0;
  left: 0;
  height: 132px;
  pointer-events: none;
  background:
    radial-gradient(ellipse at 18% 52%, rgba(255, 247, 240, 0.58), transparent 62%),
    radial-gradient(ellipse at 82% 54%, rgba(230, 250, 240, 0.58), transparent 62%),
    linear-gradient(to bottom, transparent 0%, rgba(248, 251, 255, 0.42) 42%, rgba(246, 251, 248, 0.56) 58%, transparent 100%);
  content: "";
}

.first-flow-top-media {
  height: 39.5%;
  position: relative;
  z-index: 1;
  overflow: hidden;
  flex: 0 0 auto;
}

.first-flow-top-media picture,
.first-flow-top-media img {
  display: block;
  width: 100%;
}

.first-flow-top-media picture {
  -webkit-mask-image: linear-gradient(to bottom, #000 0 80%, rgba(0, 0, 0, 0.86) 92%, transparent 100%);
  mask-image: linear-gradient(to bottom, #000 0 80%, rgba(0, 0, 0, 0.86) 92%, transparent 100%);
}

.first-flow-top-media img {
  height: auto;
  pointer-events: none;
  user-select: none;
}

.first-flow-top-media::after {
  position: absolute;
  right: 0;
  bottom: -1px;
  left: 0;
  height: 108px;
  pointer-events: none;
  background:
    linear-gradient(to bottom, transparent 0%, rgba(248, 251, 255, 0.38) 54%, transparent 100%);
  content: "";
}

.first-flow-text-grid {
  position: relative;
  z-index: 3;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(52px, 5vw, 70px);
  flex: 1 1 auto;
  padding: clamp(36px, 3.4vw, 44px) clamp(58px, 5vw, 70px) clamp(32px, 3.2vw, 44px);
}

.first-flow-text-card {
  min-width: 0;
}

.first-flow-text-card h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(30px, 2.65vw, 34px);
  font-weight: 650;
  line-height: 1.08;
  letter-spacing: 0;
}

.first-flow-accent {
  display: block;
  width: 94px;
  height: 5px;
  margin-top: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--blue), rgba(37, 99, 235, 0.16));
}

.first-flow-local-text .first-flow-accent {
  background: linear-gradient(90deg, var(--green), rgba(7, 193, 96, 0.16));
}

.first-flow-text-card ul {
  display: grid;
  gap: clamp(22px, 2.1vw, 30px);
  margin: clamp(28px, 2.7vw, 36px) 0 0;
  padding: 0;
  list-style: none;
}

.first-flow-text-card li {
  position: relative;
  padding-left: 34px;
  color: var(--muted);
  font-size: clamp(17px, 1.48vw, 20px);
  font-weight: 650;
  line-height: 1.42;
  letter-spacing: 0;
  white-space: nowrap;
}

.first-flow-text-card li::before {
  position: absolute;
  left: 0;
  top: 0.54em;
  width: 14px;
  height: 14px;
  border: 5px solid rgba(37, 99, 235, 0.16);
  border-radius: 50%;
  background: var(--blue);
  box-sizing: border-box;
  content: "";
}

.first-flow-local-text li::before {
  border-color: rgba(7, 193, 96, 0.16);
  background: var(--green);
}

@media (max-width: 820px) {
  .first-flow-image-frame.first-flow-live-text {
    aspect-ratio: auto;
  }

  .first-flow-top-media {
    height: auto;
    aspect-ratio: 2360 / 540;
  }

  .first-flow-text-grid {
    grid-template-columns: 1fr;
    gap: 34px;
    padding: 32px 24px 42px;
  }

  .first-flow-text-card h3 {
    font-size: 34px;
  }

  .first-flow-text-card li {
    white-space: normal;
    font-size: 18px;
  }
}

body.home .hero-stage {
  min-height: clamp(580px, 49vw, 680px);
}

body.home .challenge-stage {
  min-height: clamp(520px, 44vw, 610px);
}

body.home .home-app-stage {
  min-height: clamp(540px, 46vw, 640px);
}

body.home .case-media {
  width: 100%;
  min-height: clamp(620px, 52vw, 720px);
  margin-top: 68px;
}

body.home .case-media-content h3 {
  max-width: 620px;
}

.stage-inner {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 0.9fr 1.35fr;
  gap: 70px;
  align-items: center;
  min-height: inherit;
  padding: 58px 64px;
}

body.home .challenge-stage .stage-inner {
  grid-template-columns: minmax(240px, 3fr) minmax(0, 7fr);
  gap: 36px;
  padding-inline: 52px;
}

body.home .home-app-stage .stage-inner {
  grid-template-columns: minmax(240px, 3fr) minmax(0, 7fr);
  gap: 36px;
  padding-inline: 48px;
}

body.home .challenge-stage .prompt-stack,
body.home .home-app-stage .prompt-stack {
  max-width: 360px;
}

body.home .challenge-stage .dashboard,
body.home .home-app-stage .dashboard {
  min-height: 430px;
}

body.home .home-app-stage .prompt-card {
  padding: 20px;
}

.stage-inner.centered {
  grid-template-columns: 1fr;
  place-items: center;
  padding: 70px;
}

.prompt-stack {
  display: grid;
  gap: 16px;
}

.prompt-card,
.dark-card {
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 16px;
  background: #111111;
  color: #f8f6f0;
  box-shadow: 0 18px 40px rgba(17, 17, 17, 0.18);
}

.prompt-card {
  padding: 24px;
}

.prompt-label,
.mini-label {
  margin: 0 0 10px;
  color: rgba(255, 255, 255, 0.74);
  font-size: 13px;
  font-weight: 800;
}

.prompt-card p,
.dark-card p {
  margin: 0;
  color: rgba(255, 255, 255, 0.74);
}

.file-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-top: 18px;
}

.file-tile {
  min-height: 112px;
  padding: 18px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  color: #f8f6f0;
}

.file-tile span {
  display: block;
  margin-top: 20px;
  color: rgba(255, 255, 255, 0.58);
  font-size: 12px;
}

.dashboard {
  overflow: hidden;
  border-radius: 20px;
  background: var(--paper);
  border: 1px solid var(--line);
  box-shadow: 0 22px 70px rgba(33, 29, 23, 0.16);
}

.dashboard-head {
  display: flex;
  justify-content: space-between;
  gap: 22px;
  padding: 24px 28px 16px;
  border-bottom: 1px solid var(--line);
}

.dashboard-title {
  margin: 0;
  font-family: var(--display);
  font-size: 28px;
  line-height: 1.1;
}

.dashboard-subtitle {
  margin: 4px 0 0;
  color: var(--muted);
  font-size: 14px;
}

.segmented {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  align-self: start;
  padding: 4px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: var(--paper-soft);
}

.segmented span {
  padding: 4px 12px;
  border-radius: 999px;
  color: var(--muted);
  font-size: 13px;
}

.segmented span.active {
  background: var(--paper);
  color: var(--ink);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
}

.metric-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 18px 28px 0;
}

.metric {
  padding: 14px 16px;
  border-radius: 12px;
  background: var(--paper-soft);
}

.metric small {
  display: block;
  color: var(--muted-2);
  font-size: 12px;
  text-transform: uppercase;
}

.metric strong {
  display: block;
  margin-top: 4px;
  font-size: 28px;
  line-height: 1.05;
}

.metric em {
  display: block;
  margin-top: 4px;
  color: var(--green);
  font-size: 13px;
  font-style: normal;
}

.chart-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 18px;
  padding: 18px 28px 28px;
}

.chart-card {
  min-height: 280px;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 14px;
}

.chart-title {
  margin: 0 0 16px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
  text-transform: uppercase;
}

.bar-chart {
  display: flex;
  align-items: end;
  gap: 16px;
  height: 205px;
  padding: 18px 8px 0;
  border-bottom: 1px solid var(--line);
}

.bar {
  flex: 1;
  min-width: 22px;
  border-radius: 7px 7px 0 0;
  background: rgba(7, 193, 96, 0.36);
}

.bar.strong {
  background: #1ea878;
}

.donut {
  width: 174px;
  height: 174px;
  margin: 10px auto 18px;
  border-radius: 50%;
  background: conic-gradient(var(--green) 0 38%, var(--purple) 38% 65%, var(--blue) 65% 86%, #c97910 86% 100%);
  position: relative;
}

.donut::after {
  content: "";
  position: absolute;
  inset: 42px;
  border-radius: 50%;
  background: var(--paper);
}

.legend {
  display: grid;
  grid-template-columns: repeat(2, max-content);
  justify-content: center;
  gap: 8px 18px;
  color: var(--muted);
  font-size: 12px;
}

.legend span::before {
  content: "";
  display: inline-block;
  width: 9px;
  height: 9px;
  margin-right: 6px;
  border-radius: 2px;
  background: var(--green);
}

.legend span:nth-child(2)::before {
  background: var(--purple);
}

.legend span:nth-child(3)::before {
  background: var(--blue);
}

.legend span:nth-child(4)::before {
  background: #c97910;
}

.tabs {
  margin-top: 74px;
}

.tab-list {
  display: flex;
  width: fit-content;
  max-width: 100%;
  margin: 0 auto 48px;
  padding: 6px;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: var(--paper-warm);
  scrollbar-width: none;
}

.tab-list::-webkit-scrollbar {
  display: none;
}

.tab-button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 46px;
  padding: 0 22px;
  border: 0;
  border-radius: 14px;
  background: transparent;
  color: var(--muted);
  font-weight: 750;
  white-space: nowrap;
}

.tab-button.active,
.tab-button[aria-selected="true"] {
  background: var(--paper);
  color: var(--ink);
  box-shadow: 0 3px 12px rgba(40, 35, 25, 0.08);
}

.tab-dot {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: currentColor;
}

.tab-panel {
  display: none;
}

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

.stage-caption {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 80px;
  width: min(1120px, calc(100% - 48px));
  margin: 34px auto 0;
}

.stage-caption h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 34px;
  line-height: 1.15;
}

.stage-caption p {
  margin: 0;
  padding-top: 5px;
  color: var(--muted);
  font-size: 19px;
  line-height: 1.6;
}

.caption-list {
  display: grid;
  gap: 10px;
  margin: 18px 0 0;
  padding: 0;
  color: var(--muted);
  list-style: none;
}

.caption-list li {
  position: relative;
  padding-left: 20px;
}

.caption-list li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.72em;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--ink);
}

.structured {
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 92px;
  align-items: start;
  margin-top: 92px;
}

.story-card {
  position: sticky;
  top: 100px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: 16px 18px 0 rgba(232, 228, 220, 0.42);
}

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

.story-visual {
  aspect-ratio: 16 / 10;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  overflow: hidden;
  border-radius: 14px;
  background: linear-gradient(135deg, var(--rose-soft), var(--orange-soft));
}

.play {
  width: 62px;
  height: 62px;
  border: 1px solid var(--line-strong);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  position: relative;
}

.play::before {
  content: "";
  position: absolute;
  left: 24px;
  top: 20px;
  border-left: 17px solid var(--ink);
  border-top: 11px solid transparent;
  border-bottom: 11px solid transparent;
}

.story-card p {
  margin: 0 0 20px;
  color: var(--muted);
}

.row-list {
  border-top: 1px solid var(--line);
}

.info-row {
  display: grid;
  grid-template-columns: minmax(220px, 0.9fr) minmax(0, 1.1fr);
  gap: 70px;
  padding: 48px 0;
  border-bottom: 1px solid var(--line);
}

.row-heading {
  display: flex;
  gap: 18px;
  align-items: flex-start;
}

.row-icon {
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  color: var(--muted);
}

.row-heading h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 29px;
  line-height: 1.1;
}

.info-row p {
  margin: 0;
  color: var(--muted);
  font-size: 22px;
  line-height: 1.45;
}

.solution-blocks {
  display: grid;
  gap: 32px;
  margin-top: 78px;
}

.industry-tabs {
  margin-top: 70px;
}

.industry-tabs .tab-list {
  margin-bottom: 34px;
}

.solution-block {
  display: grid;
  grid-template-columns: 0.88fr 1.12fr;
  gap: 72px;
  align-items: center;
  min-height: 470px;
  padding: 58px 64px;
  border: 1px solid var(--line);
  border-radius: 30px;
  background: rgba(255, 255, 255, 0.58);
}

.solution-block h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 44px;
  line-height: 1.08;
}

.solution-block p {
  color: var(--muted);
  font-size: 19px;
}

.flow-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 24px;
}

.mini-flow {
  display: grid;
  gap: 14px;
}

.flow-step {
  display: grid;
  grid-template-columns: 46px 1fr;
  gap: 16px;
  align-items: center;
  padding: 18px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--paper);
}

.flow-step strong {
  display: grid;
  place-items: center;
  width: 46px;
  height: 46px;
  border-radius: 999px;
  background: var(--paper-warm);
  color: var(--ink);
}

.industry-panel {
  grid-template-columns: 0.78fr 1.22fr;
  min-height: 560px;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: var(--shadow);
}

.industry-visual {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 24px;
  align-items: stretch;
  min-height: 390px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.72), var(--blue-soft));
}

.industry-visual.green {
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.72), var(--green-soft));
}

.industry-visual .mini-flow {
  align-content: center;
}

.industry-dashboard {
  display: grid;
  gap: 12px;
  align-content: center;
  min-height: 100%;
  padding: 18px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 20px;
  background:
    linear-gradient(var(--paper-soft) 0 0) 22px 24px / 50% 10px no-repeat,
    rgba(255, 255, 255, 0.74);
}

.industry-dashboard span {
  display: block;
  min-height: 78px;
  border-radius: 16px;
  background:
    linear-gradient(var(--paper) 0 0) 16px 20px / 54% 9px no-repeat,
    linear-gradient(var(--paper) 0 0) 16px 44px / 72% 7px no-repeat,
    rgba(255, 255, 255, 0.74);
  border: 1px solid rgba(20, 20, 20, 0.06);
}

.scenario-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 36px;
  margin-top: 70px;
}

.scenario-list {
  padding: 36px 40px;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}

.scenario-visual {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  min-height: 170px;
  margin-bottom: 32px;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: linear-gradient(135deg, var(--blue-soft), rgba(255, 255, 255, 0.74));
}

.scenario-visual.green {
  background: linear-gradient(135deg, var(--green-soft), rgba(255, 255, 255, 0.74));
}

.scenario-visual span {
  display: grid;
  place-items: end center;
  min-height: 126px;
  padding: 14px 8px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  background:
    linear-gradient(var(--paper) 0 0) 50% 24px / 52% 10px no-repeat,
    linear-gradient(var(--paper) 0 0) 50% 50px / 70% 7px no-repeat,
    rgba(255, 255, 255, 0.72);
  color: var(--ink-soft);
  font-weight: 850;
}

.scenario-list h3 {
  margin: 0 0 28px;
  font-family: var(--display);
  font-size: 34px;
}

.scenario-list ul {
  display: grid;
  gap: 16px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.scenario-list li {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  color: var(--muted);
  font-size: 18px;
}

.scenario-list li::before {
  content: "";
  flex: 0 0 auto;
  width: 10px;
  height: 10px;
  margin-top: 10px;
  border-radius: 50%;
  background: var(--ink);
}

.case-media {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 664px;
  margin-top: 82px;
  overflow: hidden;
  border-radius: var(--radius-xl);
  background: linear-gradient(135deg, #f7d7dd, #fff0dc 55%, #e5ecff);
  box-shadow: var(--shadow);
}

.case-media::before {
  content: "";
  position: absolute;
  inset: 8%;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 30px;
}

.case-media-content {
  position: relative;
  z-index: 1;
  width: min(860px, calc(100% - 60px));
  padding: 42px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 22px 80px rgba(24, 20, 16, 0.12);
}

.case-media-content h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 46px;
  line-height: 1.05;
}

.case-media-content p {
  max-width: 620px;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 20px;
}

.loop {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 28px;
}

.loop span {
  padding: 8px 12px;
  border-radius: 999px;
  background: var(--paper-warm);
  color: var(--ink-soft);
  font-size: 14px;
  font-weight: 700;
}

body.home .home-structured {
  grid-template-columns: 340px minmax(0, 1fr);
  gap: 82px;
  margin-top: 70px;
}

body.home .row-icon {
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 850;
  letter-spacing: 0;
}

body.home .story-card .btn {
  margin-top: 4px;
}

body.home .home-structured .story-card {
  padding: 24px;
  background: rgba(255, 255, 255, 0.76);
}

body.home .home-structured .info-row {
  grid-template-columns: minmax(210px, 0.74fr) minmax(0, 1.26fr);
  gap: 58px;
  padding: 42px 0;
}

body.home .home-structured .info-row p {
  max-width: 680px;
  font-size: 20px;
}

.method-visual {
  position: relative;
  min-height: 222px;
  background:
    linear-gradient(var(--paper) 0 0) 24px 24px / 42% 12px no-repeat,
    linear-gradient(var(--paper) 0 0) 24px 52px / 64% 8px no-repeat,
    linear-gradient(135deg, var(--rose-soft), var(--orange-soft));
}

.method-visual .play {
  z-index: 2;
}

.method-visual-lines {
  position: absolute;
  left: 18px;
  right: 18px;
  bottom: 18px;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.method-visual-lines span {
  display: grid;
  place-items: center;
  min-height: 38px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 800;
}

.case-media.flagship-media {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 42px;
  place-items: stretch;
  padding: 70px;
}

.case-media.flagship-media::before {
  inset: 7%;
}

.case-media.flagship-media .case-media-content {
  align-self: center;
  width: auto;
}

.case-media.flagship-media .case-media-content h3 {
  font-size: 42px;
}

.case-screens {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  grid-template-rows: 1fr 1fr 1fr;
  gap: 16px;
  align-content: center;
}

.case-screen {
  min-height: 132px;
  padding: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 18px 52px rgba(33, 29, 23, 0.08);
}

.case-screen.large {
  grid-row: 1 / 4;
  display: flex;
  min-height: 430px;
  flex-direction: column;
}

.case-screen small {
  display: block;
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 850;
}

.case-screen strong {
  display: block;
  margin-top: 12px;
  font-family: var(--display);
  font-size: 32px;
  line-height: 1.08;
}

.case-screen span {
  display: block;
  margin-top: 8px;
  color: var(--muted);
  font-size: 15px;
}

.skin-chart {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  margin-top: auto;
  padding-top: 32px;
}

.skin-chart i {
  display: block;
  min-height: 150px;
  border-radius: 16px;
  background: linear-gradient(180deg, var(--rose-soft), var(--paper));
}

.skin-chart i:nth-child(2) {
  min-height: 205px;
  background: linear-gradient(180deg, var(--orange-soft), var(--paper));
}

.skin-chart i:nth-child(3) {
  min-height: 125px;
  background: linear-gradient(180deg, var(--blue-soft), var(--paper));
}

.skin-chart i:nth-child(4) {
  min-height: 178px;
  background: linear-gradient(180deg, var(--green-soft), var(--paper));
}

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

.case-card {
  display: flex;
  min-height: 370px;
  flex-direction: column;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.72);
}

.card-thumb {
  min-height: 170px;
  margin: 0 0 22px;
  overflow: hidden;
  border-radius: 16px;
  background:
    linear-gradient(var(--paper) 0 0) 22px 24px / 46% 12px no-repeat,
    linear-gradient(var(--paper) 0 0) 22px 52px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--blue-soft), var(--green-soft));
  border: 1px solid var(--line);
}

.card-thumb.green {
  background:
    linear-gradient(var(--paper) 0 0) 22px 24px / 46% 12px no-repeat,
    linear-gradient(var(--paper) 0 0) 22px 52px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--green-soft), var(--paper-warm));
}

.card-thumb.orange {
  background:
    linear-gradient(var(--paper) 0 0) 22px 24px / 46% 12px no-repeat,
    linear-gradient(var(--paper) 0 0) 22px 52px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--orange-soft), var(--rose-soft));
}

.card-thumb.purple {
  background:
    linear-gradient(var(--paper) 0 0) 22px 24px / 46% 12px no-repeat,
    linear-gradient(var(--paper) 0 0) 22px 52px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--purple-soft), var(--blue-soft));
}

.case-card.hidden {
  display: none;
}

.case-card h3 {
  margin: 18px 0 12px;
  font-family: var(--display);
  font-size: 31px;
  line-height: 1.1;
}

.case-card p {
  margin: 0;
  color: var(--muted);
}

.case-card ul {
  display: grid;
  gap: 8px;
  margin: 20px 0 0;
  padding: 0;
  list-style: none;
  color: var(--muted);
  font-size: 15px;
}

.case-card .card-bottom {
  margin-top: auto;
  padding-top: 24px;
}

.filter-list {
  display: flex;
  width: fit-content;
  max-width: 100%;
  margin: 52px auto 0;
  padding: 6px;
  overflow-x: auto;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--paper-warm);
  scrollbar-width: none;
}

.filter-list::-webkit-scrollbar {
  display: none;
}

.filter-button {
  min-height: 44px;
  padding: 0 18px;
  border: 0;
  border-radius: 13px;
  background: transparent;
  color: var(--muted);
  font-weight: 750;
  white-space: nowrap;
}

.filter-button.active {
  background: var(--paper);
  color: var(--ink);
  box-shadow: 0 3px 12px rgba(40, 35, 25, 0.08);
}

.agent-hero {
  display: grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap: 86px;
  align-items: end;
  padding: 128px 0 108px;
}

.agent-hero .display-title {
  grid-column: 1 / -1;
  max-width: 1180px;
  text-align: left;
}

.line-network {
  min-height: 360px;
  position: relative;
}

.network-dot {
  position: absolute;
  width: 72px;
  height: 72px;
  border-radius: 50%;
  background: var(--orange);
}

.network-dot:nth-child(1) {
  left: 10%;
  top: 44%;
}

.network-dot:nth-child(2) {
  left: 34%;
  top: 9%;
}

.network-dot:nth-child(3) {
  left: 52%;
  top: 48%;
}

.network-dot:nth-child(4) {
  left: 74%;
  top: 24%;
}

.line-network svg {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  stroke: var(--orange);
  stroke-width: 14;
  fill: none;
  stroke-linecap: round;
}

.agent-copy {
  align-self: center;
}

.agent-copy p {
  margin: 0 0 30px;
  color: var(--muted);
  font-size: 24px;
  line-height: 1.48;
}

.method-card-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 62px;
}

.method-card {
  min-height: 240px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.7);
}

.method-card::before {
  content: "";
  display: block;
  min-height: 138px;
  margin-bottom: 22px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background:
    linear-gradient(var(--paper) 0 0) 18px 22px / 42% 10px no-repeat,
    linear-gradient(var(--paper) 0 0) 18px 48px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--blue-soft), var(--green-soft));
}

.method-card:nth-child(2)::before {
  background:
    linear-gradient(var(--paper) 0 0) 18px 22px / 42% 10px no-repeat,
    linear-gradient(var(--paper) 0 0) 18px 48px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--green-soft), var(--paper-warm));
}

.method-card:nth-child(3)::before {
  background:
    linear-gradient(var(--paper) 0 0) 18px 22px / 42% 10px no-repeat,
    linear-gradient(var(--paper) 0 0) 18px 48px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--orange-soft), var(--rose-soft));
}

.method-card:nth-child(4)::before {
  background:
    linear-gradient(var(--paper) 0 0) 18px 22px / 42% 10px no-repeat,
    linear-gradient(var(--paper) 0 0) 18px 48px / 68% 8px no-repeat,
    linear-gradient(135deg, var(--purple-soft), var(--blue-soft));
}

.method-card strong {
  display: block;
  margin-bottom: 18px;
  font-family: var(--display);
  font-size: 28px;
  line-height: 1.1;
}

.method-card p {
  margin: 0;
  color: var(--muted);
}

.process-list {
  display: grid;
  gap: 0;
  margin-top: 64px;
  border-top: 1px solid var(--line);
}

.process-item {
  display: grid;
  grid-template-columns: 100px 250px minmax(0, 1fr) 340px;
  gap: 28px;
  align-items: center;
  padding: 30px 0;
  border-bottom: 1px solid var(--line);
}

.process-item .num {
  font-family: var(--display);
  font-size: 54px;
  color: var(--muted-2);
}

.process-item h3 {
  margin: 0;
  font-family: var(--display);
  font-size: 34px;
}

.process-item p {
  margin: 0;
  color: var(--muted);
  font-size: 20px;
  line-height: 1.58;
}

.process-visual {
  position: relative;
  display: grid;
  height: 164px;
  min-height: 164px;
  overflow: hidden;
  padding: 22px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background:
    radial-gradient(circle at 86% 22%, color-mix(in srgb, var(--process) 16%, transparent), transparent 36%),
    linear-gradient(135deg, var(--process-soft), rgba(255, 255, 255, 0.84));
  box-shadow: 0 18px 44px rgba(34, 30, 25, 0.05);
}

.process-visual.green {
  --process: #20b978;
  --process-soft: var(--green-soft);
}

.process-visual.orange {
  --process: #f29a3b;
  --process-soft: var(--orange-soft);
}

.process-visual.purple {
  --process: #8b5cf6;
  --process-soft: var(--purple-soft);
}

.process-visual.rose {
  --process: #ee8dae;
  --process-soft: var(--rose-soft);
}

.process-visual.blue {
  --process: #3478f6;
  --process-soft: var(--blue-soft);
}

.process-visual::before {
  position: absolute;
  inset: 18px;
  border-radius: 18px;
  opacity: 0.36;
  background:
    linear-gradient(rgba(255, 255, 255, 0.78) 0 0) 0 0 / 100% 1px no-repeat,
    linear-gradient(90deg, rgba(255, 255, 255, 0.42), transparent);
  content: "";
}

.process-visual > span {
  position: relative;
  z-index: 1;
}

.process-visual i {
  position: relative;
  z-index: 1;
  display: block;
  background: var(--process);
}

.process-visual-diagnosis {
  grid-template-columns: 1.1fr 0.9fr;
  gap: 14px;
  align-items: stretch;
}

.diag-panel {
  border-radius: 18px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.94) 0 0) 18px 18px / 58% 10px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.78) 0 0) 18px 42px / 78% 8px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.68) 0 0) 18px 62px / 48% 8px no-repeat,
    rgba(255, 255, 255, 0.62);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.74);
}

.diag-panel i {
  position: absolute;
  left: 18px;
  right: 18px;
  height: 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--process) 22%, #fff);
}

.diag-panel i:nth-child(1) {
  bottom: 18px;
  width: 86%;
}

.diag-panel i:nth-child(2) {
  bottom: 40px;
  width: 64%;
  opacity: 0.68;
}

.diag-panel i:nth-child(3) {
  bottom: 62px;
  width: 76%;
  opacity: 0.48;
}

.diag-chart {
  display: flex;
  align-items: end;
  justify-content: center;
  gap: 9px;
  padding: 18px 14px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.58);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.diag-chart i {
  flex: 0 0 24px;
  border-radius: 999px 999px 7px 7px;
  background: var(--process);
}

.diag-chart i:nth-child(1) {
  height: 38px;
  opacity: 0.36;
}

.diag-chart i:nth-child(2) {
  height: 58px;
  opacity: 0.56;
}

.diag-chart i:nth-child(3) {
  height: 84px;
  opacity: 0.82;
}

.diag-target {
  position: absolute;
  right: 34px;
  top: 24px;
  width: 54px;
  height: 54px;
  border: 8px solid color-mix(in srgb, var(--process) 20%, #fff);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.62);
  box-shadow: 0 14px 28px rgba(52, 120, 246, 0.12);
}

.diag-target::before {
  position: absolute;
  inset: 11px;
  border: 2px solid color-mix(in srgb, var(--process) 34%, transparent);
  border-radius: 50%;
  content: "";
}

.diag-target i {
  position: absolute;
  right: -7px;
  top: 10px;
  width: 18px;
  height: 18px;
  border: 4px solid rgba(255, 255, 255, 0.82);
  border-radius: 50%;
}

.process-visual-breakdown {
  grid-template-columns: 1fr;
  gap: 14px;
  align-content: center;
}

.flow-map {
  position: relative;
  height: 72px;
}

.flow-map::before {
  position: absolute;
  left: 34px;
  right: 34px;
  top: 35px;
  height: 4px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--process) 20%, #fff);
  content: "";
}

.flow-map i {
  position: absolute;
  top: 13px;
  width: 48px;
  height: 48px;
  border-radius: 17px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.86) 0 0) 12px 14px / 24px 6px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.68) 0 0) 12px 28px / 18px 6px no-repeat,
    color-mix(in srgb, var(--process) 34%, #fff);
  box-shadow: 0 12px 24px rgba(34, 30, 25, 0.06);
}

.flow-map i:nth-child(1) {
  left: 0;
}

.flow-map i:nth-child(2) {
  left: 31%;
}

.flow-map i:nth-child(3) {
  right: 31%;
}

.flow-map i:nth-child(4) {
  right: 0;
}

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

.flow-rail i {
  height: 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--process) 12%, transparent);
}

.process-visual-skill {
  grid-template-columns: 1fr 94px;
  gap: 18px;
  align-items: center;
}

.skill-stack {
  position: relative;
  height: 112px;
}

.skill-stack i {
  position: absolute;
  left: 0;
  right: 0;
  height: 34px;
  border-radius: 16px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.9) 0 0) 20px 12px / 54% 8px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.58) 0 0) 20px 24px / 72% 5px no-repeat,
    color-mix(in srgb, var(--process) 16%, #fff);
  box-shadow: 0 12px 24px rgba(34, 30, 25, 0.05);
}

.skill-stack i:nth-child(1) {
  top: 0;
}

.skill-stack i:nth-child(2) {
  top: 36px;
  left: 18px;
}

.skill-stack i:nth-child(3) {
  top: 72px;
  left: 36px;
}

.skill-core {
  position: relative;
  width: 94px;
  height: 94px;
  border-radius: 50%;
  background:
    radial-gradient(circle at center, rgba(255, 255, 255, 0.96) 0 24%, transparent 25%),
    conic-gradient(from 20deg, color-mix(in srgb, var(--process) 70%, #fff), rgba(255, 255, 255, 0.72), color-mix(in srgb, var(--process) 28%, #fff), color-mix(in srgb, var(--process) 70%, #fff));
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.64), 0 18px 36px rgba(242, 154, 59, 0.14);
}

.skill-core i {
  position: absolute;
  width: 22px;
  height: 22px;
  border: 5px solid rgba(255, 255, 255, 0.78);
  border-radius: 50%;
}

.skill-core i:nth-child(1) {
  left: 8px;
  top: 20px;
}

.skill-core i:nth-child(2) {
  right: 10px;
  top: 32px;
}

.skill-core i:nth-child(3) {
  left: 36px;
  bottom: 8px;
}

.process-visual-apps {
  grid-template-columns: 1fr;
  gap: 14px;
  align-content: center;
}

.app-window {
  position: relative;
  height: 84px;
  border-radius: 18px;
  background:
    linear-gradient(color-mix(in srgb, var(--process) 22%, #fff) 0 0) 0 0 / 44px 100% no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.86) 0 0) 60px 18px / 60% 9px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.66) 0 0) 60px 40px / 44% 8px no-repeat,
    rgba(255, 255, 255, 0.68);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.app-window i {
  position: absolute;
  bottom: 14px;
  width: 38px;
  height: 24px;
  border-radius: 10px;
  background: color-mix(in srgb, var(--process) 24%, #fff);
}

.app-window i:nth-child(1) {
  left: 60px;
}

.app-window i:nth-child(2) {
  left: 108px;
  opacity: 0.7;
}

.app-window i:nth-child(3) {
  left: 156px;
  opacity: 0.48;
}

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

.app-dock i {
  height: 28px;
  border-radius: 12px;
  background: color-mix(in srgb, var(--process) 18%, #fff);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--process) 10%, transparent);
}

.app-dock i:nth-child(1) {
  background: color-mix(in srgb, #3478f6 24%, #fff);
}

.app-dock i:nth-child(2) {
  background: color-mix(in srgb, #20b978 24%, #fff);
}

.app-dock i:nth-child(3) {
  background: color-mix(in srgb, #f29a3b 24%, #fff);
}

.app-dock i:nth-child(4) {
  background: color-mix(in srgb, #8b5cf6 24%, #fff);
}

.process-visual-iteration {
  grid-template-columns: 0.78fr 1fr;
  gap: 18px;
  align-items: center;
}

.iteration-loop {
  position: relative;
  width: 98px;
  height: 98px;
  border: 9px solid color-mix(in srgb, var(--process) 24%, #fff);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.58);
}

.iteration-loop::before {
  position: absolute;
  right: -10px;
  top: 16px;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: var(--process);
  content: "";
}

.iteration-loop i {
  position: absolute;
  left: 25px;
  top: 31px;
  width: 38px;
  height: 22px;
  border-left: 7px solid var(--process);
  border-bottom: 7px solid var(--process);
  background: transparent;
  transform: rotate(-45deg);
}

.iteration-panel {
  position: relative;
  height: 106px;
  border-radius: 18px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.88) 0 0) 18px 18px / 58% 9px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.66) 0 0) 18px 41px / 78% 8px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.56) 0 0) 18px 64px / 46% 8px no-repeat,
    rgba(255, 255, 255, 0.62);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.72);
}

.iteration-panel i {
  position: absolute;
  bottom: 18px;
  width: 16px;
  border-radius: 999px;
  background: var(--process);
}

.iteration-panel i:nth-child(1) {
  left: 22px;
  height: 30px;
  opacity: 0.38;
}

.iteration-panel i:nth-child(2) {
  left: 50px;
  height: 48px;
  opacity: 0.58;
}

.iteration-panel i:nth-child(3) {
  left: 78px;
  height: 66px;
  opacity: 0.82;
}

.process-visual strong,
.process-visual small,
.process-visual em {
  position: relative;
  z-index: 1;
  letter-spacing: 0;
}

.process-visual strong {
  color: var(--ink);
  font-size: 16px;
  font-weight: 900;
  line-height: 1.15;
}

.process-visual small {
  display: block;
  color: var(--muted);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.2;
}

.process-visual em {
  font-style: normal;
  font-size: 13px;
  font-weight: 860;
  line-height: 1;
}

.process-visual-diagnosis {
  grid-template-columns: 116px 20px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

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

.diag-inputs em,
.flow-parts em,
.skill-sources em,
.app-screen em,
.iteration-kpis em {
  display: grid;
  place-items: center;
  min-height: 38px;
  border: 1px solid color-mix(in srgb, var(--process) 14%, transparent);
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.72);
  color: color-mix(in srgb, var(--process) 72%, #151515);
  box-shadow: 0 10px 22px rgba(34, 30, 25, 0.04);
}

.diag-arrow,
.skill-arrow {
  display: block;
  height: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--process) 34%, #fff);
}

.diag-arrow::after,
.skill-arrow::after {
  position: absolute;
  right: -1px;
  top: -4px;
  width: 0;
  height: 0;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 7px solid color-mix(in srgb, var(--process) 52%, #fff);
  content: "";
}

.diag-result {
  position: relative;
  min-height: 116px;
  padding: 18px 16px;
  overflow: hidden;
  border: 1px solid color-mix(in srgb, var(--process) 13%, transparent);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.62);
}

.diag-result::before {
  position: absolute;
  right: -24px;
  bottom: -30px;
  width: 84px;
  height: 84px;
  border: 12px solid color-mix(in srgb, var(--process) 22%, #fff);
  border-radius: 50%;
  content: "";
}

.diag-result i {
  width: 74px;
  height: 11px;
  margin-top: 20px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--process) 0 78%, color-mix(in srgb, var(--process) 12%, #fff) 78%);
}

.process-visual-breakdown {
  grid-template-columns: 58px minmax(0, 1fr) 64px;
  gap: 10px;
  align-items: center;
  align-content: stretch;
}

.flow-goal,
.flow-output,
.skill-result,
.app-agent,
.iteration-adjust {
  display: grid;
  place-items: center;
  min-height: 94px;
  border: 1px solid color-mix(in srgb, var(--process) 14%, transparent);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  color: color-mix(in srgb, var(--process) 72%, #151515);
  font-size: 15px;
  font-weight: 900;
  text-align: center;
  box-shadow: 0 12px 26px rgba(34, 30, 25, 0.04);
}

.flow-parts {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.flow-parts::before {
  position: absolute;
  left: -12px;
  right: -12px;
  top: 50%;
  z-index: 0;
  height: 3px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--process) 18%, #fff);
  content: "";
}

.flow-parts em {
  min-height: 42px;
}

.process-visual-skill {
  grid-template-columns: minmax(0, 1fr) 20px 88px;
  gap: 10px;
  align-items: center;
}

.skill-sources {
  display: grid;
  gap: 8px;
}

.skill-sources em {
  justify-content: start;
  min-height: 32px;
  padding-left: 14px;
}

.skill-result {
  min-height: 108px;
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.92) 0 42%, transparent 43%),
    conic-gradient(from 30deg, color-mix(in srgb, var(--process) 72%, #fff), color-mix(in srgb, var(--process) 18%, #fff), color-mix(in srgb, var(--process) 72%, #fff));
}

.skill-result strong {
  font-size: 18px;
}

.process-visual-apps {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  align-content: stretch;
}

.app-agent {
  min-height: 118px;
  border-radius: 20px;
  background:
    radial-gradient(circle at 50% 28%, color-mix(in srgb, var(--process) 42%, #fff) 0 19px, transparent 20px),
    rgba(255, 255, 255, 0.7);
  align-content: end;
  padding-bottom: 18px;
}

.app-screen {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-height: 118px;
  padding: 12px;
  border: 1px solid color-mix(in srgb, var(--process) 13%, transparent);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.66);
}

.app-screen strong {
  grid-column: 1 / -1;
  display: block;
  padding-bottom: 4px;
}

.app-screen em {
  min-height: 28px;
  font-size: 12px;
}

.app-screen em:nth-of-type(1) {
  color: #2563eb;
}

.app-screen em:nth-of-type(2) {
  color: #12a66a;
}

.app-screen em:nth-of-type(3) {
  color: #c66a11;
}

.app-screen em:nth-of-type(4) {
  color: #7c3aed;
}

.process-visual-iteration {
  grid-template-columns: minmax(0, 1fr) 56px 86px;
  gap: 10px;
  align-items: center;
}

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

.iteration-kpis em {
  min-height: 36px;
}

.iteration-loop {
  width: 56px;
  height: 56px;
  border-width: 6px;
  border-color: color-mix(in srgb, var(--process) 28%, #fff);
  background: rgba(255, 255, 255, 0.64);
}

.iteration-loop::before {
  right: -6px;
  top: 8px;
  width: 15px;
  height: 15px;
}

.iteration-loop i {
  left: 14px;
  top: 17px;
  width: 23px;
  height: 14px;
  border-left-width: 5px;
  border-bottom-width: 5px;
}

.iteration-adjust {
  min-height: 102px;
  padding: 10px;
}

.iteration-adjust strong {
  font-size: 15px;
}

.trust-cards span {
  display: block;
  min-height: 118px;
  padding: 22px;
  text-align: left;
}

.trust-cards strong {
  display: block;
  color: var(--ink);
  font-family: var(--display);
  font-size: 24px;
  line-height: 1.1;
}

.trust-cards em {
  display: block;
  margin-top: 12px;
  color: var(--muted);
  font-size: 14px;
  font-style: normal;
  font-weight: 500;
  line-height: 1.45;
}

.about-editorial {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 80px;
  align-items: start;
  margin-top: 72px;
}

.editorial-label {
  color: var(--muted);
  font-size: 14px;
  font-weight: 800;
}

.editorial-copy {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.16;
  letter-spacing: 0;
}

.editorial-columns {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 56px;
  margin-top: 76px;
}

.editorial-columns h3 {
  margin: 0 0 14px;
  font-family: var(--display);
  font-size: 34px;
}

.editorial-columns p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}

.contact-layout {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr;
  gap: 72px;
  align-items: start;
  margin-top: 80px;
}

.contact-panel {
  padding: 38px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
}

.contact-panel h2 {
  margin: 0 0 18px;
  font-family: var(--display);
  font-size: 42px;
  line-height: 1.1;
}

.contact-panel p {
  color: var(--muted);
}

.lead-form {
  display: grid;
  gap: 20px;
}

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

.field label {
  color: var(--ink-soft);
  font-weight: 750;
}

.field input,
.field select,
.field textarea {
  width: 100%;
  min-height: 50px;
  padding: 13px 14px;
  border: 1px solid var(--line-strong);
  border-radius: 12px;
  background: var(--paper);
  color: var(--ink);
}

.field textarea {
  min-height: 140px;
  resize: vertical;
}

.field input[aria-invalid="true"],
.field select[aria-invalid="true"],
.field textarea[aria-invalid="true"] {
  border-color: #c2410c;
}

.error-text {
  min-height: 18px;
  color: #c2410c;
  font-size: 13px;
}

.success-message {
  display: none;
  padding: 14px 16px;
  border-radius: 12px;
  background: var(--green-soft);
  color: #0f7a42;
  font-weight: 700;
}

.success-message.show {
  display: block;
}

.legal {
  width: min(860px, calc(100% - 48px));
  margin: 0 auto;
  padding: 96px 0 140px;
}

.legal h1 {
  margin: 0 0 42px;
  font-family: var(--display);
  font-size: clamp(48px, 7vw, 92px);
  line-height: 1.05;
}

.legal h2 {
  margin: 42px 0 12px;
  font-family: var(--display);
  font-size: 30px;
}

.legal p,
.legal li {
  color: var(--muted);
  font-size: 17px;
}

.site-footer {
  background: var(--black);
  color: #f7f4ee;
}

.footer-inner {
  width: min(var(--wide), calc(100% - 48px));
  margin: 0 auto;
  padding: 70px 0 42px;
}

.footer-grid {
  display: grid;
  grid-template-columns: 1.1fr repeat(5, 1fr);
  gap: 34px;
  padding: 0 0 54px;
}

.footer-brand {
  font-family: var(--display);
  font-size: 30px;
}

.footer-col h3 {
  margin: 0 0 14px;
  color: rgba(247, 244, 238, 0.92);
  font-size: 14px;
}

.footer-col a,
.footer-col span {
  display: block;
  margin: 9px 0;
  color: rgba(247, 244, 238, 0.58);
  font-size: 14px;
}

.footer-bottom {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  color: rgba(247, 244, 238, 0.46);
  font-size: 13px;
}

.footer-legal-lines {
  display: grid;
  gap: 6px;
}

.footer-bottom a {
  color: inherit;
  text-decoration: none;
}

.footer-language-link {
  display: inline-flex;
  min-height: 44px;
  align-items: center;
  gap: 10px;
  align-self: center;
  padding: 0 16px;
  border: 1px solid rgba(247, 244, 238, 0.15);
  border-radius: 16px;
  color: rgba(247, 244, 238, 0.76);
  font-size: 15px;
  font-weight: 650;
  white-space: nowrap;
}

.footer-language-link svg {
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.footer-language-link .footer-synva-logo {
  width: 28px;
  height: 28px;
  fill: none;
  stroke: none;
  filter: drop-shadow(0 3px 8px rgba(139, 92, 246, 0.26));
}

.footer-bottom a:hover {
  color: rgba(247, 244, 238, 0.72);
}

.footer-language-link:hover {
  border-color: rgba(247, 244, 238, 0.28);
  background: rgba(255, 255, 255, 0.05);
  color: rgba(247, 244, 238, 0.88);
}

.accent-blue {
  color: var(--blue);
}

.accent-green {
  color: var(--green);
}

.accent-orange {
  color: var(--orange);
}

.accent-purple {
  color: var(--purple);
}

@media (max-width: 1080px) {
  .stage-inner,
  .visual-panel,
  .solution-block,
  .structured,
  .agent-hero,
  .contact-layout,
  .about-editorial,
  .story-board,
  .challenge-board,
  .comparison-board,
  .flagship-media,
  .scenario-board {
    grid-template-columns: 1fr;
  }

  .visual-panel,
  .visual-panel.reverse {
    grid-template-columns: 1fr;
  }

  body.home .challenge-stage .stage-inner,
  body.home .home-app-stage .stage-inner {
    grid-template-columns: 1fr;
    gap: 34px;
    padding-inline: 40px;
  }

  body.home .challenge-stage .prompt-stack,
  body.home .home-app-stage .prompt-stack {
    max-width: none;
  }

  body.home .challenge-stage .dashboard,
  body.home .home-app-stage .dashboard {
    min-height: 360px;
  }

  body.home .hero-stage {
    min-height: 620px;
  }

  body.home .challenge-stage {
    min-height: 580px;
  }

  body.home .home-app-stage {
    min-height: 600px;
  }

  body.home .case-media {
    min-height: 660px;
  }

  .case-media.flagship-media {
    grid-template-columns: 1fr;
    padding: 52px 42px;
  }

  body.home .home-structured {
    grid-template-columns: 1fr;
    gap: 42px;
  }

  body.home .home-structured .info-row {
    grid-template-columns: minmax(190px, 0.8fr) minmax(0, 1.2fr);
  }

  .industry-panel,
  .industry-visual {
    grid-template-columns: 1fr;
  }

  .industry-dashboard {
    min-height: 220px;
  }

  .case-screens {
    grid-template-columns: 1fr 1fr;
  }

  .case-screen.large {
    grid-column: 1 / -1;
    grid-row: auto;
    min-height: 300px;
  }

  .visual-panel-copy,
  .visual-panel.reverse .visual-panel-copy {
    padding: 36px 36px 0;
  }

  .story-card {
    position: static;
  }

  .story-board {
    grid-template-areas:
      "command"
      "loop"
      "dashboard";
  }

  .method-map {
    grid-template-columns: 1fr;
  }

  .method-arrow,
  .flow-arrow {
    transform: rotate(90deg);
    justify-self: center;
  }

  .process-map,
  .trust-strip {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .case-grid,
  .method-card-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

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

@media (max-width: 820px) {
  .nav {
    width: min(100% - 36px, var(--wide));
  }

  .nav-toggle {
    display: block;
  }

  .nav-links {
    position: fixed;
    inset: 69px 0 auto 0;
    display: none;
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: 18px 24px 28px;
    border-bottom: 1px solid var(--line);
    background: var(--page);
  }

  .nav-links.mobile-open {
    display: flex;
  }

  .nav-links a {
    width: 100%;
    padding: 15px 0;
    border-bottom: 1px solid var(--line);
    color: var(--ink);
  }

  .nav-actions .btn {
    display: none;
  }

  .line-icon {
    display: none;
  }

  .section {
    padding: 96px 0;
  }

  body.home .home-band {
    padding-top: 96px;
    padding-bottom: 96px;
  }

  .section:first-child,
  .hero {
    padding-top: 82px;
  }

  body.home .hero {
    padding-bottom: 96px;
  }

  .container,
  .container-wide,
  .hero-narrow {
    width: min(100% - 40px, var(--max));
  }

  .display-title,
  .display-title.page-title {
    font-size: clamp(34px, 7.2vw, 42px);
    line-height: 1.12;
  }

  .section-title {
    font-size: clamp(30px, 7.6vw, 38px);
  }

  .hero-lede,
  .section-lede {
    font-size: 18px;
  }

  .hero-actions,
  .section-actions {
    flex-direction: column;
    align-items: stretch;
  }

  .btn {
    width: 100%;
  }

  .demo-stage {
    min-height: auto;
    margin-top: 54px;
    border-radius: 24px;
  }

  body.home .hero > .container-wide {
    padding-top: var(--hero-cta-module-gap);
  }

  .stage-inner {
    gap: 32px;
    padding: 34px 22px;
  }

  body.home .challenge-stage .stage-inner,
  body.home .home-app-stage .stage-inner {
    gap: 28px;
    padding-inline: 22px;
  }

  body.home .challenge-stage .dashboard,
  body.home .home-app-stage .dashboard {
    min-height: 320px;
  }

  body.home .stage-inner {
    min-height: auto;
    align-content: center;
  }

  body.home .hero-stage {
    min-height: 620px;
  }

  body.home .challenge-stage,
  body.home .home-app-stage {
    min-height: 560px;
  }

  body.home .case-media {
    min-height: 560px;
  }

  .case-media.flagship-media {
    padding: 28px 20px;
  }

  body.home .demo-stage .chart-grid {
    display: none;
  }

  body.home .file-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home .file-tile {
    min-height: 92px;
    padding: 14px;
  }

  body.home .prompt-card {
    padding: 20px;
  }

  body.home .metric-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .story-board,
  .challenge-board,
  .flagship-media {
    padding: 28px 20px;
  }

  .hero-story .story-board {
    gap: 16px;
  }

  .hero-story .command-card {
    padding: 22px;
  }

  .command-card h2,
  .pain-board h3,
  .comparison-pane h3,
  .scenario-board h3 {
    font-size: 30px;
  }

  .pain-grid,
  .app-bullets,
  .trust-strip,
  .process-map {
    grid-template-columns: 1fr;
  }

  .hero-story .growth-loop {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .hero-story .loop-node {
    min-height: 118px;
    padding: 14px;
  }

  .hero-story .loop-node strong {
    margin-top: 10px;
    font-size: 24px;
  }

  .hero-story .loop-node span {
    font-size: 12px;
  }

  .hero-story .story-dashboard .chart-grid {
    display: none;
  }

  .hero-story .story-dashboard .metric-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    padding: 14px 14px 18px;
  }

  .hero-story .story-dashboard .metric {
    padding: 10px 6px;
    text-align: center;
  }

  .hero-story .story-dashboard .metric strong {
    font-size: 20px;
  }

  .hero-story .story-dashboard .metric em {
    font-size: 11px;
  }

  .flow-board {
    grid-template-columns: 1fr;
  }

  .flow-column,
  .pain-board,
  .comparison-pane,
  .method-node,
  .process-map div {
    min-height: auto;
  }

  .method-node strong,
  .process-map strong {
    margin-top: 32px;
  }

  .system-visual,
  .scenario-flow {
    grid-template-columns: 1fr;
  }

  .system-visual span,
  .scenario-flow span {
    min-height: 72px;
  }

  .visual-panel {
    min-height: auto;
  }

  .visual-panel-copy h3 {
    font-size: 30px;
  }

  .mock-visual {
    min-height: 300px;
    margin: 20px;
  }

  .mock-phone-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .metric-row,
  .chart-grid,
  .scenario-grid,
  .editorial-columns,
  .stage-caption,
  .info-row,
  .process-item {
    grid-template-columns: 1fr;
  }

  body.home .home-structured .info-row {
    grid-template-columns: 1fr;
    gap: 16px;
  }

  body.home .home-structured .info-row p {
    font-size: 18px;
  }

  .method-visual {
    min-height: 190px;
  }

  .case-screens {
    grid-template-columns: 1fr;
  }

  .case-screen.large {
    min-height: 260px;
  }

  .skin-chart {
    align-items: end;
  }

  .skin-chart i {
    min-height: 88px;
  }

  .industry-panel {
    gap: 28px;
    min-height: auto;
  }

  .industry-visual {
    min-height: auto;
    padding: 20px;
  }

  .industry-dashboard {
    min-height: 180px;
  }

  .scenario-visual {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-height: auto;
  }

  .scenario-visual span {
    min-height: 86px;
  }

  .process-visual {
    min-height: 116px;
  }

  .trust-cards span {
    min-height: auto;
    padding: 18px;
  }

  .dashboard-head {
    flex-direction: column;
  }

  .metric-row,
  .chart-grid {
    padding-left: 18px;
    padding-right: 18px;
  }

  .dashboard-title {
    font-size: 22px;
  }

  .metric-row {
    gap: 8px;
  }

  .metric strong {
    font-size: 22px;
  }

  .chart-card {
    min-height: 220px;
  }

  .case-media {
    min-height: 520px;
  }

  .case-media-content {
    padding: 28px;
  }

  .case-media-content h3 {
    font-size: 34px;
  }

  .case-map div {
    min-height: 86px;
    font-size: 24px;
  }

  .case-grid,
  .method-card-grid {
    grid-template-columns: 1fr;
  }

  .agent-hero {
    gap: 44px;
    padding: 78px 0 80px;
  }

  .line-network {
    min-height: 260px;
  }

  .network-dot {
    width: 52px;
    height: 52px;
  }

  .agent-copy p {
    font-size: 19px;
  }

  .solution-block {
    min-height: auto;
    padding: 34px 24px;
  }

  .solution-block h3,
  .scenario-list h3,
  .editorial-columns h3 {
    font-size: 30px;
  }

  .process-item {
    gap: 12px;
    padding: 34px 0;
  }

  .process-item .num {
    font-size: 38px;
  }

  .about-editorial {
    gap: 28px;
  }

  .editorial-copy {
    font-size: 34px;
  }

  .footer-grid,
  .footer-bottom {
    grid-template-columns: 1fr;
  }

  .footer-bottom {
    display: grid;
  }

  .footer-inner {
    width: min(100% - 40px, var(--wide));
  }
}

@media (max-width: 560px) {
  .tab-list,
  .filter-list {
    width: 100%;
    justify-content: flex-start;
  }

  .tab-button,
  .filter-button {
    padding: 0 16px;
  }

  .file-grid,
  .metric-row {
    grid-template-columns: 1fr;
  }

  body.home .file-grid,
  body.home .metric-row {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.home .metric-row {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .split-lede span {
    display: inline;
  }

  body.home .home-hero-lede span {
    display: block;
  }

  .case-media.flagship-media {
    padding: 22px 16px;
  }

  .method-visual-lines {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .case-screen {
    min-height: auto;
    padding: 18px;
  }

  .case-screen strong {
    font-size: 26px;
  }

  .industry-visual,
  .scenario-visual {
    padding: 16px;
  }

  .industry-dashboard {
    min-height: 150px;
  }

  .scenario-visual span {
    min-height: 74px;
    font-size: 20px;
  }

  .process-visual {
    min-height: 96px;
  }

  .bar-chart {
    gap: 8px;
  }

  .bar {
    min-width: 12px;
  }
}

.products-page .product-hero {
  padding-bottom: 48px;
  background: linear-gradient(180deg, #f8fbff 0%, #f5fcf8 100%);
}

.products-page .product-overview-section {
  padding-top: 28px;
}

body.products-page .product-band {
  padding-top: 124px;
  padding-bottom: 124px;
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

body.products-page .product-band-overview {
  padding-top: 28px;
  border-top: 0;
  background: linear-gradient(180deg, #f5fcf8 0%, #f5fcf8 72%, #fbfaf7 100%);
}

body.products-page .product-band-architecture {
  background: linear-gradient(180deg, #fbfaf7 0%, #f6f2ec 54%, #fbfaf7 100%);
}

body.products-page .product-band-growth {
  background: linear-gradient(180deg, #f7fbff 0%, #f2f7ff 55%, #fbfaf7 100%);
}

body.products-page .product-band-fran {
  background: linear-gradient(180deg, #f7fcf5 0%, #f1faf0 55%, #fbfaf7 100%);
}

body.products-page .product-band-ops {
  background: linear-gradient(180deg, #fffaf2 0%, #fff5e9 55%, #fbfaf7 100%);
}

body.products-page .product-band-train {
  background: linear-gradient(180deg, #fbf9ff 0%, #f5f1ff 55%, #fbfaf7 100%);
}

body.products-page .product-band-final {
  background: linear-gradient(180deg, #fbfaf7 0%, #f4f0ea 100%);
}

.products-page .product-overview-section > .container {
  width: min(var(--wide), calc(100% - 48px));
}

.product-overview-frame {
  margin-top: 62px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  aspect-ratio: auto;
  box-shadow: none;
}

.product-system-grid {
  align-items: stretch;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 0;
}

.product-system-grid .method-card {
  min-height: auto;
}

.product-system-grid .product-overview-card {
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 18px;
  min-height: 532px;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: 0 26px 68px rgba(33, 29, 23, 0.09);
}

.product-system-grid .product-overview-card::before {
  display: none;
}

.method-card-media {
  display: block;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 20px;
  background: transparent;
  aspect-ratio: 6 / 5;
  box-shadow: 0 22px 54px rgba(33, 29, 23, 0.1);
}

.method-card-media img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.product-overview-copy {
  flex: 0 0 auto;
  min-height: 0;
  padding: 0 10px 2px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.product-overview-copy .tag {
  margin-bottom: 18px;
  background: rgba(255, 255, 255, 0.82);
}

.product-overview-copy strong {
  font-size: clamp(27px, 1.72vw, 34px);
}

.product-overview-copy p {
  font-size: 17px;
  line-height: 1.65;
}

@media (max-width: 1180px) {
  .product-overview-frame {
    aspect-ratio: auto;
  }

  .product-system-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  body.products-page .product-hero {
    padding-bottom: 48px;
  }

  body.products-page .product-band {
    padding-top: 96px;
    padding-bottom: 96px;
  }

  body.products-page .product-band-overview {
    padding-top: 28px;
    border-top: 0;
  }

  .products-page .product-overview-section > .container {
    width: min(100% - 32px, var(--max));
  }

  .product-overview-frame {
    padding: 22px;
  }

  .product-system-grid {
    grid-template-columns: 1fr;
  }
}

.product-architecture {
  padding-top: 124px;
}

.product-architecture > .container {
  width: min(var(--wide), calc(100% - 48px));
}

.architecture-flow {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
  margin-top: 66px;
}

.flow-card {
  min-height: 250px;
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 18px 52px rgba(33, 29, 23, 0.08);
}

.flow-card span {
  color: var(--muted-2);
  font-weight: 900;
}

.flow-card strong {
  display: block;
  margin-top: 54px;
  font-family: var(--display);
  font-size: 28px;
  line-height: 1.08;
}

.flow-card p {
  margin: 14px 0 0;
  color: var(--muted);
  font-size: 15px;
}

.skill-benchmark-stage {
  display: grid;
  grid-template-columns: 0.82fr 1.18fr 1fr;
  gap: 20px;
  margin-top: 68px;
  aspect-ratio: 2360 / 1320;
}

.benchmark-card {
  display: flex;
  min-height: 0;
  flex-direction: column;
  overflow: hidden;
  padding: clamp(24px, 2.2vw, 32px);
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 20px 60px rgba(33, 29, 23, 0.08);
}

.benchmark-card > span {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.04em;
}

.benchmark-card h3 {
  margin: 34px 0 0;
  font-family: var(--display);
  font-size: clamp(34px, 3vw, 42px);
  line-height: 1.08;
}

.benchmark-card p {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 17px;
  line-height: 1.55;
}

.problem-card {
  background: linear-gradient(135deg, var(--paper), var(--orange-soft));
}

.skill-card {
  background: #111111;
  color: #f8f6f0;
}

.skill-card span,
.skill-card p {
  color: rgba(248, 246, 240, 0.66);
}

.benchmark-metric {
  margin-top: auto;
  padding: 18px 20px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
}

.benchmark-metric small,
.benchmark-metric em {
  display: block;
  color: var(--muted);
  font-style: normal;
  font-weight: 750;
}

.benchmark-metric strong {
  display: block;
  margin: 10px 0;
  font-family: var(--display);
  font-size: clamp(18px, 1.38vw, 22px);
  line-height: 1.12;
  white-space: nowrap;
}

.practice-chain {
  display: grid;
  gap: 10px;
  margin-top: 40px;
}

.practice-chain div {
  display: flex;
  min-height: 50px;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 0 16px;
  border: 1px solid rgba(33, 29, 23, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
}

.practice-chain strong {
  color: var(--ink);
  font-size: 17px;
  font-weight: 900;
}

.practice-chain small {
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
}

.practice-chain i {
  display: block;
  width: 2px;
  height: 14px;
  margin-left: 24px;
  border-radius: 999px;
  background: rgba(33, 29, 23, 0.22);
}

.skill-source-map {
  display: grid;
  grid-template-columns: 0.92fr 1.08fr;
  gap: 12px;
  margin-top: 20px;
}

.skill-source-main,
.skill-source-grid div {
  border: 1px solid rgba(255, 255, 255, 0.14);
  background: rgba(255, 255, 255, 0.08);
}

.skill-source-main {
  display: flex;
  min-height: 0;
  flex-direction: column;
  justify-content: center;
  padding: 16px;
  border-radius: 18px;
}

.skill-source-main small,
.skill-source-main em {
  color: rgba(248, 246, 240, 0.58);
  font-style: normal;
  font-weight: 800;
}

.skill-source-main strong {
  display: block;
  margin: 6px 0;
  color: #f8f6f0;
  font-size: 20px;
  font-weight: 900;
  line-height: 1.15;
}

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

.skill-source-grid div {
  display: inline-flex;
  min-height: 50px;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  color: rgba(248, 246, 240, 0.88);
  font-size: 14px;
  font-weight: 900;
}

.skill-formula {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 10px;
  align-items: center;
  margin-top: 16px;
}

.skill-formula div {
  display: inline-flex;
  min-height: 42px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  color: #f8f6f0;
  font-size: 15px;
  font-weight: 900;
}

.skill-formula b {
  color: rgba(248, 246, 240, 0.42);
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.skill-stack {
  display: grid;
  gap: 9px;
  margin-top: 16px;
}

.skill-stack div {
  display: flex;
  min-height: 68px;
  flex-direction: column;
  justify-content: center;
  padding: 12px 18px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
}

.skill-stack strong {
  display: block;
  color: #f8f6f0;
  font-size: 18px;
}

.skill-stack small {
  display: block;
  margin-top: 5px;
  color: rgba(248, 246, 240, 0.62);
  font-size: 12.5px;
  line-height: 1.35;
}

.skill-loader {
  margin-top: 22px;
}

.skill-loader-core {
  padding: 16px 20px;
  border: 1px solid rgba(43, 105, 246, 0.14);
  border-radius: 20px;
  background:
    radial-gradient(circle at 10% 0%, rgba(43, 105, 246, 0.16), transparent 42%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(245, 249, 255, 0.86));
  box-shadow: 0 18px 44px rgba(43, 105, 246, 0.1);
}

.skill-loader-core small,
.skill-loader-core em {
  display: block;
  color: var(--muted);
  font-style: normal;
  font-weight: 800;
}

.skill-loader-core strong {
  display: block;
  margin: 6px 0;
  color: var(--ink);
  font-size: 22px;
  font-weight: 900;
}

.skill-loader-arrows {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  padding: 8px 20px 7px;
}

.skill-loader-arrows span {
  position: relative;
  display: block;
  width: 2px;
  height: 20px;
  margin: 0 auto;
  border-radius: 999px;
  background: rgba(43, 105, 246, 0.26);
}

.skill-loader-arrows span::after {
  position: absolute;
  right: 50%;
  bottom: -3px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: rgba(43, 105, 246, 0.44);
  content: "";
  transform: translateX(50%);
}

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

.app-skill-item {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  min-height: 108px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--ink);
  font-weight: 900;
}

.app-skill-item::before {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--blue);
  box-shadow: 0 0 0 6px rgba(43, 105, 246, 0.1);
  content: "";
}

.fran-skill::before {
  background: var(--green);
  box-shadow: 0 0 0 6px rgba(20, 184, 122, 0.1);
}

.ops-skill::before {
  background: var(--orange);
  box-shadow: 0 0 0 6px rgba(255, 139, 38, 0.12);
}

.train-skill::before {
  background: var(--purple);
  box-shadow: 0 0 0 6px rgba(137, 92, 246, 0.12);
}

.app-skill-item b {
  display: block;
  grid-column: 1 / -1;
  padding-right: 20px;
  font-size: 18px;
  line-height: 1;
}

.app-skill-item small {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(43, 105, 246, 0.08);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.fran-skill small {
  background: rgba(20, 184, 122, 0.1);
}

.ops-skill small {
  background: rgba(255, 139, 38, 0.1);
}

.train-skill small {
  background: rgba(137, 92, 246, 0.1);
}

.execution-pipeline {
  display: grid;
  grid-template-columns: 1fr auto 1fr auto 1fr;
  gap: 8px;
  align-items: center;
  margin-top: auto;
  padding-top: 12px;
}

.execution-pipeline span {
  display: inline-flex;
  min-height: 38px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #111111;
  color: #f8f6f0;
  font-size: 13px;
  font-weight: 900;
}

.execution-pipeline i {
  width: 16px;
  height: 2px;
  border-radius: 999px;
  background: rgba(33, 29, 23, 0.24);
}

.product-module {
  position: relative;
  scroll-margin-top: 96px;
}

.product-module + .product-module {
  padding-top: 124px;
}

.product-growth .section-title {
  max-width: 1180px;
  font-size: clamp(24px, 4.45vw, 58px);
  white-space: nowrap;
}

.module-eyebrow {
  display: flex;
  width: fit-content;
  min-height: 34px;
  align-items: center;
  margin: 0 auto 18px;
  padding: 0 14px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--muted);
  font-size: 14px;
  font-weight: 850;
}

.product-showcase {
  margin-top: 54px;
}

.product-tab-list {
  margin-bottom: 30px;
}

.product-stage {
  display: grid;
  grid-template-columns: minmax(230px, 0.34fr) minmax(0, 1fr);
  gap: 18px;
  height: 820px;
  min-height: 820px;
  padding: 22px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 30px;
  background:
    radial-gradient(circle at 12% 18%, rgba(255, 255, 255, 0.54) 0 14%, transparent 15%),
    linear-gradient(135deg, #dfe8ff, #eef6ff 46%, #d9f8ee);
  box-shadow: var(--shadow);
}

.product-task-panel,
.product-visual-panel {
  position: relative;
  z-index: 1;
}

.product-task-panel {
  display: flex;
  min-height: 100%;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  padding: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.64);
  backdrop-filter: blur(14px);
}

.product-kicker {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}

.product-task-panel h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(28px, 2.4vw, 38px);
  line-height: 1.08;
}

.task-panel-copy {
  display: grid;
  gap: 16px;
}

.product-task-panel > p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.5;
}

.task-panel-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.55;
}

.matrix-task-panel {
  justify-content: flex-start;
}

.matrix-task-panel .task-panel-copy {
  gap: 13px;
}

.matrix-decision-map {
  display: grid;
  gap: 14px;
  margin: 4px 0 2px;
}

.matrix-task-panel .matrix-decision-map {
  flex: 1;
  align-content: start;
  margin-top: 0;
}

.matrix-overview-card {
  padding: 18px;
  border: 1px solid rgba(47, 102, 234, 0.16);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(239, 246, 255, 0.78));
  box-shadow: 0 18px 42px rgba(47, 102, 234, 0.12);
}

.matrix-overview-card small {
  display: block;
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 900;
}

.matrix-overview-card strong {
  display: block;
  margin-top: 8px;
  color: var(--ink);
  font-size: 18px;
  line-height: 1.34;
}

.matrix-mini-bars {
  display: grid;
  grid-template-columns: 0.6fr 0.9fr 1.2fr 0.8fr;
  align-items: end;
  gap: 8px;
  height: 56px;
  margin-top: 16px;
}

.matrix-mini-bars i {
  display: block;
  border-radius: 12px 12px 8px 8px;
  background: linear-gradient(180deg, rgba(47, 102, 234, 0.9), rgba(47, 102, 234, 0.18));
}

.matrix-mini-bars i:nth-child(1) {
  height: 38%;
}

.matrix-mini-bars i:nth-child(2) {
  height: 68%;
}

.matrix-mini-bars i:nth-child(3) {
  height: 100%;
}

.matrix-mini-bars i:nth-child(4) {
  height: 54%;
}

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

.matrix-signal-card {
  min-height: 76px;
  padding: 14px;
  border: 1px solid rgba(47, 102, 234, 0.13);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 14px 34px rgba(47, 102, 234, 0.08);
}

.matrix-signal-card small {
  display: block;
  margin-bottom: 8px;
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 850;
}

.matrix-signal-card strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.35;
}

.matrix-signal-card.accent {
  border-color: rgba(255, 126, 32, 0.28);
  background: rgba(255, 247, 237, 0.88);
}

.matrix-route {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 26px minmax(0, 1fr) 26px minmax(0, 1fr);
  align-items: center;
  padding: 12px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.58);
}

.matrix-route span {
  min-width: 0;
  color: #2f66ea;
  font-size: 13px;
  font-weight: 900;
  text-align: center;
  white-space: nowrap;
}

.matrix-route i {
  display: block;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(47, 102, 234, 0.24), rgba(47, 102, 234, 0.88));
}

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

.matrix-action-row div {
  min-width: 0;
  padding: 12px 10px;
  border-radius: 14px;
  background: rgba(17, 17, 17, 0.9);
  color: #fff;
}

.matrix-action-row b,
.matrix-action-row em {
  display: block;
  text-align: center;
}

.matrix-action-row b {
  font-size: 14px;
  line-height: 1.1;
}

.matrix-action-row em {
  margin-top: 6px;
  color: rgba(255, 255, 255, 0.66);
  font-size: 11px;
  font-style: normal;
  line-height: 1.25;
}

.product-task-panel .prompt-card {
  margin-top: auto;
  padding: 18px;
}

.product-task-panel .prompt-label {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  margin-bottom: 12px;
  padding: 0 12px;
  border: 1px solid rgba(255, 255, 255, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
}

.product-visual-panel {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 18px;
  min-width: 0;
}

.shot-screen {
  position: relative;
  min-height: 670px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: var(--paper);
  box-shadow: 0 24px 80px rgba(33, 29, 23, 0.16);
}

.shot-screen::before {
  content: "";
  position: absolute;
  inset: 0;
  opacity: 0.52;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px) 0 0 / 42px 42px,
    linear-gradient(180deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px) 0 0 / 42px 42px;
  pointer-events: none;
}

.shot-screen.has-real-shot {
  background: #f7f9fb;
}

.shot-screen.has-real-shot::before {
  content: none;
}

.shot-real-image {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}

.screen-frame {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto 1fr;
  min-height: inherit;
}

.screen-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--line);
}

.screen-kicker {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: var(--paper-warm);
  color: var(--muted);
  font-size: 12px;
  font-weight: 850;
}

.screen-dots {
  display: inline-flex;
  gap: 7px;
}

.screen-dots i {
  width: 9px;
  height: 9px;
  border-radius: 999px;
  background: var(--line-strong);
}

.screen-title-area {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 18px;
  padding: 22px 26px 0;
}

.screen-title-area h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(24px, 2vw, 32px);
  line-height: 1.08;
}

.screen-toolbar {
  display: inline-flex;
  gap: 8px;
  flex-shrink: 0;
}

.screen-toolbar i {
  width: 74px;
  height: 30px;
  border-radius: 999px;
  background: var(--paper-warm);
}

.screen-toolbar i:last-child {
  width: 42px;
  background: var(--ink);
}

.screen-workspace {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 16px;
  padding: 20px 26px 26px;
}

.screen-workspace.has-screen-shot {
  display: block;
  min-height: 0;
  height: 566px;
  padding: 20px 26px 26px;
  overflow: hidden;
  border-radius: 18px;
  border: 0;
  background: transparent;
}

.screen-workspace-image {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 0;
  max-height: 100%;
  border-radius: 18px;
  object-fit: cover;
  object-position: top center;
  background: #f7f9fb;
}

.screen-sidebar {
  display: grid;
  gap: 10px;
  align-content: start;
  min-height: 520px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--paper-soft);
}

.screen-sidebar span {
  min-height: 38px;
  padding: 9px 10px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.74);
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

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

.screen-metric {
  min-height: 76px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.78);
}

.screen-metric small {
  display: block;
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 850;
}

.screen-metric strong {
  display: block;
  margin-top: 8px;
  color: var(--ink);
  font-size: 24px;
  line-height: 1;
}

.screen-body {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-items: stretch;
  padding: 16px 0 0;
}

.screen-graphic {
  position: relative;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 12px;
  min-height: 330px;
  padding: 18px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--paper-soft);
}

.screen-graphic i {
  display: block;
  align-self: end;
  min-height: 54px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.78), rgba(37, 99, 235, 0.2));
}

.screen-graphic i:nth-child(2) {
  min-height: 118px;
}

.screen-graphic i:nth-child(3) {
  min-height: 168px;
}

.screen-graphic i:nth-child(4) {
  min-height: 92px;
}

.screen-graphic i:nth-child(5),
.screen-graphic i:nth-child(6),
.screen-graphic i:nth-child(7),
.screen-graphic i:nth-child(8) {
  min-height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.9);
}

.screen-list {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  align-content: start;
  margin: 0;
  padding: 0;
  list-style: none;
}

.screen-list li {
  min-height: 60px;
  padding: 13px 14px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink-soft);
  font-size: 14px;
  font-weight: 750;
}

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

.shot-button {
  min-height: 58px;
  padding: 10px 12px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.64);
  color: var(--muted);
  font-weight: 850;
  text-align: left;
  transition: background 160ms ease, color 160ms ease, transform 160ms ease, border 160ms ease;
}

.shot-button:hover {
  transform: translateY(-1px);
}

.shot-button.active {
  border-color: rgba(17, 17, 17, 0.18);
  background: var(--black);
  color: var(--white);
}

.product-fran .product-stage {
  grid-template-columns: minmax(230px, 0.34fr) minmax(0, 1fr);
  background:
    radial-gradient(circle at 86% 18%, rgba(255, 255, 255, 0.56) 0 12%, transparent 13%),
    linear-gradient(135deg, #dff7e9, #eef8ff 54%, #f9edc5);
}

.product-ops .product-stage {
  grid-template-columns: minmax(230px, 0.34fr) minmax(0, 1fr);
  background:
    radial-gradient(circle at 18% 80%, rgba(255, 255, 255, 0.56) 0 14%, transparent 15%),
    linear-gradient(135deg, #ffe2c4, #effbff 52%, #ffe9d8);
}

.product-train .product-stage {
  grid-template-columns: minmax(230px, 0.34fr) minmax(0, 1fr);
  background:
    radial-gradient(circle at 16% 20%, rgba(255, 255, 255, 0.56) 0 13%, transparent 14%),
    linear-gradient(135deg, #ebe1ff, #e8f8e5 54%, #e2efff);
}

.product-fran .screen-graphic i {
  background: linear-gradient(180deg, rgba(7, 193, 96, 0.82), rgba(7, 193, 96, 0.2));
}

.product-ops .screen-graphic i {
  background: linear-gradient(180deg, rgba(255, 140, 0, 0.84), rgba(255, 140, 0, 0.2));
}

.product-train .screen-graphic i {
  background: linear-gradient(180deg, rgba(124, 58, 237, 0.78), rgba(124, 58, 237, 0.2));
}

.product-fran [data-screen-type="pipeline"] .screen-graphic,
.product-fran [data-screen-type="event"] .screen-graphic,
.product-fran [data-screen-type="approval"] .screen-graphic {
  grid-template-columns: 1fr;
}

.product-fran [data-screen-type="pipeline"] .screen-graphic i,
.product-fran [data-screen-type="event"] .screen-graphic i,
.product-fran [data-screen-type="approval"] .screen-graphic i {
  min-height: 36px;
  border-radius: 999px;
}

.product-ops [data-screen-type="calendar"] .screen-graphic,
.product-ops [data-screen-type="board"] .screen-graphic,
.product-ops [data-screen-type="templates"] .screen-graphic {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.product-ops [data-screen-type="calendar"] .screen-graphic i,
.product-ops [data-screen-type="board"] .screen-graphic i,
.product-ops [data-screen-type="templates"] .screen-graphic i {
  min-height: 72px;
  border-radius: 16px;
}

.product-train [data-screen-type="map"] .screen-graphic,
.product-train [data-screen-type="ability"] .screen-graphic,
.product-train [data-screen-type="role-switch"] .screen-graphic,
.product-train [data-screen-type="skill-folder"] .screen-graphic {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.product-train [data-screen-type="map"] .screen-graphic i,
.product-train [data-screen-type="ability"] .screen-graphic i,
.product-train [data-screen-type="role-switch"] .screen-graphic i,
.product-train [data-screen-type="skill-folder"] .screen-graphic i {
  min-height: 98px;
  border-radius: 18px;
}

.final-product-cta {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(244, 240, 234, 0.82));
}

.home-final-cta .trust-cards {
  margin-top: 54px;
}

.home-final-cta .section-actions {
  margin-top: 42px;
}

.cases-page .display-title.page-title {
  max-width: 1120px;
  margin-right: auto;
  margin-left: auto;
  font-size: clamp(50px, 5.8vw, 86px);
  line-height: 1.08;
}

.cases-page .section-title {
  font-size: clamp(42px, 4.8vw, 70px);
}

.case-hero {
  padding-bottom: 48px;
}

.growth-keys-section {
  padding-top: 28px;
  padding-bottom: 124px;
  background: transparent;
}

.cases-page .final-product-cta {
  padding-top: 124px;
  padding-bottom: 124px;
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

.growth-keys {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 62px;
}

.growth-keys article {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 260px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 48px rgba(33, 29, 23, 0.05);
}

.growth-keys span,
.case-action-grid span,
.case-strategy-panel > span,
.robot-command > span,
.agent-execution-panel > span,
.vision-note > span,
.knowledge-stack-panel > span {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.growth-keys strong {
  display: block;
  margin-top: auto;
  font-family: var(--display);
  font-size: 31px;
  line-height: 1.06;
}

.growth-keys p,
.case-summary-card p,
.case-strategy-panel p,
.case-action-grid p,
.robot-command p,
.vision-note p,
.knowledge-stack-panel p {
  margin: 14px 0 0;
  color: var(--muted);
}

.case-study {
  border-top: 1px solid var(--line);
  overflow: hidden;
}

.case-lizi {
  background: linear-gradient(180deg, #fff8f6 0%, #f6ecef 46%, #fffaf2 100%);
}

.case-robot {
  background: linear-gradient(180deg, #f2f7fb 0%, #eef3f7 48%, #fbfaf7 100%);
}

.case-beauty {
  background: linear-gradient(180deg, #f5fbf4 0%, #fff3f7 50%, #fbfaf7 100%);
}

.case-vision {
  background: linear-gradient(180deg, #eef8ff 0%, #f1fbf4 52%, #fbfaf7 100%);
}

.case-edu {
  background: linear-gradient(180deg, #fffaf0 0%, #f2f0ff 52%, #fbfaf7 100%);
}

.case-heading {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 370px);
  gap: 44px;
  align-items: end;
}

.case-heading-centered {
  display: block;
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
}

.case-heading-centered .case-heading-copy {
  display: grid;
  justify-items: center;
}

.case-label-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-bottom: 18px;
}

.case-label-row .module-eyebrow,
.case-label-row .status-badge {
  margin: 0;
  min-height: 34px;
}

.case-heading-centered .section-title {
  max-width: 1180px;
  margin: 0 auto;
}

.case-heading-lede {
  max-width: 860px;
  margin-top: 22px;
}

.case-summary-card {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 18px 48px rgba(33, 29, 23, 0.05);
}

.case-summary-card .status-badge {
  margin-bottom: 18px;
}

.case-theater {
  display: grid;
  gap: 26px;
  min-height: 650px;
  margin-top: 66px;
  padding: 28px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 32px;
  box-shadow: var(--shadow);
}

.case-strategy-panel,
.robot-command,
.trial-dashboard,
.agent-execution-panel,
.vision-note,
.knowledge-stack-panel,
.advisor-workflow {
  min-width: 0;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.74);
}

.case-strategy-panel,
.robot-command,
.agent-execution-panel,
.vision-note,
.knowledge-stack-panel {
  padding: 34px;
}

.case-strategy-panel.dark {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  background: #111111;
  color: #f8f6f0;
}

.case-strategy-panel.dark p,
.case-strategy-panel.dark > span {
  color: rgba(248, 246, 240, 0.72);
}

.case-strategy-panel h3,
.robot-command h3,
.agent-execution-panel h3,
.vision-note h3,
.knowledge-stack-panel h3 {
  margin: 18px 0 0;
  font-family: var(--display);
  font-size: clamp(34px, 3.8vw, 52px);
  line-height: 1.02;
}

.signal-list {
  display: grid;
  gap: 10px;
  margin-top: 38px;
}

.signal-list strong {
  margin-bottom: 4px;
  color: #f8f6f0;
  font-size: 14px;
}

.signal-list span {
  padding: 14px 16px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.11);
  color: #f8f6f0;
  font-weight: 800;
}

.lizi-theater {
  grid-template-columns: minmax(270px, 0.78fr) minmax(0, 1.22fr);
  background:
    radial-gradient(circle at 80% 20%, rgba(255, 255, 255, 0.9), transparent 32%),
    linear-gradient(135deg, #f5d8de 0%, #fff3dc 50%, #e5f0ff 100%);
}

.lizi-loop-board {
  position: relative;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  grid-template-rows: repeat(6, minmax(58px, 1fr));
  min-height: 594px;
  gap: 24px;
}

.loop-step {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-width: 0;
  padding: 20px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 42px rgba(33, 29, 23, 0.08);
}

.loop-step strong {
  color: var(--muted-2);
  font-size: 14px;
}

.loop-step span {
  margin: 0;
  font-family: var(--display);
  color: var(--ink);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.02;
}

.loop-step small {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.loop-step.entrance {
  grid-column: 1 / 4;
  grid-row: 1 / 3;
  background: rgba(255, 246, 228, 0.86);
}

.loop-step.trust {
  grid-column: 4 / 7;
  grid-row: 1 / 3;
  background: rgba(255, 236, 241, 0.86);
}

.loop-step.asset {
  grid-column: 2 / 6;
  grid-row: 3 / 5;
  background: #111111;
}

.loop-step.asset strong,
.loop-step.asset span,
.loop-step.asset small {
  color: #f8f6f0;
}

.loop-step.retention {
  grid-column: 1 / 4;
  grid-row: 5 / 7;
  background: rgba(232, 244, 255, 0.88);
}

.loop-step.scale {
  grid-column: 4 / 7;
  grid-row: 5 / 7;
  background: rgba(236, 248, 231, 0.9);
}

.case-action-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.case-action-grid article {
  display: grid;
  align-content: start;
  min-height: 250px;
  padding: 28px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 16px 44px rgba(33, 29, 23, 0.05);
}

.case-action-grid strong {
  display: block;
  margin-top: 42px;
  font-family: var(--display);
  font-size: 31px;
  line-height: 1.06;
}

.robot-theater {
  grid-template-columns: minmax(280px, 0.82fr) minmax(0, 1.18fr);
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(222, 235, 244, 0.98), rgba(247, 250, 250, 0.92)),
    #eef3f7;
}

.robot-command {
  display: grid;
  align-content: space-between;
}

.robot-scenes {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 34px;
}

.robot-scenes span {
  min-height: 62px;
  padding: 15px;
  border-radius: 16px;
  background: rgba(17, 17, 17, 0.06);
  color: var(--ink-soft);
  font-weight: 850;
}

.trial-dashboard {
  display: grid;
  grid-template-rows: auto 1fr 190px;
  gap: 18px;
  padding: 24px;
}

.trial-metrics {
  display: grid;
  gap: 12px;
  align-content: stretch;
}

.trial-metrics div {
  display: grid;
  align-content: space-between;
  min-height: 106px;
  padding: 18px;
  border-radius: 18px;
  background: #111111;
  color: #f8f6f0;
}

.trial-metrics small {
  color: rgba(248, 246, 240, 0.62);
}

.trial-metrics strong {
  margin-top: 14px;
  font-family: var(--display);
  font-size: 26px;
  line-height: 1.1;
}

.trial-bars {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: end;
  gap: 12px;
  padding: 18px;
  border-radius: 20px;
  background: rgba(17, 17, 17, 0.05);
}

.trial-bars i {
  display: block;
  border-radius: 14px 14px 6px 6px;
  background: #6c8798;
}

.trial-bars i:nth-child(1) {
  height: 42%;
}

.trial-bars i:nth-child(2) {
  height: 68%;
}

.trial-bars i:nth-child(3) {
  height: 86%;
}

.trial-bars i:nth-child(4) {
  height: 55%;
}

.trial-bars i:nth-child(5) {
  height: 76%;
}

.store-theater {
  grid-template-columns: minmax(0, 1.08fr) minmax(300px, 0.92fr);
  background: linear-gradient(135deg, #e5f7e8 0%, #fff0f5 54%, #f7faf5 100%);
}

.store-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.store-board div {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 276px;
  padding: 24px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.76);
}

.store-board strong {
  color: var(--muted-2);
  font-size: 14px;
}

.store-board span {
  font-family: var(--display);
  color: var(--ink);
  font-size: clamp(30px, 3.4vw, 46px);
  line-height: 1.02;
}

.store-board small {
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.agent-execution-panel {
  display: grid;
  align-content: start;
}

.queue-list {
  display: grid;
  gap: 12px;
  margin-top: 34px;
}

.queue-list p {
  margin: 0;
  padding: 18px;
  border-radius: 16px;
  background: #111111;
  color: #f8f6f0;
  font-weight: 760;
}

.queue-list strong {
  display: inline-block;
  min-width: 54px;
  color: rgba(248, 246, 240, 0.62);
}

.vision-theater {
  display: grid;
  grid-template-columns: minmax(0, 1.22fr) minmax(280px, 0.78fr);
  align-items: stretch;
  background: linear-gradient(135deg, #def0ff 0%, #e9f8ea 58%, #fbfaf7 100%);
}

.lifecycle-path {
  display: flex;
  align-items: stretch;
  gap: 14px;
}

.lifecycle-path div {
  position: relative;
  display: flex;
  flex: 1 1 0;
  flex-direction: column;
  justify-content: space-between;
  min-width: 0;
  min-height: 590px;
  padding: 16px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.74);
}

.lifecycle-path div::after {
  position: absolute;
  top: 28px;
  right: -12px;
  width: 10px;
  height: 10px;
  border-top: 2px solid rgba(17, 17, 17, 0.24);
  border-right: 2px solid rgba(17, 17, 17, 0.24);
  content: "";
  transform: rotate(45deg);
}

.lifecycle-path div:last-child::after {
  display: none;
}

.lifecycle-path span {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
}

.lifecycle-path strong {
  writing-mode: vertical-rl;
  align-self: center;
  margin: auto 0;
  font-family: var(--display);
  font-size: clamp(30px, 3.2vw, 46px);
  line-height: 1.05;
}

.lifecycle-path p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
  line-height: 1.45;
}

.vision-note {
  display: grid;
  align-content: space-between;
}

.edu-theater {
  grid-template-columns: minmax(300px, 0.9fr) minmax(0, 1.1fr);
  align-items: stretch;
  background: linear-gradient(135deg, #fff4dd 0%, #eef2ff 58%, #fbfaf7 100%);
}

.knowledge-stack-panel {
  display: grid;
  align-content: space-between;
}

.knowledge-layers {
  display: grid;
  gap: 10px;
  margin-top: 34px;
}

.knowledge-layers strong {
  min-height: 58px;
  padding: 16px 18px;
  border-radius: 16px;
  background: #111111;
  color: #f8f6f0;
  font-weight: 850;
}

.advisor-workflow {
  display: grid;
  align-content: space-between;
  gap: 16px;
  padding: 24px;
}

.advisor-message {
  padding: 24px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.8);
}

.advisor-message.strong {
  background: #111111;
  color: #f8f6f0;
}

.advisor-message small {
  color: var(--muted-2);
  font-weight: 900;
}

.advisor-message.strong small {
  color: rgba(248, 246, 240, 0.62);
}

.advisor-message p {
  margin: 18px 0 0;
  font-family: var(--display);
  font-size: clamp(27px, 3vw, 42px);
  line-height: 1.08;
}

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

.followup-row span {
  display: grid;
  min-height: 82px;
  place-items: center;
  padding: 12px;
  border-radius: 16px;
  background: rgba(17, 17, 17, 0.06);
  color: var(--ink-soft);
  font-weight: 850;
  text-align: center;
}

@media (max-width: 1180px) {
  .growth-keys,
  .case-action-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .case-action-grid article:last-child {
    grid-column: 1 / -1;
  }

  .case-heading,
  .lizi-theater,
  .robot-theater,
  .store-theater,
  .vision-theater,
  .edu-theater {
    grid-template-columns: 1fr;
  }

  .case-theater {
    min-height: auto;
  }

  .lizi-loop-board {
    min-height: 560px;
  }

  .lifecycle-path div {
    min-height: 500px;
  }
}

@media (max-width: 900px) {
  .cases-page .growth-keys-section {
    padding-bottom: 96px;
  }

  .cases-page .final-product-cta {
    padding-top: 96px;
    padding-bottom: 96px;
  }

  .growth-keys,
  .case-action-grid,
  .store-board,
  .followup-row {
    grid-template-columns: 1fr;
  }

  .growth-keys article,
  .case-action-grid article {
    min-height: auto;
  }

  .case-action-grid strong {
    margin-top: 28px;
  }

  .case-theater {
    padding: 22px;
    border-radius: 24px;
  }

  .lizi-loop-board {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: none;
    min-height: auto;
    gap: 12px;
  }

  .loop-step.entrance,
  .loop-step.trust,
  .loop-step.asset,
  .loop-step.retention,
  .loop-step.scale {
    grid-column: auto;
    grid-row: auto;
  }

  .lifecycle-path {
    flex-direction: column;
  }

  .lifecycle-path div {
    min-height: auto;
  }

  .lifecycle-path div::after {
    top: auto;
    right: 50%;
    bottom: -10px;
    transform: rotate(135deg);
  }

  .lifecycle-path strong {
    writing-mode: initial;
    align-self: start;
    margin: 30px 0;
  }
}

@media (max-width: 560px) {
  .case-hero {
    padding-bottom: 54px;
  }

  .cases-page .display-title.page-title {
    font-size: 44px;
  }

  .cases-page .section-title {
    font-size: 34px;
  }

  .growth-keys article,
  .case-summary-card,
  .case-strategy-panel,
  .robot-command,
  .agent-execution-panel,
  .vision-note,
  .knowledge-stack-panel,
  .advisor-workflow,
  .case-action-grid article {
    padding: 20px;
  }

  .case-theater {
    margin-top: 38px;
    padding: 14px;
  }

  .store-board div,
  .trial-metrics div {
    min-height: 176px;
  }

  .robot-scenes,
  .trial-bars {
    grid-template-columns: 1fr;
  }

  .trial-bars {
    min-height: 260px;
  }

  .trial-bars i {
    height: 38px !important;
  }

  .advisor-message {
    padding: 18px;
  }
}

.growth-key-card {
  --growth-accent: #c97910;
  --growth-accent-strong: #86500b;
  --growth-accent-soft: rgba(201, 121, 16, 0.14);
  display: grid !important;
  grid-template-rows: auto auto;
  align-content: center;
  gap: 22px;
  justify-content: initial !important;
  min-height: 532px;
  padding: 22px 10px !important;
  border-radius: 26px !important;
}

.growth-key-visual {
  position: relative;
  z-index: 0;
  display: grid;
  height: 267px;
  min-height: 267px;
  gap: 12px;
  padding: 20px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 20px;
  background: var(--paper-warm);
  box-shadow: 0 22px 54px rgba(33, 29, 23, 0.1);
}

.growth-key-visual::before {
  display: none;
}

.growth-key-visual > * {
  position: relative;
  z-index: 1;
}

.growth-key-visual small {
  display: block;
  color: var(--muted);
  font-size: 12px;
  font-style: normal;
  font-weight: 850;
  line-height: 1.2;
}

.growth-key-visual b {
  display: block;
  color: var(--ink);
  font-size: 16px;
  font-weight: 950;
  line-height: 1.18;
}

.growth-key-entry {
  --growth-accent: #c97910;
  --growth-accent-strong: #86500b;
  --growth-accent-soft: rgba(201, 121, 16, 0.14);
}

.growth-key-trust {
  --growth-accent: #bb6b83;
  --growth-accent-strong: #864356;
  --growth-accent-soft: rgba(187, 107, 131, 0.14);
}

.growth-key-asset {
  --growth-accent: #4d84b3;
  --growth-accent-strong: #24577e;
  --growth-accent-soft: rgba(77, 132, 179, 0.14);
}

.growth-key-skill {
  --growth-accent: #678e61;
  --growth-accent-strong: #3d6437;
  --growth-accent-soft: rgba(103, 142, 97, 0.15);
}

.growth-key-entry .growth-key-visual {
  background: linear-gradient(135deg, #fff1d8, #f8faf6);
}

.growth-key-trust .growth-key-visual {
  background: linear-gradient(135deg, #f9e3e9, #fff8f0);
}

.growth-key-asset .growth-key-visual {
  background: linear-gradient(135deg, #e8f2ff, #f8faf6);
}

.growth-key-skill .growth-key-visual {
  background: linear-gradient(135deg, #e8f6e5, #fff7e8);
}

.growth-map-head,
.growth-proof-panel,
.growth-profile-card,
.growth-skill-source {
  border: 1px solid rgba(20, 20, 20, 0.09);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.76);
}

.growth-map-head {
  display: grid;
  align-content: center;
  min-height: 56px;
  padding: 11px 14px;
}

.growth-map-head b {
  margin-top: 4px;
  color: var(--growth-accent-strong);
}

.growth-entry-map {
  grid-template-rows: auto 1fr auto;
}

.growth-entry-route {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 16px minmax(0, 1fr) 16px minmax(0, 1fr);
  gap: 5px;
  align-items: center;
}

.growth-entry-route div {
  display: grid;
  min-height: 82px;
  align-content: center;
  gap: 5px;
  padding: 11px 9px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.68);
  text-align: center;
}

.growth-entry-route .accent {
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), var(--growth-accent-soft));
  border-color: color-mix(in srgb, var(--growth-accent) 30%, transparent);
  box-shadow: 0 12px 26px var(--growth-accent-soft);
}

.growth-entry-route .accent b {
  color: var(--growth-accent-strong);
}

.growth-entry-route em {
  position: relative;
  height: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--growth-accent) 40%, rgba(17, 17, 17, 0.12));
}

.growth-entry-route em::after {
  position: absolute;
  top: -3px;
  right: 0;
  width: 7px;
  height: 7px;
  border-top: 2px solid var(--growth-accent);
  border-right: 2px solid var(--growth-accent);
  content: "";
  transform: rotate(45deg);
}

.growth-map-chips,
.growth-proof-row,
.growth-followup-bar,
.growth-role-grid {
  display: grid;
  gap: 7px;
}

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

.growth-map-chips small,
.growth-proof-row small,
.growth-followup-bar small,
.growth-role-grid small {
  display: inline-flex;
  min-height: 29px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--growth-accent-strong);
  text-align: center;
}

.growth-trust-map {
  grid-template-rows: auto 1fr auto;
}

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

.growth-proof-panel {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 8px;
  min-height: 94px;
  padding: 16px 14px;
  background:
    radial-gradient(circle at 50% 0%, var(--growth-accent-soft), transparent 62%),
    rgba(255, 255, 255, 0.78);
  text-align: center;
}

.growth-proof-panel b {
  max-width: 180px;
  color: var(--growth-accent-strong);
}

.growth-trust-result {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 10px;
  align-items: center;
  min-height: 52px;
  padding: 10px 13px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 22%, transparent);
  border-radius: 15px;
  background: var(--growth-accent-soft);
}

.growth-trust-result small {
  padding-right: 10px;
  border-right: 1px solid color-mix(in srgb, var(--growth-accent) 24%, transparent);
}

.growth-asset-map {
  grid-template-rows: auto 1fr auto;
}

.growth-profile-card,
.growth-skill-source {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  min-height: 58px;
  padding: 12px 14px;
}

.growth-profile-card b,
.growth-skill-source b {
  color: var(--growth-accent-strong);
  text-align: right;
}

.growth-asset-timeline {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-items: center;
}

.growth-asset-timeline::before {
  position: absolute;
  top: 50%;
  right: 12%;
  left: 12%;
  height: 2px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--growth-accent) 32%, rgba(17, 17, 17, 0.14));
  content: "";
}

.growth-asset-timeline div {
  position: relative;
  display: grid;
  min-height: 80px;
  align-content: center;
  gap: 6px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: 0 12px 28px rgba(33, 29, 23, 0.06);
  text-align: center;
}

.growth-asset-timeline div::before {
  position: absolute;
  top: 10px;
  left: 50%;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--growth-accent);
  box-shadow: 0 0 0 5px var(--growth-accent-soft);
  content: "";
  transform: translateX(-50%);
}

.growth-asset-timeline b {
  color: var(--growth-accent-strong);
}

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

.growth-skill-map {
  grid-template-rows: auto auto 1fr;
}

.growth-skill-core {
  display: grid;
  width: 96px;
  min-height: 68px;
  justify-self: center;
  align-content: center;
  justify-items: center;
  gap: 4px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 28%, transparent);
  border-radius: 22px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.92), var(--growth-accent-soft));
  box-shadow: 0 14px 30px var(--growth-accent-soft);
}

.growth-skill-core::before,
.growth-skill-core::after {
  position: absolute;
  left: 50%;
  width: 2px;
  height: 12px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--growth-accent) 36%, rgba(17, 17, 17, 0.12));
  content: "";
  transform: translateX(-50%);
}

.growth-skill-core::before {
  top: -12px;
}

.growth-skill-core::after {
  bottom: -12px;
}

.growth-skill-core b {
  color: var(--growth-accent-strong);
}

.growth-role-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: end;
}

.growth-role-grid small {
  min-height: 42px;
  border-radius: 14px;
  font-size: 13px;
}

.growth-visual-head,
.growth-insight-bar {
  display: flex;
  min-height: 54px;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 11px 13px;
  border: 1px solid rgba(20, 20, 20, 0.09);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.78);
}

.growth-visual-head b,
.growth-insight-bar b {
  color: var(--growth-accent-strong);
  text-align: right;
}

.growth-entry-score,
.growth-trust-spotlight,
.growth-asset-board,
.growth-skill-blueprint {
  display: grid;
  gap: 8px;
  min-height: 108px;
}

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

.growth-entry-score .growth-focus-card {
  grid-column: 1 / -1;
}

.growth-entry-score > div:not(.growth-focus-card),
.growth-proof-grid small,
.growth-asset-fields small,
.growth-method-grid small {
  display: grid;
  min-height: 46px;
  align-content: center;
  justify-items: center;
  gap: 4px;
  padding: 7px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.68);
  text-align: center;
}

.growth-entry-score > div:not(.growth-focus-card) b {
  color: var(--growth-accent-strong);
  font-size: 14px;
}

.growth-focus-card {
  display: grid;
  min-height: 58px;
  align-content: center;
  gap: 5px;
  padding: 12px 14px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 28%, transparent);
  border-radius: 16px;
  background:
    radial-gradient(circle at 90% 10%, rgba(255, 255, 255, 0.9), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.94), var(--growth-accent-soft));
  box-shadow: 0 14px 30px var(--growth-accent-soft);
}

.growth-focus-card b {
  color: var(--growth-accent-strong);
}

.growth-lever-row,
.growth-role-row {
  display: grid;
  gap: 7px;
}

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

.growth-role-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.growth-lever-row small,
.growth-role-row small {
  display: inline-flex;
  min-height: 28px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--growth-accent-strong);
  text-align: center;
}

.growth-trust-spotlight,
.growth-asset-board,
.growth-skill-blueprint {
  grid-template-columns: minmax(0, 0.95fr) minmax(0, 1.05fr);
  align-items: stretch;
}

.growth-proof-grid,
.growth-asset-fields,
.growth-method-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.growth-proof-grid small,
.growth-asset-fields small,
.growth-method-grid small {
  color: var(--growth-accent-strong);
  font-size: 12px;
}

.growth-insight-bar {
  min-height: 48px;
  padding: 10px 13px;
  background: var(--growth-accent-soft);
}

.growth-insight-bar b {
  max-width: 128px;
  font-size: 14px;
}

.growth-action-focus,
.growth-judgment-dial,
.growth-asset-stack,
.growth-method-template {
  position: relative;
  isolation: isolate;
  align-content: center;
}

.growth-action-focus::after,
.growth-judgment-dial::after,
.growth-asset-stack::after,
.growth-method-template::after {
  position: absolute;
  inset: auto 26px 20px;
  z-index: -1;
  height: 26px;
  border-radius: 50%;
  background: var(--growth-accent-soft);
  filter: blur(18px);
  content: "";
}

.action-focus-cloud {
  position: absolute;
  inset: 28px 20px 58px;
  z-index: 2;
}

.action-focus-cloud span {
  position: absolute;
  z-index: 2;
  display: inline-flex;
  min-width: 52px;
  min-height: 34px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.56);
  color: color-mix(in srgb, var(--growth-accent-strong) 52%, transparent);
  box-shadow: 0 10px 26px rgba(33, 29, 23, 0.06);
}

.action-focus-cloud span:nth-child(1) {
  top: -2px;
  left: -10px;
}

.action-focus-cloud span:nth-child(2) {
  top: 18px;
  right: -14px;
}

.action-focus-cloud span:nth-child(3) {
  bottom: 28px;
  left: -8px;
}

.action-focus-cloud span:nth-child(4) {
  right: 6px;
  bottom: 66px;
}

.action-focus-target,
.asset-sheet,
.method-template-card {
  position: relative;
  display: grid;
  width: min(178px, 100%);
  min-height: 142px;
  align-content: center;
  justify-items: start;
  gap: 8px;
  margin: 14px auto 0;
  padding: 24px 20px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 36%, transparent);
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), rgba(255, 255, 255, 0.68)),
    var(--growth-accent-soft);
  box-shadow:
    0 24px 50px rgba(33, 29, 23, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.74);
}

.action-focus-target::before {
  position: absolute;
  inset: -14px;
  border: 1px dashed color-mix(in srgb, var(--growth-accent) 55%, transparent);
  border-radius: 31px;
  content: "";
}

.action-focus-target::after {
  position: absolute;
  top: 15px;
  right: 15px;
  width: 15px;
  height: 15px;
  border-top: 2px solid var(--growth-accent);
  border-right: 2px solid var(--growth-accent);
  content: "";
}

.action-focus-target small,
.asset-sheet small,
.method-template-card small {
  color: var(--growth-accent-strong);
}

.action-focus-target b,
.asset-sheet b,
.method-template-card b {
  font-family: var(--display);
  font-size: 24px;
  font-weight: 650;
  line-height: 1.05;
}

.action-focus-target em {
  position: absolute;
  right: -17px;
  bottom: -13px;
  width: 50px;
  height: 50px;
  border: 2px solid color-mix(in srgb, var(--growth-accent) 56%, transparent);
  border-radius: 50%;
  background:
    linear-gradient(var(--growth-accent), var(--growth-accent)) 50% 0 / 2px 100% no-repeat,
    linear-gradient(var(--growth-accent), var(--growth-accent)) 0 50% / 100% 2px no-repeat,
    rgba(255, 255, 255, 0.42);
  box-shadow: 0 12px 30px var(--growth-accent-soft);
}

.action-focus-score,
.asset-trace,
.method-copy-row {
  display: grid;
  gap: 8px;
  width: 100%;
  align-self: end;
}

.action-focus-score,
.asset-trace {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.growth-action-focus .action-focus-score {
  transform: translateY(10px);
}

.action-focus-score span,
.asset-trace span {
  position: relative;
  display: inline-flex;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--growth-accent-strong);
  box-shadow: inset 0 0 0 1px rgba(20, 20, 20, 0.08);
}

.judgment-dial {
  position: relative;
  display: grid;
  width: 166px;
  height: 166px;
  justify-self: center;
  place-items: center;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 28%, transparent);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.98) 0 47%, transparent 48%),
    conic-gradient(
      from 206deg,
      var(--growth-accent-soft) 0 28%,
      color-mix(in srgb, var(--growth-accent) 28%, white) 28% 53%,
      rgba(255, 255, 255, 0.82) 53% 100%
    );
  box-shadow:
    0 22px 48px rgba(33, 29, 23, 0.1),
    inset 0 0 0 12px rgba(255, 255, 255, 0.42);
}

.judgment-dial i {
  position: absolute;
  inset: 14px;
  border: 1px dashed color-mix(in srgb, var(--growth-accent) 38%, transparent);
  border-radius: 50%;
}

.judgment-dial i:nth-child(2) {
  inset: 34px;
  border-style: solid;
  opacity: 0.56;
}

.judgment-dial em {
  position: absolute;
  top: 28px;
  left: 50%;
  width: 3px;
  height: 62px;
  border-radius: 999px;
  background: var(--growth-accent);
  box-shadow: 0 8px 22px var(--growth-accent-soft);
  transform: rotate(36deg);
  transform-origin: 50% 54px;
}

.judgment-dial div {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 5px;
  text-align: center;
}

.judgment-dial b {
  color: var(--growth-accent-strong);
  font-family: var(--display);
  font-size: 22px;
  font-weight: 650;
  line-height: 1.04;
}

.judgment-callouts {
  position: absolute;
  inset: 26px 15px 72px;
}

.judgment-callouts span {
  position: absolute;
  display: inline-flex;
  min-width: 46px;
  min-height: 32px;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--growth-accent-strong);
  box-shadow: 0 12px 28px rgba(33, 29, 23, 0.08);
}

.judgment-callouts span:nth-child(1) {
  top: 10px;
  left: 0;
}

.judgment-callouts span:nth-child(2) {
  top: 0;
  right: 0;
}

.judgment-callouts span:nth-child(3) {
  right: 14px;
  bottom: 0;
}

.judgment-rule {
  display: flex;
  min-height: 48px;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  width: 100%;
  padding: 10px 14px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 24%, transparent);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.74);
}

.judgment-rule b {
  color: var(--growth-accent-strong);
  text-align: right;
}

.asset-sheet-stack,
.method-template-stack {
  position: absolute;
  inset: 28px 28px 58px;
}

.asset-sheet-stack i,
.method-template-stack i {
  position: absolute;
  inset: 18px 22px auto;
  height: 136px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.44);
  box-shadow: 0 20px 42px rgba(33, 29, 23, 0.07);
}

.asset-sheet-stack i:nth-child(1),
.method-template-stack i:nth-child(1) {
  transform: translate(-18px, 10px) rotate(-6deg);
}

.asset-sheet-stack i:nth-child(2),
.method-template-stack i:nth-child(2) {
  transform: translate(18px, -4px) rotate(6deg);
}

.asset-sheet {
  min-height: 150px;
}

.asset-sheet::after {
  position: absolute;
  top: -1px;
  right: -1px;
  width: 34px;
  height: 34px;
  border-bottom-left-radius: 16px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0) 50%, var(--growth-accent-soft) 51%);
  content: "";
}

.asset-sheet em {
  display: block;
  width: 100%;
  height: 24px;
  margin-top: 3px;
  background:
    radial-gradient(circle, var(--growth-accent) 0 3px, transparent 4px) 0 16px / 33% 8px repeat-x,
    linear-gradient(115deg, transparent 0 13%, var(--growth-accent) 14% 16%, transparent 17% 44%, var(--growth-accent) 45% 47%, transparent 48% 74%, var(--growth-accent) 75% 77%, transparent 78%);
  opacity: 0.82;
}

.method-template-card {
  min-height: 150px;
}

.method-template-card::before {
  position: absolute;
  top: 18px;
  right: 18px;
  width: 34px;
  height: 34px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 34%, transparent);
  border-radius: 50%;
  background: var(--growth-accent-soft);
  content: "";
}

.method-template-card::after {
  position: absolute;
  top: 26px;
  right: 25px;
  width: 14px;
  height: 8px;
  border-bottom: 2px solid var(--growth-accent);
  border-left: 2px solid var(--growth-accent);
  content: "";
  transform: rotate(-45deg);
}

.method-template-card em {
  display: grid;
  width: 100%;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 5px;
}

.method-template-card em::before,
.method-template-card em::after,
.method-template-card em {
  border-color: transparent;
}

.method-template-card em::before,
.method-template-card em::after {
  display: block;
  height: 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--growth-accent) 26%, white);
  content: "";
}

.method-copy-row {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.method-copy-row span {
  position: relative;
  display: grid;
  min-height: 40px;
  align-content: center;
  justify-items: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--growth-accent-strong);
}

.method-copy-row span::before {
  position: absolute;
  top: -4px;
  width: 10px;
  height: 10px;
  border: 1px solid rgba(255, 255, 255, 0.8);
  border-radius: 50%;
  background: var(--growth-accent);
  content: "";
}

.growth-key-copy {
  display: grid;
  align-content: start;
  min-height: 0;
  padding: 0 12px 8px;
}

.growth-key-copy .growth-key-tag {
  display: inline-flex;
  width: fit-content;
  min-height: 32px;
  align-items: center;
  padding: 0 13px;
  border: 1px solid color-mix(in srgb, var(--growth-accent) 24%, var(--line));
  border-radius: 999px;
  background: color-mix(in srgb, var(--growth-accent-soft) 74%, white);
  color: var(--growth-accent-strong);
  font-size: 14px;
  font-weight: 750;
  text-transform: none;
}

.growth-key-copy strong {
  margin-top: 24px !important;
}

.growth-key-copy p {
  margin-top: 16px !important;
}

@media (max-width: 900px) {
  .growth-key-card {
    grid-template-rows: minmax(240px, auto) auto;
    min-height: auto;
  }
}

@media (max-width: 560px) {
  .growth-key-card {
    grid-template-rows: minmax(222px, auto) auto;
  }

  .growth-key-visual {
    height: 257px;
    min-height: 257px;
    gap: 10px;
    padding: 16px;
  }

  .growth-entry-route {
    grid-template-columns: minmax(0, 1fr) 12px minmax(0, 1fr) 12px minmax(0, 1fr);
    gap: 4px;
  }

  .growth-entry-route div {
    min-height: 74px;
    padding: 10px 5px;
  }

  .growth-key-visual b {
    font-size: 14px;
  }
}

.case-tabs-block {
  --case-accent: #c97910;
  --case-soft: #fff3dd;
  --case-panel: rgba(255, 255, 255, 0.78);
  margin-top: 62px !important;
  padding: 28px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 32px;
  box-shadow: var(--shadow);
}

.case-tabs-lizi {
  --case-accent: #c97910;
  --case-soft: #fff3dd;
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 255, 255, 0.92), transparent 33%),
    linear-gradient(135deg, #f5d8de 0%, #fff3dc 50%, #e5f0ff 100%);
}

.case-tabs-robot {
  --case-accent: #5f7888;
  --case-soft: #e2edf5;
  background:
    linear-gradient(135deg, rgba(221, 234, 242, 0.98), rgba(247, 250, 250, 0.92)),
    #eef3f7;
}

.case-tabs-beauty {
  --case-accent: #6f8f71;
  --case-soft: #e8f7e8;
  background: linear-gradient(135deg, #e4f6e8 0%, #fff1f6 58%, #f7faf5 100%);
}

.case-tabs-vision {
  --case-accent: #4e88a4;
  --case-soft: #e4f5ff;
  background: linear-gradient(135deg, #dff2ff 0%, #ecf8e8 58%, #fbfaf7 100%);
}

.case-tabs-edu {
  --case-accent: #8b7148;
  --case-soft: #fff1d2;
  background: linear-gradient(135deg, #fff4dd 0%, #eef2ff 58%, #fbfaf7 100%);
}

.case-tab-list {
  justify-content: flex-start;
  width: 100%;
  margin: 0 0 24px;
  border-color: rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.54);
}

.case-tab-button {
  color: var(--ink-soft);
}

.case-tab-button .tab-dot {
  background: var(--case-accent);
}

.case-tab-stage {
  display: grid;
  grid-template-columns: minmax(0, 0.84fr) minmax(0, 1.16fr);
  gap: 24px;
  min-height: 620px;
}

.case-tab-stage.reverse {
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
}

.case-tabs-beauty .case-tab-stage {
  grid-template-columns: minmax(0, 0.96fr) minmax(0, 1.04fr);
}

.case-tabs-vision .case-tab-stage {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
}

.case-tabs-edu .case-tab-stage {
  grid-template-columns: minmax(0, 0.88fr) minmax(0, 1.12fr);
}

.case-tab-copy,
.case-media-panel {
  min-width: 0;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: var(--case-panel);
}

.case-tab-copy {
  display: grid;
  align-content: start;
  padding: 36px;
}

.case-tab-copy.dark {
  background: #111111;
  color: #f8f6f0;
}

.case-tab-copy > span {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.case-tab-copy.dark > span,
.case-tab-copy.dark p {
  color: rgba(248, 246, 240, 0.7);
}

.case-tab-copy h3 {
  margin: 20px 0 0;
  font-family: var(--display);
  font-size: clamp(38px, 4.4vw, 64px);
  line-height: 1.02;
}

.case-tab-copy p {
  margin: 28px 0 0;
  color: var(--muted);
  font-size: 19px;
}

.case-bullet-list {
  display: grid;
  gap: 12px;
  margin: 42px 0 0;
  padding: 0;
  list-style: none;
}

.case-bullet-list li {
  padding: 15px 18px;
  border-radius: 16px;
  background: rgba(17, 17, 17, 0.055);
  color: var(--ink-soft);
  font-weight: 820;
}

.case-tab-copy.dark .case-bullet-list li {
  background: rgba(255, 255, 255, 0.12);
  color: #f8f6f0;
}

.case-media-panel {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 16px;
  margin: 0;
  padding: 24px;
}

.case-media-header {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding-bottom: 14px;
  border-bottom: 1px solid rgba(20, 20, 20, 0.08);
}

.case-media-header span {
  margin-right: auto;
  padding: 7px 13px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink-soft);
  font-size: 13px;
  font-weight: 850;
}

.case-media-header i {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: rgba(17, 17, 17, 0.18);
}

.case-image-slot {
  position: relative;
  display: grid;
  align-content: end;
  min-height: 500px;
  padding: 30px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.68), rgba(255, 255, 255, 0.22)),
    var(--case-soft);
}

.case-image-slot::before {
  position: absolute;
  inset: 26px;
  border: 1px solid rgba(17, 17, 17, 0.08);
  border-radius: 20px;
  content: "";
}

.case-image-slot strong,
.case-image-slot span {
  position: relative;
  z-index: 1;
}

.case-image-slot strong {
  font-family: var(--display);
  color: var(--ink);
  font-size: clamp(38px, 5vw, 78px);
  line-height: 0.98;
}

.case-image-slot span {
  max-width: 620px;
  margin-top: 18px;
  color: var(--ink-soft);
  font-size: 18px;
  font-weight: 760;
}

.case-image-slot i {
  position: absolute;
  z-index: 0;
  display: block;
  border-radius: 18px;
  background: color-mix(in srgb, var(--case-accent) 42%, white);
  opacity: 0.72;
}

.case-image-slot i:nth-of-type(1) {
  top: 58px;
  left: 56px;
  width: 42%;
  height: 18px;
}

.case-image-slot i:nth-of-type(2) {
  top: 100px;
  right: 54px;
  width: 130px;
  height: 130px;
  border-radius: 34px;
}

.case-image-slot i:nth-of-type(3) {
  right: 56px;
  bottom: 150px;
  width: 52%;
  height: 22px;
}

.case-tabs-robot .case-image-slot {
  background:
    repeating-linear-gradient(90deg, rgba(17, 17, 17, 0.06) 0 1px, transparent 1px 70px),
    linear-gradient(135deg, #e4eef4, #f8faf8);
}

.case-tabs-beauty .case-image-slot {
  background:
    radial-gradient(circle at 76% 20%, rgba(255, 255, 255, 0.88), transparent 26%),
    linear-gradient(135deg, #e8f7e8, #fff0f6);
}

.case-tabs-vision .case-image-slot {
  background:
    linear-gradient(90deg, rgba(78, 136, 164, 0.13) 0 18%, transparent 18% 100%),
    linear-gradient(135deg, #e3f5ff, #edf8e9);
}

.case-tabs-edu .case-image-slot {
  background:
    linear-gradient(180deg, rgba(17, 17, 17, 0.04), transparent 40%),
    linear-gradient(135deg, #fff2d8, #eef2ff);
}

@media (max-width: 1180px) {
  .growth-key-card {
    grid-template-rows: auto auto;
    min-height: 500px;
  }

  .case-tab-stage,
  .case-tab-stage.reverse,
  .case-tabs-beauty .case-tab-stage,
  .case-tabs-vision .case-tab-stage,
  .case-tabs-edu .case-tab-stage {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .case-image-slot {
    min-height: 440px;
  }
}

@media (max-width: 900px) {
  .growth-key-card {
    grid-template-rows: auto auto;
    min-height: auto;
  }

  .growth-key-copy {
    min-height: auto;
  }

  .case-tabs-block {
    padding: 18px;
    border-radius: 24px;
  }

  .case-tab-list {
    margin-bottom: 18px;
  }

  .case-tab-copy,
  .case-media-panel {
    border-radius: 20px;
  }

  .case-tab-copy {
    padding: 24px;
  }

  .case-media-panel {
    padding: 18px;
  }

  .case-image-slot {
    min-height: 360px;
    padding: 24px;
  }
}

@media (max-width: 560px) {
  .growth-key-card {
    grid-template-rows: auto auto;
    gap: 18px;
    padding: 10px !important;
  }

  .growth-key-copy strong {
    margin-top: 24px !important;
  }

  .case-tabs-block {
    margin-top: 40px !important;
    padding: 12px;
  }

  .case-tab-button {
    min-height: 42px;
    padding: 0 15px;
    font-size: 13px;
  }

  .case-tab-stage {
    gap: 14px;
  }

  .case-tab-copy {
    padding: 20px;
  }

  .case-tab-copy h3 {
    font-size: 34px;
  }

  .case-tab-copy p {
    margin-top: 20px;
    font-size: 16px;
  }

  .case-bullet-list {
    margin-top: 28px;
  }

  .case-media-panel {
    padding: 14px;
  }

  .case-media-header span {
    max-width: 220px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .case-image-slot {
    min-height: 300px;
    padding: 20px;
  }

  .case-image-slot strong {
    font-size: 38px;
  }

  .case-image-slot span {
    font-size: 15px;
  }
}

/* Differentiated case stages: tabs stay uniform; the business stage changes. */
.particle-growth-lab,
.robot-command-console,
.beauty-agent-room,
.vision-care-record,
.edu-skill-console {
  padding: 30px;
  border-radius: 34px;
}

.particle-growth-lab {
  background:
    radial-gradient(circle at 84% 16%, rgba(255, 255, 255, 0.96), transparent 30%),
    linear-gradient(135deg, #f4d5de 0%, #fff1d8 45%, #e6f2ff 100%);
}

.robot-command-console {
  background:
    linear-gradient(135deg, rgba(222, 235, 244, 0.98), rgba(247, 250, 250, 0.92)),
    #edf4f8;
}

.beauty-agent-room {
  background: linear-gradient(135deg, #e8f7e7 0%, #fff2f7 52%, #f7faf5 100%);
}

.vision-care-record {
  background: linear-gradient(135deg, #e1f4ff 0%, #eef8e9 62%, #fbfaf7 100%);
}

.edu-skill-console {
  background: linear-gradient(135deg, #fff3d8 0%, #eef2ff 58%, #fbfaf7 100%);
}

.case-tabs-block .case-tab-list {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  gap: 8px;
  width: 100%;
  margin: 0 0 26px;
  padding: 7px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.58);
}

.case-tabs-block .case-tab-button {
  justify-content: center;
  width: auto;
  min-width: max-content;
  min-height: 44px;
  padding: 0 18px;
  border-radius: 999px;
  color: var(--ink-soft);
}

.case-tabs-block .case-tab-button::after {
  content: none;
}

.case-tabs-block .case-tab-button.active {
  background: #ffffff;
  color: var(--ink);
  box-shadow: inset 0 0 0 1px rgba(20, 20, 20, 0.06);
}

.particle-growth-lab .case-tab-stage,
.particle-growth-lab .case-tab-stage.reverse {
  grid-template-columns: minmax(300px, 0.72fr) minmax(0, 1.28fr);
  gap: 28px;
  height: 690px;
  min-height: 690px;
}

.particle-growth-lab .case-tab-copy,
.robot-command-console .case-tab-copy,
.beauty-agent-room .case-tab-copy,
.vision-care-record .case-tab-copy,
.edu-skill-console .case-tab-copy {
  align-content: space-between;
}

.particle-growth-lab .case-tab-copy {
  background: rgba(255, 255, 255, 0.82);
}

.particle-growth-lab .case-tab-copy.dark {
  background: #101010;
}

.lizi-entry-insight {
  position: relative;
  grid-template-rows: auto auto auto auto;
  gap: 16px;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  padding: 26px 32px;
}

.particle-growth-lab .case-tab-copy.lizi-entry-insight,
.particle-growth-lab .case-tab-copy.lizi-id-insight {
  align-content: center;
}

.lizi-entry-insight::before {
  position: absolute;
  inset: -32% -18% auto auto;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 210, 202, 0.18), transparent 68%);
  content: "";
}

.lizi-entry-insight > * {
  position: relative;
  z-index: 1;
}

.lizi-id-insight {
  position: relative;
  grid-template-rows: auto auto auto auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  padding: 26px 32px;
}

.lizi-id-insight::before {
  position: absolute;
  inset: -32% -18% auto auto;
  width: 260px;
  height: 260px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 210, 202, 0.18), transparent 68%);
  content: "";
}

.lizi-id-insight > * {
  position: relative;
  z-index: 1;
}

.id-insight-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(255, 232, 211, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 229, 203, 0.78);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.id-insight-head h3 {
  max-width: 520px;
  margin: 12px 0 0;
  font-size: clamp(30px, 2.35vw, 35px);
  line-height: 1.08;
}

.id-insight-head p {
  margin: 11px 0 0;
  color: rgba(248, 246, 240, 0.72);
  font-size: 14px;
  line-height: 1.48;
}

.id-ledger-board {
  position: relative;
  display: grid;
  gap: 10px;
  min-height: 204px;
  padding: 15px;
  overflow: hidden;
  border: 1px solid rgba(255, 226, 203, 0.13);
  border-radius: 22px;
  background:
    radial-gradient(circle at 78% 20%, rgba(255, 215, 198, 0.13), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.055)),
    #171717;
}

.id-ledger-board::before {
  position: absolute;
  top: 18px;
  right: 18px;
  bottom: 18px;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(224, 134, 57, 0.42), transparent);
  content: "";
}

.id-ledger-board::after {
  position: absolute;
  top: 21px;
  right: 9px;
  display: grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border: 1px solid rgba(255, 218, 190, 0.24);
  border-radius: 50%;
  background: #1f1b18;
  color: rgba(255, 221, 190, 0.84);
  font-size: 10px;
  font-weight: 900;
  content: "AI";
}

.id-ledger-core {
  display: grid;
  gap: 7px;
  padding: 13px 14px;
  border: 1px solid rgba(255, 226, 203, 0.12);
  border-radius: 17px;
  background:
    linear-gradient(135deg, rgba(224, 134, 57, 0.12), rgba(255, 255, 255, 0.055));
}

.id-ledger-core small,
.id-trigger-matrix small,
.id-result-strip span {
  color: rgba(255, 214, 174, 0.74);
  font-size: 11px;
  font-weight: 900;
}

.id-ledger-core strong {
  color: #fffaf3;
  font-size: 18px;
  font-weight: 930;
  line-height: 1.08;
}

.id-ledger-core span {
  color: rgba(248, 246, 240, 0.62);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.32;
}

.id-ledger-fields {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}

.id-ledger-fields article {
  min-height: 58px;
  padding: 10px 7px;
  border: 1px solid rgba(255, 226, 203, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.1);
}

.id-ledger-fields b {
  display: block;
  color: #fffaf3;
  font-size: 15px;
  font-weight: 930;
}

.id-ledger-fields span {
  display: block;
  margin-top: 6px;
  color: rgba(248, 246, 240, 0.58);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.2;
}

.id-trigger-matrix {
  display: grid;
  gap: 8px;
}

.id-trigger-matrix article {
  display: grid;
  grid-template-columns: 34px 64px 1fr;
  align-items: center;
  gap: 9px;
  min-height: 52px;
  padding: 7px 12px;
  border: 1px solid rgba(255, 226, 203, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.09);
}

.id-trigger-matrix svg {
  width: 31px;
  height: 31px;
  padding: 6px;
  border: 1px solid rgba(255, 223, 198, 0.38);
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.1);
  color: rgba(255, 222, 196, 0.88);
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.id-trigger-matrix strong {
  color: #fffaf3;
  font-size: 14px;
  font-weight: 900;
  line-height: 1.22;
}

.id-result-strip {
  display: grid;
  grid-template-columns: 1fr repeat(3, minmax(0, 68px));
  gap: 7px;
  align-items: center;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.11);
}

.id-result-strip strong {
  display: grid;
  place-items: center;
  min-height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: rgba(255, 250, 243, 0.92);
  font-size: 14px;
  font-weight: 920;
}

.lizi-entry-insight .entry-kicker {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(255, 232, 211, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 229, 203, 0.78);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lizi-entry-insight h3 {
  max-width: 520px;
  margin: 12px 0 0;
  font-size: clamp(30px, 2.35vw, 35px);
  line-height: 1.08;
}

.lizi-entry-insight p {
  margin: 11px 0 0;
  color: rgba(248, 246, 240, 0.72);
  font-size: 14px;
  line-height: 1.48;
}

.entry-action-map {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 40px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  margin-top: 2px;
}

.entry-action-node {
  min-height: 104px;
  padding: 14px 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  background:
    linear-gradient(135deg, rgba(255, 217, 190, 0.13), rgba(255, 255, 255, 0.06)),
    rgba(255, 255, 255, 0.06);
}

.entry-action-node small,
.entry-result-board span,
.entry-axis-title b {
  display: block;
  color: rgba(255, 214, 174, 0.72);
  font-size: 11px;
  font-weight: 900;
}

.entry-action-node strong {
  display: block;
  margin-top: 8px;
  color: #fffaf3;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.05;
  white-space: nowrap;
}

.entry-action-node span {
  display: block;
  margin-top: 8px;
  color: rgba(248, 246, 240, 0.68);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.36;
}

.entry-action-arrow {
  position: relative;
  display: grid;
  place-items: center;
  width: 40px;
  height: 40px;
  border: 1px solid rgba(255, 210, 170, 0.24);
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.12);
  color: rgba(255, 221, 190, 0.86);
  font-size: 13px;
  font-weight: 900;
}

.entry-action-arrow::before,
.entry-action-arrow::after {
  position: absolute;
  width: 18px;
  height: 1px;
  background: rgba(255, 210, 170, 0.34);
  content: "";
}

.entry-action-arrow::before {
  transform: translateX(-29px);
}

.entry-action-arrow::after {
  transform: translateX(29px);
}

.entry-growth-axis {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 9px;
  min-height: auto;
  margin-top: 4px;
}

.entry-axis-rail {
  position: absolute;
  top: 18px;
  right: 42px;
  left: 42px;
  height: 2px;
  background: linear-gradient(90deg, rgba(224, 134, 57, 0.78), rgba(255, 228, 202, 0.24));
}

.entry-axis-step {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto 1fr;
  min-height: 178px;
  padding: 13px 10px 12px;
  border: 1px solid rgba(255, 226, 203, 0.13);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.13), rgba(255, 255, 255, 0.055)),
    #181818;
}

.entry-axis-title {
  display: flex;
  align-items: baseline;
  gap: 6px;
  margin-top: 6px;
}

.entry-axis-title strong {
  color: #fffaf3;
  font-size: 17px;
  font-weight: 900;
  line-height: 1.1;
}

.entry-axis-step span {
  margin-top: 7px;
  color: rgba(248, 246, 240, 0.64);
  font-size: 12px;
  font-weight: 740;
  line-height: 1.34;
}

.entry-axis-step svg {
  width: 31px;
  height: 31px;
  margin-bottom: 12px;
  padding: 6px;
  border: 1px solid rgba(255, 223, 198, 0.42);
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.1);
  color: rgba(255, 222, 196, 0.88);
  stroke: currentColor;
  stroke-width: 2;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.entry-result-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  margin-top: 2px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, 0.11);
}

.entry-result-board span {
  grid-column: 1 / -1;
  font-size: 12px;
}

.entry-result-board div {
  min-height: 56px;
  padding: 9px 8px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.09);
}

.entry-result-board strong {
  display: block;
  color: rgba(255, 250, 243, 0.9);
  font-size: 16px;
  font-weight: 900;
}

.entry-result-board strong::before {
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 8px;
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.9);
  content: "";
}

.entry-result-board small {
  display: block;
  margin-top: 4px;
  color: rgba(248, 246, 240, 0.58);
  font-size: 12px;
  font-weight: 760;
}

@media (max-width: 560px) {
  .lizi-entry-insight {
    gap: 16px;
    padding: 24px;
  }

  .lizi-entry-insight h3 {
    font-size: 31px;
  }

  .lizi-entry-insight p {
    font-size: 15px;
  }

  .entry-action-map,
  .entry-growth-axis,
  .entry-result-board {
    grid-template-columns: 1fr;
  }

  .entry-action-arrow,
  .entry-axis-rail {
    display: none;
  }

  .entry-action-node,
  .entry-axis-step {
    min-height: auto;
  }

  .entry-axis-step::before {
    margin-bottom: 12px;
  }
}

.lizi-report-insight {
  position: relative;
  grid-template-rows: auto auto 1fr auto;
  gap: 12px;
  height: 100%;
  max-height: 690px;
  min-height: 0;
  overflow: hidden;
  padding: 24px 28px;
  background:
    radial-gradient(circle at 100% 0%, rgba(255, 219, 226, 0.42), transparent 36%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.94), rgba(255, 250, 245, 0.82));
  color: #171717;
}

.particle-growth-lab .case-tab-copy.lizi-report-insight {
  align-content: stretch;
}

.particle-growth-lab .case-tab-stage > .lizi-report-insight,
.particle-growth-lab .case-tab-stage > .media-lizi-skin {
  align-self: stretch;
  height: 100%;
  max-height: 690px;
  min-height: 0;
}

.particle-growth-lab .case-tab-stage > .media-lizi-skin {
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
}

.lizi-report-insight::before {
  position: absolute;
  inset: 18px;
  pointer-events: none;
  border: 1px solid rgba(185, 132, 116, 0.16);
  border-radius: 20px;
  content: "";
}

.lizi-report-insight > * {
  position: relative;
  z-index: 1;
}

.report-insight-head span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(173, 116, 101, 0.2);
  border-radius: 999px;
  background: rgba(255, 247, 240, 0.9);
  color: #8e5a40;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.report-insight-head h3 {
  max-width: 350px;
  margin: 12px 0 0;
  font-size: clamp(26px, 2vw, 31px);
  line-height: 1.08;
}

.report-insight-head p {
  margin: 10px 0 0;
  color: rgba(37, 31, 28, 0.66);
  font-size: 12px;
  font-weight: 720;
  line-height: 1.42;
}

.report-trust-bridge {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 58px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
}

.report-bridge-card {
  min-height: 96px;
  padding: 11px 12px;
  border: 1px solid rgba(188, 127, 112, 0.16);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 14px 34px rgba(120, 77, 64, 0.07);
}

.report-bridge-card small {
  display: block;
  color: #b66f55;
  font-size: 11px;
  font-weight: 900;
}

.report-bridge-card strong {
  display: block;
  margin-top: 7px;
  color: #171717;
  font-size: 15px;
  font-weight: 920;
  line-height: 1.12;
}

.report-bridge-card span {
  display: block;
  margin-top: 7px;
  color: rgba(37, 31, 28, 0.55);
  font-size: 11px;
  font-weight: 780;
}

.report-bridge-core {
  position: relative;
  display: grid;
  place-items: center;
  width: 50px;
  height: 50px;
  border: 1px solid rgba(255, 174, 190, 0.52);
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(255, 240, 244, 0.92), rgba(255, 249, 239, 0.82));
  color: #b35769;
}

.report-bridge-core::before,
.report-bridge-core::after {
  position: absolute;
  top: 50%;
  width: 23px;
  height: 1px;
  background: rgba(188, 127, 112, 0.28);
  content: "";
}

.report-bridge-core::before {
  left: -23px;
}

.report-bridge-core::after {
  right: -23px;
}

.report-bridge-core svg {
  width: 25px;
  height: 25px;
  stroke: currentColor;
  stroke-width: 3;
  stroke-linecap: round;
  fill: none;
}

.report-bridge-core span {
  position: absolute;
  bottom: -18px;
  color: rgba(37, 31, 28, 0.48);
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
}

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

.report-action-matrix article {
  display: grid;
  align-content: start;
  min-height: 88px;
  padding: 10px;
  border: 1px solid rgba(188, 127, 112, 0.14);
  border-radius: 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 245, 242, 0.58));
}

.report-action-matrix b {
  color: #b66f55;
  font-size: 11px;
  font-weight: 940;
}

.report-action-matrix strong {
  margin-top: 5px;
  color: #171717;
  font-size: 16px;
  font-weight: 920;
  line-height: 1.1;
}

.report-action-matrix span {
  margin-top: 5px;
  color: rgba(37, 31, 28, 0.58);
  font-size: 11px;
  font-weight: 740;
  line-height: 1.26;
}

.report-result-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  padding-top: 10px;
  border-top: 1px solid rgba(188, 127, 112, 0.16);
}

.report-result-strip span {
  grid-column: 1 / -1;
  color: #9a604a;
  font-size: 12px;
  font-weight: 900;
}

.report-result-strip strong {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 7px 8px;
  border-radius: 12px;
  background: rgba(255, 244, 239, 0.78);
  color: #241d1a;
  font-size: 12px;
  font-weight: 900;
}

.report-result-strip strong::before {
  width: 6px;
  height: 6px;
  margin-right: 8px;
  border-radius: 50%;
  background: #d88738;
  content: "";
}

.media-lizi-skin .case-image-slot.lizi-skin-report-ui {
  display: block;
  align-content: stretch;
  height: 100%;
  min-height: 0;
  padding: 0;
  background:
    radial-gradient(circle at 14% 18%, rgba(255, 255, 255, 0.96), transparent 26%),
    radial-gradient(circle at 88% 18%, rgba(255, 217, 226, 0.72), transparent 30%),
    linear-gradient(135deg, #fff5e6 0%, #fde8ef 52%, #eaf5ff 100%);
}

.case-image-slot.lizi-skin-report-ui::before,
.particle-growth-lab .case-image-slot.lizi-skin-report-ui::after {
  content: none;
}

.lizi-skin-report-ui strong,
.lizi-skin-report-ui span {
  position: static;
  max-width: none;
  margin-top: 0;
  font-family: inherit;
  color: inherit;
  font-size: inherit;
  line-height: inherit;
}

.skin-report-shell {
  position: relative;
  z-index: 1;
  height: 100%;
  min-height: 0;
  padding: 16px;
}

.skin-report-shell::before {
  position: absolute;
  right: -40px;
  bottom: -46px;
  width: 210px;
  height: 210px;
  border: 1px solid rgba(255, 255, 255, 0.78);
  border-radius: 50%;
  background:
    radial-gradient(circle at 38% 38%, rgba(255, 255, 255, 0.72), transparent 18%),
    radial-gradient(circle at 62% 60%, rgba(255, 155, 181, 0.42), transparent 34%),
    rgba(255, 255, 255, 0.22);
  box-shadow: inset 0 0 26px rgba(255, 255, 255, 0.72);
  content: "";
}

.skin-report-card {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto auto;
  gap: 9px;
  height: 100%;
  min-height: 0;
  padding: 18px;
  overflow: hidden;
  border: 1px solid rgba(255, 255, 255, 0.88);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.88),
    0 24px 70px rgba(116, 69, 58, 0.12);
  backdrop-filter: blur(14px);
}

.skin-report-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
}

.skin-report-head span {
  display: block;
  color: #7a5347;
  font-size: 13px;
  font-weight: 920;
}

.skin-report-head strong {
  display: block;
  margin-top: 4px;
  font-family: var(--display);
  color: #171717;
  font-size: clamp(30px, 2.9vw, 42px);
  line-height: 0.95;
}

.skin-report-head p {
  margin: 6px 0 0;
  color: rgba(45, 35, 31, 0.62);
  font-size: 12px;
  font-weight: 760;
}

.skin-report-head em {
  padding: 6px 9px;
  border: 1px solid rgba(189, 132, 120, 0.18);
  border-radius: 999px;
  background: rgba(255, 247, 244, 0.72);
  color: #9c6772;
  font-size: 12px;
  font-style: normal;
  font-weight: 860;
  white-space: nowrap;
}

.skin-report-pills {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 9px;
}

.skin-report-pills span {
  padding: 8px 7px;
  border-radius: 999px;
  background: rgba(245, 241, 235, 0.82);
  color: rgba(50, 39, 35, 0.78);
  font-size: 12px;
  font-weight: 880;
  text-align: center;
}

.skin-report-main {
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  gap: 12px;
  min-height: 0;
}

.skin-face-card,
.skin-radar-card {
  min-width: 0;
  min-height: 0;
  padding: 12px;
  border: 1px solid rgba(203, 151, 128, 0.15);
  border-radius: 20px;
  background: rgba(255, 252, 248, 0.82);
}

.skin-face-card {
  display: grid;
  grid-template-columns: 0.88fr 1fr;
  gap: 14px;
  align-items: center;
}

.skin-face-visual {
  position: relative;
  min-height: 142px;
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual i,
.case-image-slot.lizi-skin-report-ui .skin-face-visual i:nth-of-type(1),
.case-image-slot.lizi-skin-report-ui .skin-face-visual i:nth-of-type(2),
.case-image-slot.lizi-skin-report-ui .skin-face-visual i:nth-of-type(3),
.case-image-slot.lizi-skin-report-ui .skin-face-visual i:nth-of-type(4),
.case-image-slot.lizi-skin-report-ui .skin-face-visual i:nth-of-type(5) {
  position: absolute;
  z-index: 0;
  display: block;
  margin: 0;
  padding: 0;
  opacity: 1;
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual .face-outline {
  inset: 9px 14px 4px;
  width: auto;
  height: auto;
  border: 3px solid rgba(70, 62, 58, 0.72);
  border-radius: 50% 50% 46% 46%;
  background: rgba(255, 242, 237, 0.52);
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual .face-zone {
  background: rgba(239, 129, 151, 0.2);
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual .face-zone-forehead {
  top: 28px;
  left: 40px;
  width: 64px;
  height: 32px;
  border-radius: 50% 50% 45% 45%;
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual .face-zone-left {
  top: 82px;
  left: 27px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual .face-zone-right {
  top: 82px;
  right: 27px;
  width: 42px;
  height: 42px;
  border-radius: 50%;
}

.case-image-slot.lizi-skin-report-ui .skin-face-visual .face-zone-chin {
  bottom: 19px;
  left: 54px;
  width: 38px;
  height: 24px;
  border-radius: 50%;
}

.skin-face-visual b {
  position: absolute;
  z-index: 1;
  display: block;
  background: #2b2522;
}

.skin-face-visual b:nth-of-type(1),
.skin-face-visual b:nth-of-type(2) {
  top: 72px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
}

.skin-face-visual b:nth-of-type(1) {
  left: 58px;
}

.skin-face-visual b:nth-of-type(2) {
  right: 58px;
}

.skin-face-visual b:nth-of-type(3) {
  bottom: 48px;
  left: 60px;
  width: 30px;
  height: 2px;
  border-radius: 999px;
  background: rgba(43, 37, 34, 0.5);
}

.skin-risk-list {
  display: grid;
  gap: 11px;
}

.skin-risk-list div {
  display: grid;
  grid-template-columns: 48px 1fr;
  align-items: center;
  gap: 10px;
}

.skin-risk-list strong {
  color: #6f4f3d;
  font-size: 14px;
  font-weight: 920;
}

.skin-risk-list span {
  position: relative;
  height: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(244, 216, 218, 0.7);
  color: transparent;
}

.skin-risk-list span::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: 76%;
  border-radius: inherit;
  background: #e984a0;
  content: "";
}

.skin-risk-list div:nth-child(2) span::before {
  width: 58%;
}

.skin-radar-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  justify-items: center;
  text-align: center;
}

.skin-radar-card strong {
  color: #6f4f3d;
  font-size: 15px;
  font-weight: 920;
}

.skin-radar-card svg {
  width: min(100%, 190px);
  height: 118px;
  margin-top: 2px;
}

.skin-radar-card polygon {
  fill: none;
  stroke: rgba(197, 143, 152, 0.28);
  stroke-width: 1;
}

.skin-radar-card polygon:nth-of-type(3) {
  fill: rgba(232, 119, 154, 0.22);
  stroke: #e4769a;
  stroke-width: 2;
}

.skin-radar-card circle {
  fill: #e4769a;
  stroke: #ffffff;
  stroke-width: 2;
}

.skin-radar-tags {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 6px;
  width: 100%;
}

.skin-radar-tags span {
  padding: 6px 7px;
  border-radius: 999px;
  background: rgba(255, 239, 244, 0.84);
  color: rgba(94, 65, 62, 0.72);
  font-size: 11px;
  font-weight: 820;
}

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

.skin-report-tasks article {
  min-height: 54px;
  padding: 9px 10px;
  border: 1px solid rgba(203, 151, 128, 0.13);
  border-radius: 16px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(255, 236, 220, 0.42));
}

.skin-report-tasks b,
.skin-report-tasks span {
  display: block;
}

.skin-report-tasks b {
  color: #211915;
  font-size: 12px;
  font-weight: 930;
}

.skin-report-tasks span {
  margin-top: 4px;
  color: rgba(65, 49, 44, 0.58);
  font-size: 11px;
  font-weight: 780;
}

.skin-report-footer {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 12px;
  padding-top: 8px;
  border-top: 1px solid rgba(203, 151, 128, 0.16);
}

.skin-report-footer small {
  display: inline-flex;
  width: fit-content;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 242, 246, 0.9);
  color: #9a536a;
  font-size: 10px;
  font-weight: 900;
}

.skin-report-footer strong {
  display: block;
  margin-top: 5px;
  font-family: var(--display);
  color: #171717;
  font-size: clamp(22px, 1.8vw, 28px);
  line-height: 0.95;
}

.skin-report-footer > span {
  color: rgba(65, 49, 44, 0.6);
  font-size: 11px;
  font-weight: 820;
  text-align: right;
}

@media (max-width: 560px) {
  .lizi-report-insight {
    height: auto;
    padding: 24px;
  }

  .report-trust-bridge,
  .report-action-matrix {
    grid-template-columns: 1fr;
  }

  .report-bridge-core {
    width: 46px;
    height: 46px;
    margin: 0 auto;
  }

  .report-bridge-core::before,
  .report-bridge-core::after,
  .report-bridge-core span {
    display: none;
  }

  .media-lizi-skin .case-image-slot.lizi-skin-report-ui,
  .skin-report-shell {
    height: auto;
    min-height: 0;
  }

  .skin-report-shell {
    padding: 16px;
  }

  .skin-report-card {
    gap: 10px;
    height: auto;
    min-height: 0;
    overflow: visible;
    padding: 16px;
  }

  .skin-report-head {
    display: grid;
  }

  .skin-report-head strong {
    font-size: 38px;
  }

  .skin-report-pills,
  .skin-report-main,
  .skin-report-tasks,
  .skin-face-card {
    grid-template-columns: 1fr;
  }

  .skin-face-visual {
    min-height: 150px;
  }

  .skin-report-footer {
    display: grid;
  }

  .skin-report-footer > span {
    text-align: left;
  }
}

.lizi-report-insight {
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  padding: 26px 28px;
}

.report-insight-head h3 {
  max-width: 360px;
  font-size: clamp(28px, 2.15vw, 33px);
}

.report-insight-head p {
  max-width: 348px;
  font-size: 12px;
}

.report-decision-system {
  position: relative;
  min-height: 304px;
  border: 1px solid rgba(188, 127, 112, 0.15);
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 46%, rgba(255, 215, 224, 0.58), transparent 32%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(255, 245, 241, 0.58));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.76);
}

.report-decision-system::before,
.report-decision-system::after {
  position: absolute;
  inset: 50% 34px auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(191, 128, 113, 0.38), transparent);
  content: "";
}

.report-decision-system::after {
  inset: 32px auto 32px 50%;
  width: 1px;
  height: auto;
  background: linear-gradient(180deg, transparent, rgba(191, 128, 113, 0.34), transparent);
}

.decision-report-sheet {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: 168px;
  min-height: 154px;
  padding: 16px;
  border: 1px solid rgba(218, 154, 142, 0.25);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 20px 52px rgba(118, 73, 62, 0.13);
  transform: translate(-50%, -50%);
}

.decision-report-sheet span {
  display: block;
  color: #b76f56;
  font-size: 11px;
  font-weight: 940;
}

.decision-report-sheet strong {
  display: block;
  margin-top: 8px;
  font-family: var(--display);
  color: #171717;
  font-size: 28px;
  line-height: 1;
}

.decision-report-sheet p {
  margin: 8px 0 0;
  color: rgba(37, 31, 28, 0.58);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.42;
}

.decision-report-sheet div {
  display: grid;
  gap: 6px;
  margin-top: 14px;
}

.decision-report-sheet i {
  display: block;
  height: 8px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(226, 119, 151, 0.82), rgba(250, 217, 219, 0.8));
}

.decision-report-sheet i:nth-child(2) {
  width: 72%;
}

.decision-report-sheet i:nth-child(3) {
  width: 84%;
}

.decision-node {
  position: absolute;
  z-index: 1;
  width: 128px;
  min-height: 72px;
  padding: 11px 12px;
  border: 1px solid rgba(188, 127, 112, 0.15);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 32px rgba(113, 74, 60, 0.07);
}

.decision-node small {
  color: #b66f55;
  font-size: 10px;
  font-weight: 940;
}

.decision-node strong {
  display: block;
  margin-top: 5px;
  color: #201814;
  font-size: 14px;
  font-weight: 930;
  line-height: 1.18;
}

.decision-risk {
  top: 18px;
  left: 18px;
}

.decision-language {
  top: 18px;
  right: 18px;
}

.decision-purchase {
  bottom: 18px;
  left: 18px;
}

.decision-asset {
  right: 18px;
  bottom: 18px;
}

.report-conversion-lanes {
  display: grid;
  gap: 8px;
}

.report-conversion-lanes article {
  display: grid;
  grid-template-columns: 32px 88px 1fr;
  align-items: center;
  gap: 10px;
  min-height: 48px;
  padding: 9px 11px;
  border: 1px solid rgba(188, 127, 112, 0.13);
  border-radius: 14px;
  background: rgba(255, 250, 246, 0.78);
}

.report-conversion-lanes b {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(229, 132, 146, 0.12);
  color: #b66f55;
  font-size: 11px;
  font-weight: 950;
}

.report-conversion-lanes strong {
  color: #171717;
  font-size: 15px;
  font-weight: 930;
}

.report-conversion-lanes span {
  color: rgba(37, 31, 28, 0.58);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.26;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-ui {
  position: relative;
  display: block;
  height: 100%;
  min-height: 0;
  padding: 0;
  overflow: hidden;
  border-radius: 22px;
  background:
    radial-gradient(circle at 8% 10%, rgba(255, 255, 255, 0.92), transparent 17%),
    radial-gradient(circle at 17% 82%, rgba(255, 184, 196, 0.28), transparent 19%),
    radial-gradient(circle at 96% 18%, rgba(255, 255, 255, 0.52), transparent 20%),
    linear-gradient(135deg, #fff7ef 0%, #fde7ed 62%, #f8dce5 100%);
}

.case-image-slot.lizi-skin-report-ui::before {
  position: absolute;
  left: 0;
  bottom: -18%;
  width: 42%;
  height: 46%;
  border-radius: 50%;
  background:
    radial-gradient(circle at 54% 48%, rgba(255, 255, 255, 0.55), transparent 22%),
    radial-gradient(circle at 48% 54%, rgba(242, 137, 160, 0.26), transparent 44%);
  opacity: 0.74;
  content: "";
}

.particle-growth-lab .case-image-slot.lizi-skin-report-ui::after {
  position: absolute;
  right: -10%;
  bottom: -16%;
  width: 30%;
  height: 38%;
  border: 1px solid rgba(255, 255, 255, 0.64);
  border-radius: 50%;
  background:
    radial-gradient(circle at 44% 42%, rgba(255, 255, 255, 0.72), transparent 15%),
    radial-gradient(circle at 62% 62%, rgba(244, 130, 153, 0.3), transparent 38%),
    rgba(255, 255, 255, 0.16);
  box-shadow: inset 0 0 24px rgba(255, 255, 255, 0.58);
  content: "";
}

.skin-report-title {
  position: absolute;
  top: 20%;
  left: 5%;
  z-index: 2;
  width: 27%;
  color: #704642;
}

.skin-report-title > strong {
  display: block;
  font-family: var(--display);
  font-size: clamp(30px, 3.6vw, 54px);
  font-weight: 760;
  line-height: 1;
}

.skin-report-title div {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 20px;
}

.skin-report-title span {
  color: #e45d80;
  font-size: 14px;
  font-weight: 780;
}

.skin-report-title em {
  padding: 5px 12px;
  border: 1px solid rgba(193, 107, 123, 0.18);
  border-radius: 999px;
  background: rgba(255, 244, 242, 0.76);
  color: rgba(103, 67, 64, 0.72);
  font-size: 12px;
  font-style: normal;
  font-weight: 760;
}

.skin-report-title ol {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 24px 0 0;
  padding: 0;
  list-style: none;
}

.skin-report-title li {
  position: relative;
  display: grid;
  justify-items: center;
  gap: 8px;
  color: rgba(85, 64, 60, 0.68);
  font-size: 11px;
  font-weight: 760;
  text-align: center;
}

.skin-report-title li::before {
  display: block;
  width: 30px;
  height: 30px;
  border: 1px solid rgba(212, 124, 139, 0.2);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.54);
  box-shadow: inset 0 0 0 8px rgba(230, 121, 152, 0.12);
  content: "";
}

.skin-report-title li:not(:last-child)::after {
  position: absolute;
  top: 14px;
  left: calc(50% + 21px);
  width: 24px;
  height: 1px;
  background: rgba(193, 107, 123, 0.18);
  content: "";
}

.skin-report-glass {
  position: absolute;
  top: 4.8%;
  right: 2.4%;
  z-index: 2;
  width: 67%;
  height: 80%;
  padding: 16px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.5);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.7),
    0 18px 54px rgba(103, 66, 56, 0.12);
  backdrop-filter: blur(12px);
}

.skin-report-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.34fr) minmax(0, 0.92fr);
  grid-template-rows: minmax(0, 1fr) 0.42fr;
  gap: 10px;
  height: 100%;
}

.skin-profile-card,
.skin-cycle-card,
.skin-trigger-card {
  min-width: 0;
  min-height: 0;
  border: 1px solid rgba(203, 151, 128, 0.14);
  border-radius: 18px;
  background: rgba(255, 252, 248, 0.66);
}

.skin-profile-card,
.skin-cycle-card {
  padding: 12px;
}

.skin-profile-card h4,
.skin-cycle-card h4,
.skin-trigger-card h4 {
  margin: 0;
  color: #6c3d3a;
  font-size: 16px;
  font-weight: 860;
}

.skin-profile-body {
  display: grid;
  grid-template-columns: minmax(104px, 0.88fr) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}

.skin-profile-card .skin-face-visual {
  min-height: 142px;
}

.skin-profile-card .skin-risk-list {
  gap: 9px;
}

.skin-profile-card .skin-risk-list div {
  grid-template-columns: 38px 1fr;
}

.skin-profile-card .skin-risk-list strong {
  font-size: 12px;
}

.skin-profile-card .skin-risk-list span {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  height: 18px;
  padding-right: 2px;
  background: rgba(244, 216, 218, 0.72);
  color: rgba(102, 67, 64, 0.74);
  font-size: 10px;
  font-weight: 760;
}

.skin-explain-box {
  margin-top: 6px;
  padding: 8px;
  border: 1px solid rgba(232, 126, 153, 0.15);
  border-radius: 14px;
  background: rgba(255, 247, 247, 0.62);
}

.skin-explain-box strong {
  display: block;
  color: #6c3d3a;
  font-size: 12px;
  font-weight: 900;
}

.skin-explain-box p {
  margin: 4px 0 0;
  color: rgba(75, 57, 53, 0.64);
  font-size: 9px;
  font-weight: 680;
  line-height: 1.35;
}

.skin-cycle-card {
  display: grid;
  grid-template-rows: auto 1fr auto;
}

.skin-radar-wrap {
  position: relative;
  min-height: 142px;
  margin-top: 2px;
}

.skin-radar-wrap svg {
  position: absolute;
  top: 12px;
  left: 50%;
  width: 148px;
  height: 118px;
  transform: translateX(-50%);
}

.skin-radar-wrap polygon {
  fill: none;
  stroke: rgba(197, 143, 152, 0.27);
  stroke-width: 1;
}

.skin-radar-wrap polygon:nth-of-type(3) {
  fill: rgba(232, 119, 154, 0.22);
  stroke: #e4769a;
  stroke-width: 2;
}

.skin-radar-wrap circle {
  fill: #e4769a;
  stroke: #ffffff;
  stroke-width: 2;
}

.radar-label {
  position: absolute;
  color: rgba(85, 64, 60, 0.68);
  font-size: 9px;
  font-weight: 760;
  white-space: nowrap;
}

.radar-top {
  top: 3px;
  left: 50%;
  transform: translateX(-50%);
}

.radar-left {
  top: 58px;
  left: 0;
}

.radar-right {
  top: 58px;
  right: 0;
}

.radar-bottom-left {
  bottom: 2px;
  left: 14px;
}

.radar-bottom-right {
  right: 14px;
  bottom: 2px;
}

.skin-tag-panel {
  padding-top: 6px;
  border-top: 1px solid rgba(203, 151, 128, 0.15);
}

.skin-tag-panel strong {
  display: block;
  color: #6c3d3a;
  font-size: 12px;
  font-weight: 900;
}

.skin-tag-panel div {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 6px;
}

.skin-tag-panel span {
  padding: 4px 9px;
  border: 1px solid rgba(228, 112, 143, 0.18);
  border-radius: 999px;
  background: rgba(255, 235, 240, 0.68);
  color: #a84d63;
  font-size: 9px;
  font-weight: 780;
}

.skin-trigger-card {
  grid-column: 1 / -1;
  padding: 10px 12px;
}

.skin-trigger-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 6px;
}

.skin-trigger-list article {
  display: grid;
  grid-template-columns: 34px 1fr;
  align-items: center;
  gap: 6px 8px;
  min-height: 58px;
  padding: 8px;
  border: 1px solid rgba(203, 151, 128, 0.13);
  border-radius: 14px;
  background: rgba(255, 247, 247, 0.66);
}

.case-image-slot.lizi-skin-report-ui .skin-trigger-list i {
  position: static;
  z-index: auto;
  display: block;
  grid-row: 1 / 3;
  width: 30px;
  height: 30px;
  padding: 0;
  border-radius: 14px;
  background:
    radial-gradient(circle at 62% 38%, rgba(255, 255, 255, 0.72), transparent 20%),
    linear-gradient(135deg, #f47ea0, #f4c2c4);
  opacity: 1;
}

.skin-trigger-list strong {
  display: block;
  color: #513733;
  font-size: 11px;
  font-weight: 900;
}

.skin-trigger-list span {
  display: block;
  margin-top: 2px;
  color: rgba(75, 57, 53, 0.62);
  font-size: 8.8px;
  line-height: 1.22;
}

.skin-trigger-list b {
  grid-column: 2;
  width: fit-content;
  padding: 4px 9px;
  border-radius: 999px;
  background: rgba(255, 222, 229, 0.82);
  color: #c64d72;
  font-size: 9px;
  font-weight: 820;
  white-space: nowrap;
}

.skin-report-nav {
  position: absolute;
  right: 9%;
  bottom: 3.6%;
  z-index: 2;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 9px;
  width: 54%;
}

.skin-report-nav span {
  display: grid;
  place-items: center;
  min-height: 36px;
  border: 1px solid rgba(255, 255, 255, 0.66);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: rgba(88, 63, 60, 0.76);
  font-size: 10px;
  font-weight: 820;
  box-shadow: 0 12px 28px rgba(104, 68, 60, 0.09);
}

.skin-report-nav span:first-child {
  color: #c84e76;
  background: rgba(255, 246, 247, 0.82);
}

@media (max-width: 560px) {
  .lizi-report-insight {
    grid-template-rows: auto auto auto;
    height: auto;
    max-height: none;
    padding: 24px;
  }

  .report-decision-system {
    min-height: 420px;
  }

  .decision-report-sheet {
    width: 174px;
  }

  .decision-node {
    width: 124px;
  }

  .report-conversion-lanes article {
    grid-template-columns: 32px 1fr;
  }

  .report-conversion-lanes span {
    grid-column: 2;
  }

  .media-lizi-skin .case-image-slot.lizi-skin-report-ui {
    min-height: 980px;
  }

  .skin-report-title,
  .skin-report-glass,
  .skin-report-nav {
    position: relative;
    top: auto;
    right: auto;
    bottom: auto;
    left: auto;
    width: auto;
  }

  .skin-report-title {
    padding: 30px 24px 0;
  }

  .skin-report-title > strong {
    font-size: 42px;
  }

  .skin-report-glass {
    height: auto;
    margin: 22px 14px 0;
    padding: 14px;
  }

  .skin-report-grid,
  .skin-profile-body,
  .skin-trigger-list {
    grid-template-columns: 1fr;
  }

  .skin-trigger-card {
    grid-column: auto;
  }

  .skin-report-nav {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
    margin: 16px 20px 22px;
  }
}

.particle-growth-lab .case-media-panel {
  background: rgba(255, 255, 255, 0.54);
}

.particle-growth-lab .case-media-header {
  border-bottom-color: rgba(203, 151, 128, 0.18);
}

.particle-growth-lab .case-media-header span {
  border: 1px solid rgba(255, 226, 212, 0.74);
  background: rgba(255, 251, 247, 0.78);
  color: #6f4f3d;
  font-size: 14px;
  font-weight: 880;
  box-shadow: 0 10px 24px rgba(154, 91, 54, 0.06);
}

.particle-growth-lab .case-media-header i {
  background: rgba(168, 148, 137, 0.36);
}

.particle-growth-lab .case-image-slot {
  min-height: 570px;
  background:
    radial-gradient(circle at 21% 22%, rgba(255, 255, 255, 0.84), transparent 20%),
    linear-gradient(135deg, #fff0d6 0%, #fde7ef 52%, #e4f2ff 100%);
}

.particle-growth-lab .case-image-slot::after {
  position: absolute;
  top: 88px;
  right: 70px;
  width: min(280px, 34%);
  height: 210px;
  border: 1px solid rgba(17, 17, 17, 0.1);
  border-radius: 28px;
  background:
    linear-gradient(180deg, rgba(17, 17, 17, 0.12) 0 18px, transparent 18px),
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.32));
  content: "";
}

.robot-command-console .case-tab-stage,
.robot-command-console .case-tab-stage.reverse {
  grid-template-columns: minmax(0, 1.28fr) minmax(300px, 0.72fr);
  gap: 28px;
  height: 690px;
  min-height: 690px;
  max-height: 690px;
  align-items: stretch;
}

.robot-command-console .case-media-panel {
  order: -1;
  background: #f6f9fa;
}

.robot-command-console .case-tab-copy,
.robot-command-console .case-media-panel {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.robot-command-console .case-tab-copy {
  background: #101a20;
  color: #f8f6f0;
}

.robot-command-console .robot-scene-insight {
  position: relative;
  grid-template-rows: auto auto auto auto;
  gap: 15px;
  align-content: center;
  height: 100%;
  min-height: 0;
  padding: 24px 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 84% 10%, rgba(80, 154, 205, 0.18), transparent 34%),
    linear-gradient(160deg, #0e181f 0%, #101a20 52%, #0a0d10 100%);
}

.robot-scene-insight::before {
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(150, 190, 215, 0.13);
  border-radius: 22px;
  content: "";
  pointer-events: none;
}

.robot-scene-insight > * {
  position: relative;
  z-index: 1;
}

.robot-scene-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(165, 208, 232, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: rgba(194, 228, 247, 0.86);
  font-size: 12px;
  font-weight: 900;
}

.robot-scene-head h3 {
  display: block;
  max-width: 430px;
  margin: 12px 0 0;
  font-size: clamp(29px, 2.1vw, 34px);
  line-height: 1.06;
}

.robot-scene-head h3 span {
  display: block;
}

.robot-scene-head p {
  max-width: 420px;
  margin: 10px 0 0;
  color: rgba(238, 248, 252, 0.72);
  font-size: 13px;
  line-height: 1.45;
}

.scene-value-map {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 112px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 152px;
  padding: 10px;
  border: 1px solid rgba(128, 176, 205, 0.16);
  border-radius: 22px;
  background:
    linear-gradient(90deg, transparent 0 28%, rgba(112, 164, 196, 0.15) 28% 29%, transparent 29% 71%, rgba(112, 164, 196, 0.15) 71% 72%, transparent 72%),
    rgba(255, 255, 255, 0.045);
}

.scene-value-col {
  display: grid;
  gap: 5px;
}

.scene-value-col-right {
  text-align: right;
}

.scene-value-col-right small {
  justify-self: end;
}

.scene-value-col small,
.scene-value-core small {
  color: rgba(194, 228, 247, 0.58);
  font-size: 11px;
  font-weight: 900;
}

.scene-value-col b {
  min-height: 26px;
  padding: 6px 9px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.075);
  color: rgba(249, 252, 253, 0.94);
  font-size: 12px;
  font-weight: 900;
}

.scene-value-col-right b {
  justify-self: stretch;
  width: 100%;
  text-align: right;
  background: rgba(67, 124, 160, 0.22);
  color: rgba(233, 247, 255, 0.96);
}

.scene-value-core {
  display: grid;
  place-items: center;
  gap: 6px;
  min-height: 104px;
  padding: 10px 9px;
  border: 1px solid rgba(92, 167, 213, 0.32);
  border-radius: 999px;
  background:
    radial-gradient(circle, rgba(79, 164, 216, 0.32), transparent 68%),
    rgba(8, 20, 28, 0.86);
  box-shadow: 0 18px 42px rgba(3, 10, 16, 0.28);
  text-align: center;
}

.scene-value-core span {
  display: grid;
  place-items: center;
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(96, 174, 222, 0.22);
  color: #dff4ff;
  font-size: 15px;
  font-weight: 950;
}

.scene-value-core strong {
  color: #ffffff;
  font-size: 15px;
  font-weight: 950;
}

.scene-deal-steps {
  display: grid;
  gap: 7px;
}

.scene-deal-steps article {
  display: grid;
  grid-template-columns: 42px minmax(74px, 0.36fr) minmax(0, 1fr);
  align-items: center;
  gap: 12px;
  min-height: 42px;
  padding: 6px 11px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.065);
}

.scene-deal-steps b {
  display: grid;
  place-items: center;
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: rgba(79, 164, 216, 0.18);
  color: #9fd8f8;
  font-size: 12px;
  font-weight: 950;
}

.scene-deal-steps strong {
  color: #f8fbfc;
  font-size: 14px;
  font-weight: 950;
}

.scene-deal-steps span {
  color: rgba(238, 248, 252, 0.66);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.4;
}

.scene-result-strip {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 5px;
  padding-top: 13px;
  border-top: 1px solid rgba(160, 202, 226, 0.14);
}

.scene-result-strip span {
  display: flex;
  align-items: center;
  min-height: 40px;
  padding: 9px 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(245, 250, 252, 0.92);
  font-size: 13px;
  font-weight: 900;
}

.scene-result-strip span::before {
  width: 6px;
  height: 6px;
  margin-right: 7px;
  border-radius: 50%;
  background: #60aede;
  content: "";
}

.robot-proof-insight {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-content: center;
  gap: 17px;
  height: 100%;
  min-height: 0;
  padding: 24px 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 16% 18%, rgba(111, 181, 219, 0.2), transparent 32%),
    radial-gradient(circle at 86% 78%, rgba(239, 154, 58, 0.14), transparent 34%),
    linear-gradient(160deg, #0d181f 0%, #101820 54%, #090d10 100%);
}

.robot-proof-insight::before {
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(150, 190, 215, 0.13);
  border-radius: 22px;
  content: "";
  pointer-events: none;
}

.robot-proof-insight > * {
  position: relative;
  z-index: 1;
}

.proof-insight-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(165, 208, 232, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: rgba(194, 228, 247, 0.86);
  font-size: 12px;
  font-weight: 900;
}

.proof-insight-head h3 {
  max-width: 420px;
  margin: 12px 0 0;
  color: #f8fbfc;
  font-size: clamp(29px, 2.1vw, 34px);
  line-height: 1.06;
}

.proof-insight-head h3 span {
  display: block;
}

.proof-insight-head p {
  max-width: 420px;
  margin: 10px 0 0;
  color: rgba(238, 248, 252, 0.7);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.proof-evidence-board {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 108px minmax(0, 1fr);
  align-items: center;
  gap: 8px;
  min-height: 154px;
  padding: 12px;
  border: 1px solid rgba(128, 176, 205, 0.16);
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 50%, rgba(101, 174, 216, 0.16), transparent 42%),
    rgba(255, 255, 255, 0.045);
}

.proof-evidence-board::before,
.proof-evidence-board::after {
  position: absolute;
  top: 50%;
  width: 32px;
  height: 1px;
  background: linear-gradient(90deg, rgba(96, 174, 222, 0.08), rgba(96, 174, 222, 0.56));
  content: "";
}

.proof-evidence-board::before {
  left: 32%;
}

.proof-evidence-board::after {
  right: 32%;
  transform: rotate(180deg);
}

.proof-source-list,
.proof-question-list {
  display: grid;
  gap: 7px;
}

.proof-source-list span,
.proof-question-list span {
  color: rgba(194, 228, 247, 0.58);
  font-size: 11px;
  font-weight: 900;
}

.proof-question-list {
  text-align: right;
}

.proof-question-list span {
  justify-self: end;
}

.proof-source-list b,
.proof-question-list b {
  min-height: 28px;
  padding: 7px 9px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.078);
  color: rgba(249, 252, 253, 0.94);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.15;
}

.proof-question-list b {
  justify-self: end;
  width: calc(100% - 8px);
  background: rgba(67, 124, 160, 0.22);
  color: rgba(233, 247, 255, 0.96);
}

.proof-core-card {
  position: relative;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 5px;
  min-height: 118px;
  padding: 12px 9px;
  border: 1px solid rgba(92, 167, 213, 0.28);
  border-radius: 24px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.1), rgba(255, 255, 255, 0.04)),
    rgba(8, 20, 28, 0.86);
  box-shadow: 0 18px 42px rgba(3, 10, 16, 0.28);
  text-align: center;
}

.proof-core-card::before {
  width: 35px;
  height: 42px;
  border: 1px solid rgba(159, 216, 248, 0.4);
  border-radius: 9px;
  background:
    linear-gradient(rgba(159, 216, 248, 0.55), rgba(159, 216, 248, 0.55)) 9px 12px / 17px 2px no-repeat,
    linear-gradient(rgba(159, 216, 248, 0.38), rgba(159, 216, 248, 0.38)) 9px 20px / 17px 2px no-repeat,
    linear-gradient(rgba(239, 154, 58, 0.7), rgba(239, 154, 58, 0.7)) 9px 28px / 12px 2px no-repeat,
    rgba(96, 174, 222, 0.12);
  content: "";
}

.proof-core-card small {
  color: rgba(194, 228, 247, 0.58);
  font-size: 11px;
  font-weight: 900;
}

.proof-core-card strong {
  color: #ffffff;
  font-size: 16px;
  font-weight: 950;
}

.proof-core-card em {
  max-width: 86px;
  color: rgba(238, 248, 252, 0.62);
  font-size: 10px;
  font-style: normal;
  font-weight: 760;
  line-height: 1.35;
}

.proof-memo-system {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px;
  grid-template-rows: minmax(0, 1fr) auto;
  grid-template-areas:
    "paper verdict"
    "action action";
  gap: 12px;
  min-height: 0;
  height: 100%;
  padding: 0;
  overflow: hidden;
  border-radius: 24px;
  background:
    radial-gradient(circle at 78% 12%, rgba(96, 174, 222, 0.18), transparent 30%),
    radial-gradient(circle at 16% 84%, rgba(239, 154, 58, 0.12), transparent 30%),
    rgba(255, 255, 255, 0.045);
}

.proof-memo-system::before {
  content: none;
}

.proof-memo-paper,
.proof-memo-verdict,
.proof-memo-action {
  position: relative;
  z-index: 1;
}

.proof-memo-paper {
  grid-area: paper;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
  padding: 16px;
  border: 1px solid rgba(160, 202, 226, 0.14);
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.11), rgba(255, 255, 255, 0.055)),
    rgba(8, 20, 28, 0.54);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.05);
}

.proof-memo-title {
  display: grid;
  gap: 8px;
  padding-bottom: 12px;
  border-bottom: 1px solid rgba(160, 202, 226, 0.12);
}

.proof-memo-title span,
.proof-memo-action span {
  color: rgba(194, 228, 247, 0.58);
  font-size: 11px;
  font-weight: 900;
}

.proof-memo-title strong {
  max-width: 210px;
  color: #ffffff;
  font-size: 19px;
  font-weight: 950;
  line-height: 1.14;
}

.proof-memo-questions {
  display: grid;
  align-content: center;
  gap: 8px;
  min-height: 0;
}

.proof-memo-questions article {
  position: relative;
  display: grid;
  gap: 5px;
  min-height: 72px;
  padding: 10px 12px 10px 18px;
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.07);
}

.proof-memo-questions article::before {
  position: absolute;
  top: 12px;
  bottom: 12px;
  left: 0;
  width: 4px;
  border-radius: 999px;
  background: linear-gradient(180deg, #60aede, rgba(240, 168, 95, 0.86));
  content: "";
}

.proof-memo-questions b {
  color: #f8fbfc;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.16;
}

.proof-memo-questions span {
  color: rgba(238, 248, 252, 0.64);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.38;
}

.proof-memo-verdict {
  grid-area: verdict;
  z-index: 2;
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 12px;
  min-height: 0;
  padding: 14px 10px;
  overflow: hidden;
  border: 1px solid rgba(96, 174, 222, 0.22);
  border-radius: 20px;
  background:
    radial-gradient(circle at 50% 28%, rgba(96, 174, 222, 0.22), transparent 42%),
    rgba(255, 255, 255, 0.06);
  text-align: center;
}

.proof-memo-verdict::before {
  width: 78px;
  height: 78px;
  border: 1px solid rgba(96, 174, 222, 0.34);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(12, 26, 35, 0.98) 0 48%, transparent 49%),
    conic-gradient(from 218deg, #60aede 0 70%, rgba(240, 168, 95, 0.86) 70% 87%, rgba(255, 255, 255, 0.14) 87% 100%);
  box-shadow:
    0 16px 34px rgba(3, 10, 16, 0.28),
    inset 0 0 0 7px rgba(8, 20, 28, 0.92);
  content: "";
}

.proof-memo-verdict small {
  color: rgba(194, 228, 247, 0.62);
  font-size: 11px;
  font-weight: 900;
}

.proof-memo-verdict strong {
  color: #ffffff;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.15;
}

.proof-memo-verdict div {
  display: grid;
  gap: 7px;
  width: 100%;
}

.proof-memo-verdict i {
  display: block;
  height: 7px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
}

.proof-memo-verdict i::before {
  display: block;
  width: 74%;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #60aede, #f0a85f);
  content: "";
}

.proof-memo-verdict span {
  color: rgba(238, 248, 252, 0.62);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.3;
}

.proof-memo-action {
  grid-area: action;
  display: grid;
  grid-template-columns: minmax(0, 0.78fr) minmax(0, 1fr);
  gap: 8px 14px;
  align-items: center;
  min-height: 104px;
  padding: 13px 15px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(239, 154, 58, 0.13), rgba(96, 174, 222, 0.07)),
    rgba(255, 255, 255, 0.06);
}

.proof-memo-action span {
  grid-column: 1 / -1;
}

.proof-memo-action strong {
  color: #f8fbfc;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.12;
}

.proof-memo-action p {
  margin: 0;
  color: rgba(238, 248, 252, 0.66);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.42;
}

.proof-decision-panel {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  min-height: 244px;
  padding: 14px;
  overflow: hidden;
  border: 1px solid rgba(128, 176, 205, 0.16);
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 50%, rgba(96, 174, 222, 0.2), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.025));
}

.proof-decision-panel::before {
  position: absolute;
  inset: 36px 68px;
  border: 1px dashed rgba(160, 202, 226, 0.18);
  border-radius: 999px;
  content: "";
}

.proof-decision-panel::after {
  position: absolute;
  top: 50%;
  left: 30px;
  right: 30px;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(160, 202, 226, 0.16), transparent);
  content: "";
}

.proof-decision-core {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 5px;
  width: 134px;
  height: 134px;
  padding: 14px;
  border: 1px solid rgba(96, 174, 222, 0.34);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(12, 26, 35, 0.98) 0 48%, transparent 49%),
    conic-gradient(from 220deg, #60aede 0 64%, rgba(240, 168, 95, 0.86) 64% 83%, rgba(255, 255, 255, 0.14) 83% 100%);
  box-shadow:
    0 20px 48px rgba(3, 10, 16, 0.32),
    inset 0 0 0 10px rgba(8, 20, 28, 0.9);
  text-align: center;
  transform: translate(-50%, -50%);
}

.proof-decision-core small {
  color: rgba(194, 228, 247, 0.62);
  font-size: 11px;
  font-weight: 900;
}

.proof-decision-core strong {
  color: #ffffff;
  font-size: 23px;
  font-weight: 950;
  line-height: 1;
}

.proof-decision-core span {
  max-width: 84px;
  color: rgba(238, 248, 252, 0.66);
  font-size: 10px;
  font-weight: 780;
  line-height: 1.28;
}

.proof-metric-card {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 92px;
  padding: 12px 13px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.07);
}

.proof-metric-card b {
  width: fit-content;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(96, 174, 222, 0.14);
  color: #9fd8f8;
  font-size: 11px;
  font-weight: 950;
}

.proof-metric-card strong {
  color: #f8fbfc;
  font-size: 13px;
  font-weight: 950;
  line-height: 1.15;
}

.proof-metric-card span {
  color: rgba(238, 248, 252, 0.6);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.3;
}

.proof-metric-card-b,
.proof-metric-card-d {
  text-align: right;
}

.proof-metric-card-b b,
.proof-metric-card-d b {
  justify-self: end;
  background: rgba(240, 168, 95, 0.14);
  color: #f0b06c;
}

.proof-decision-actions {
  display: grid;
  gap: 0;
  min-height: 132px;
  padding: 8px 12px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(96, 174, 222, 0.12), transparent 34%),
    rgba(255, 255, 255, 0.055);
}

.proof-decision-actions article {
  display: grid;
  grid-template-columns: 42px minmax(82px, 0.38fr) minmax(0, 1fr);
  align-items: center;
  gap: 10px;
  min-height: 38px;
  padding: 6px 0;
}

.proof-decision-actions article:not(:last-child) {
  border-bottom: 1px solid rgba(160, 202, 226, 0.11);
}

.proof-decision-actions b {
  display: grid;
  place-items: center;
  width: 30px;
  height: 24px;
  border-radius: 999px;
  background: rgba(239, 154, 58, 0.16);
  color: #f0b06c;
  font-size: 11px;
  font-weight: 950;
}

.proof-decision-actions strong {
  color: #f8fbfc;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.18;
}

.proof-decision-actions span {
  color: rgba(238, 248, 252, 0.66);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.34;
}

.proof-action-path {
  display: grid;
  gap: 8px;
}

.proof-action-path article {
  display: grid;
  grid-template-columns: 40px minmax(66px, 0.34fr) minmax(0, 1fr);
  align-items: center;
  gap: 11px;
  min-height: 48px;
  padding: 8px 11px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.065);
}

.proof-action-path b {
  display: grid;
  place-items: center;
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: rgba(239, 154, 58, 0.16);
  color: #f0b06c;
  font-size: 12px;
  font-weight: 950;
}

.proof-action-path strong {
  color: #f8fbfc;
  font-size: 14px;
  font-weight: 950;
}

.proof-action-path span {
  color: rgba(238, 248, 252, 0.66);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.4;
}

.proof-result-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0;
  padding: 8px;
  border-top: 1px solid rgba(160, 202, 226, 0.14);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.045);
}

.proof-result-row span {
  display: flex;
  justify-content: center;
  align-items: center;
  min-height: 32px;
  padding: 7px 8px;
  border-radius: 0;
  background: transparent;
  color: rgba(245, 250, 252, 0.92);
  font-size: 12px;
  font-weight: 900;
}

.proof-result-row span:not(:last-child) {
  border-right: 1px solid rgba(160, 202, 226, 0.12);
}

.proof-result-row span::before {
  width: 6px;
  height: 6px;
  margin-right: 7px;
  border-radius: 50%;
  background: #f0a85f;
  content: "";
}

.robot-channel-insight {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-content: center;
  gap: 16px;
  height: 100%;
  min-height: 0;
  padding: 24px 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 14%, rgba(96, 174, 222, 0.2), transparent 32%),
    radial-gradient(circle at 86% 84%, rgba(240, 168, 95, 0.14), transparent 34%),
    linear-gradient(160deg, #0d181f 0%, #101820 54%, #090d10 100%);
}

.robot-channel-insight::before {
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(150, 190, 215, 0.13);
  border-radius: 22px;
  content: "";
  pointer-events: none;
}

.robot-channel-insight > * {
  position: relative;
  z-index: 1;
}

.channel-insight-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(165, 208, 232, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: rgba(194, 228, 247, 0.86);
  font-size: 12px;
  font-weight: 900;
}

.channel-insight-head h3 {
  max-width: 420px;
  margin: 12px 0 0;
  color: #f8fbfc;
  font-size: clamp(28px, 2vw, 33px);
  line-height: 1.06;
}

.channel-insight-head p {
  max-width: 420px;
  margin: 10px 0 0;
  color: rgba(238, 248, 252, 0.7);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.channel-training-studio {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 0;
  height: 100%;
}

.training-method-board {
  position: relative;
  display: grid;
  gap: 6px;
  min-height: 112px;
  padding: 15px 16px 15px 100px;
  overflow: hidden;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(96, 174, 222, 0.18), rgba(255, 255, 255, 0.06)),
    rgba(255, 255, 255, 0.055);
}

.training-method-board::before {
  position: absolute;
  top: 18px;
  left: 18px;
  width: 62px;
  height: 68px;
  border: 1px solid rgba(160, 202, 226, 0.22);
  border-radius: 13px;
  background:
    linear-gradient(rgba(159, 216, 248, 0.56), rgba(159, 216, 248, 0.56)) 14px 18px / 38px 2px no-repeat,
    linear-gradient(rgba(159, 216, 248, 0.38), rgba(159, 216, 248, 0.38)) 14px 31px / 30px 2px no-repeat,
    linear-gradient(rgba(240, 168, 95, 0.76), rgba(240, 168, 95, 0.76)) 14px 44px / 34px 2px no-repeat,
    rgba(8, 20, 28, 0.78);
  box-shadow: 0 14px 30px rgba(3, 10, 16, 0.22);
  content: "";
}

.training-method-board span,
.training-output-strip span {
  color: rgba(194, 228, 247, 0.58);
  font-size: 11px;
  font-weight: 900;
}

.training-method-board strong {
  color: #ffffff;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.16;
  white-space: nowrap;
}

.training-method-board p {
  margin: 0;
  color: rgba(238, 248, 252, 0.64);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.36;
}

.training-seat-map {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-height: 0;
  padding: 12px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0.035));
}

.training-seat-map::before {
  position: absolute;
  top: 50%;
  right: 16px;
  left: 16px;
  height: 1px;
  background: rgba(160, 202, 226, 0.12);
  content: "";
}

.training-seat-map::after {
  position: absolute;
  top: 16px;
  bottom: 16px;
  left: 50%;
  width: 1px;
  background: rgba(160, 202, 226, 0.12);
  content: "";
}

.training-seat-map article {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 102px;
  padding: 13px 12px;
  border: 1px solid rgba(160, 202, 226, 0.12);
  border-radius: 18px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.05));
}

.training-seat-map article::before {
  width: 26px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, #60aede, #f0a85f);
  content: "";
}

.training-seat-map small {
  color: rgba(194, 228, 247, 0.58);
  font-size: 10px;
  font-weight: 900;
}

.training-seat-map b {
  color: #f8fbfc;
  font-size: 16px;
  font-weight: 950;
}

.training-seat-map span {
  color: rgba(238, 248, 252, 0.62);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.32;
}

.training-output-strip {
  display: grid;
  grid-template-columns: 86px repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-items: center;
  min-height: 74px;
  padding: 12px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(240, 168, 95, 0.12), rgba(96, 174, 222, 0.09)),
    rgba(255, 255, 255, 0.055);
}

.training-output-strip b {
  display: grid;
  place-items: center;
  min-height: 40px;
  padding: 8px 7px;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(248, 251, 252, 0.94);
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.robot-command-console .case-tab-copy > span,
.robot-command-console .case-tab-copy p {
  color: rgba(248, 246, 240, 0.68);
}

.robot-command-console .case-bullet-list li,
.edu-skill-console .case-bullet-list li {
  background: rgba(255, 255, 255, 0.12);
  color: #f8f6f0;
}

.robot-command-console .case-image-slot {
  min-height: 570px;
  align-content: center;
  background:
    linear-gradient(90deg, rgba(17, 17, 17, 0.05) 0 1px, transparent 1px 100%),
    linear-gradient(0deg, rgba(17, 17, 17, 0.05) 0 1px, transparent 1px 100%),
    linear-gradient(135deg, #dde9f0, #f8faf8);
  background-size: 68px 68px, 68px 68px, auto;
}

.robot-command-console .case-image-slot.case-image-photo {
  height: 100%;
  min-height: 0;
  padding: 0;
  background: #eef4f7;
}

.robot-command-console .case-image-slot.case-image-photo::after {
  content: none;
}

.robot-command-console .robot-scene-photo img {
  object-position: center center;
}

.robot-command-console .robot-photo-caption {
  bottom: 22px;
  left: 22px;
  gap: 6px;
  width: min(248px, calc(100% - 44px));
  max-width: 248px;
  padding: 12px 18px 13px 14px;
  border-radius: 16px;
  border-color: rgba(190, 214, 230, 0.62);
  background: linear-gradient(135deg, rgba(248, 252, 255, 0.86), rgba(225, 238, 247, 0.62));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.74),
    0 18px 48px rgba(17, 35, 46, 0.16);
}

.robot-command-console .robot-photo-caption small {
  padding: 4px 8px;
  background: rgba(235, 246, 255, 0.9);
  color: #286081;
  font-size: 11px;
}

.robot-command-console .robot-photo-caption strong {
  color: rgba(16, 29, 38, 0.92);
  font-size: clamp(22px, 1.54vw, 27px);
}

.robot-command-console .robot-photo-caption span {
  color: rgba(22, 38, 48, 0.66);
  font-size: 12px;
  line-height: 1.45;
}

.media-robot-channel .case-image-slot.robot-channel-capability-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.96), transparent 28%),
    radial-gradient(circle at 84% 18%, rgba(93, 171, 222, 0.2), transparent 30%),
    radial-gradient(circle at 72% 88%, rgba(240, 168, 95, 0.16), transparent 34%),
    linear-gradient(135deg, #f6fbff 0%, #edf6fb 50%, #fff7ed 100%);
}

.media-robot-channel .robot-channel-capability-image::before,
.media-robot-channel .robot-channel-capability-image::after {
  content: none;
}

.robot-channel-capability-image strong,
.robot-channel-capability-image span,
.robot-channel-capability-image i {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.channel-capability-map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  height: 100%;
  color: #172631;
}

.channel-map-head {
  display: grid;
  gap: 7px;
  max-width: 640px;
}

.channel-map-head span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(45, 115, 152, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #286081;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.channel-map-head strong {
  font-family: var(--display);
  font-size: clamp(29px, 2.1vw, 34px);
  font-weight: 900;
  line-height: 1.02;
}

.channel-map-head p {
  max-width: 620px;
  margin: 0;
  color: rgba(29, 47, 58, 0.64);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.channel-map-body {
  display: grid;
  grid-template-columns: minmax(250px, 0.86fr) minmax(0, 1.14fr);
  gap: 12px;
  min-height: 0;
}

.channel-playbook-panel,
.channel-training-track article,
.channel-map-footer article {
  border: 1px solid rgba(66, 126, 165, 0.13);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(30, 62, 80, 0.07);
}

.channel-playbook-panel {
  display: grid;
  align-content: center;
  gap: 13px;
  min-height: 0;
  padding: 18px;
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 255, 255, 0.58)),
    radial-gradient(circle at 50% 20%, rgba(98, 181, 231, 0.16), transparent 36%);
}

.channel-playbook-panel > span,
.channel-map-footer b {
  color: #286081;
  font-size: 16px;
  font-weight: 900;
}

.channel-playbook-panel strong {
  max-width: 280px;
  color: #172631;
  font-size: 23px;
  font-weight: 950;
  line-height: 1.12;
}

.channel-playbook-panel div {
  display: grid;
  gap: 8px;
}

.channel-playbook-panel b {
  display: flex;
  align-items: center;
  min-height: 38px;
  padding: 9px 11px;
  border-radius: 13px;
  background: rgba(238, 247, 252, 0.86);
  color: rgba(29, 47, 58, 0.82);
  font-size: 14px;
  font-weight: 900;
}

.channel-playbook-panel b::before {
  content: none;
}

.channel-playbook-panel svg,
.channel-training-track b svg {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-right: 8px;
  fill: none;
  stroke: #286081;
  stroke-width: 1.9;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.channel-training-track {
  position: relative;
  display: grid;
  gap: 10px;
  align-content: center;
  min-height: 0;
}

.channel-training-track::before {
  position: absolute;
  top: 20px;
  bottom: 20px;
  left: 27px;
  width: 2px;
  background: linear-gradient(180deg, rgba(45, 115, 152, 0.34), rgba(240, 168, 95, 0.28));
  content: "";
}

.channel-training-track article {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(104px, 0.36fr) minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  min-height: 86px;
  padding: 12px;
  border-radius: 18px;
}

.channel-training-track small {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: #286081;
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.channel-training-track b {
  display: flex;
  align-items: center;
  color: #172631;
  font-size: 20px;
  font-weight: 950;
}

.channel-training-track span {
  color: rgba(29, 47, 58, 0.62);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.34;
}

.channel-map-footer {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.channel-map-footer article {
  display: grid;
  gap: 5px;
  align-content: center;
  min-height: 74px;
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.7);
}

.channel-map-footer span {
  color: rgba(29, 47, 58, 0.58);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.28;
}

.robot-command-console .case-image-slot::after {
  position: absolute;
  inset: auto 38px 42px 38px;
  height: 34%;
  border-radius: 20px;
  background:
    linear-gradient(90deg, #7893a3 0 16%, transparent 16% 20%, #7893a3 20% 39%, transparent 39% 44%, #7893a3 44% 66%, transparent 66% 71%, #7893a3 71% 100%);
  opacity: 0.86;
  content: "";
}

.robot-command-console .media-robot-channel .robot-channel-capability-image::after {
  content: none;
}

.media-robot-follow .case-image-slot.robot-follow-operation-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 16% 16%, rgba(255, 255, 255, 0.96), transparent 28%),
    radial-gradient(circle at 86% 74%, rgba(240, 168, 95, 0.17), transparent 34%),
    linear-gradient(135deg, #eef7fc 0%, #f8fbfc 46%, #fff7ea 100%);
}

.media-robot-follow .robot-follow-operation-image::before,
.robot-command-console .media-robot-follow .robot-follow-operation-image::after {
  content: none;
}

.robot-follow-operation-image strong,
.robot-follow-operation-image span,
.robot-follow-operation-image i {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.follow-operation-board {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  color: #172631;
}

.follow-board-head {
  display: grid;
  gap: 7px;
  max-width: 690px;
}

.follow-board-head span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(45, 115, 152, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: #286081;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.follow-board-head strong {
  font-family: var(--display);
  font-size: clamp(30px, 2.2vw, 36px);
  font-weight: 900;
  line-height: 1.04;
}

.follow-board-head p {
  max-width: 650px;
  margin: 0;
  color: rgba(29, 47, 58, 0.64);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.follow-board-main {
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(230px, 0.88fr);
  gap: 12px;
  min-height: 0;
}

.follow-segment-matrix,
.follow-action-queue,
.follow-loop-strip span {
  border: 1px solid rgba(66, 126, 165, 0.13);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(30, 62, 80, 0.07);
}

.follow-segment-matrix {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 9px;
  min-height: 0;
  padding: 36px 14px 14px 46px;
  overflow: hidden;
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(45, 115, 152, 0.08), transparent 50%),
    linear-gradient(0deg, rgba(240, 168, 95, 0.08), transparent 52%),
    rgba(255, 255, 255, 0.7);
}

.follow-segment-matrix::before,
.follow-segment-matrix::after {
  position: absolute;
  background: rgba(45, 115, 152, 0.13);
  content: "";
}

.follow-segment-matrix::before {
  top: 36px;
  bottom: 14px;
  left: calc(50% + 14px);
  width: 1px;
}

.follow-segment-matrix::after {
  right: 14px;
  bottom: calc(50% - 11px);
  left: 46px;
  height: 1px;
}

.matrix-axis {
  position: absolute;
  z-index: 2;
  color: rgba(40, 96, 129, 0.72);
  font-size: 12px;
  font-weight: 950;
}

.matrix-axis-top {
  top: 13px;
  left: 50%;
  transform: translateX(-20%);
}

.matrix-axis-side {
  top: 50%;
  left: 15px;
  width: 1em;
  line-height: 1.18;
  text-align: center;
  transform: translateY(-50%);
  transform-origin: center;
}

.follow-segment-matrix article {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 0;
  padding: 12px;
  border-radius: 16px;
  background:
    radial-gradient(circle at 86% 20%, rgba(98, 181, 231, 0.2), transparent 32%),
    rgba(255, 255, 255, 0.82);
  box-shadow: inset 0 0 0 1px rgba(45, 115, 152, 0.16);
}

.follow-segment-matrix .segment-hot {
  background:
    radial-gradient(circle at 86% 20%, rgba(98, 181, 231, 0.2), transparent 32%),
    rgba(255, 255, 255, 0.82);
}

.follow-segment-matrix small {
  color: rgba(186, 111, 52, 0.82);
  font-size: 11px;
  font-weight: 900;
}

.follow-segment-matrix b {
  color: #172631;
  font-size: 20px;
  font-weight: 950;
  line-height: 1.1;
}

.follow-segment-matrix span {
  color: rgba(29, 47, 58, 0.62);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.35;
}

.follow-action-queue {
  position: relative;
  display: grid;
  align-content: center;
  gap: 10px;
  min-height: 0;
  padding: 18px;
  overflow: hidden;
  border-radius: 22px;
  background:
    radial-gradient(circle at 84% 12%, rgba(98, 181, 231, 0.18), transparent 34%),
    rgba(255, 255, 255, 0.7);
}

.follow-action-queue::before {
  position: absolute;
  top: 58px;
  bottom: 48px;
  left: 35px;
  width: 2px;
  background: linear-gradient(180deg, rgba(45, 115, 152, 0.38), rgba(240, 168, 95, 0.32));
  content: "";
}

.follow-action-queue > span {
  color: #286081;
  font-size: 15px;
  font-weight: 950;
}

.follow-action-queue article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr);
  gap: 8px 10px;
  align-items: center;
  min-height: 74px;
  padding: 10px 10px 10px 0;
}

.follow-action-queue b {
  display: grid;
  grid-row: span 2;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 3px solid rgba(255, 255, 255, 0.88);
  border-radius: 50%;
  background: #286081;
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
  box-shadow: 0 10px 20px rgba(45, 115, 152, 0.16);
}

.follow-action-queue strong {
  color: #172631;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.12;
}

.follow-action-queue small {
  color: rgba(29, 47, 58, 0.6);
  font-size: 12px;
  font-weight: 780;
  line-height: 1.3;
}

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

.follow-loop-strip span {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 58px;
  padding: 10px 8px;
  border-radius: 15px;
  color: rgba(23, 38, 49, 0.86);
  font-size: 16px;
  font-weight: 950;
  text-align: center;
}

.follow-loop-strip span:not(:last-child)::after {
  position: absolute;
  top: 50%;
  right: -9px;
  z-index: 2;
  width: 10px;
  height: 2px;
  background: rgba(45, 115, 152, 0.24);
  content: "";
}

.robot-follow-insight {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 16px;
  height: 100%;
  min-height: 0;
  padding: 24px 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 16% 15%, rgba(92, 174, 222, 0.22), transparent 34%),
    radial-gradient(circle at 86% 78%, rgba(240, 168, 95, 0.15), transparent 34%),
    linear-gradient(160deg, #0c171e 0%, #101920 55%, #090d10 100%);
}

.robot-follow-insight::before {
  position: absolute;
  inset: 20px;
  border: 1px solid rgba(150, 190, 215, 0.13);
  border-radius: 22px;
  content: "";
  pointer-events: none;
}

.robot-follow-insight > * {
  position: relative;
  z-index: 1;
}

.follow-insight-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(165, 208, 232, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.07);
  color: rgba(194, 228, 247, 0.86);
  font-size: 12px;
  font-weight: 900;
}

.follow-insight-head h3 {
  max-width: 420px;
  margin: 12px 0 0;
  color: #f8fbfc;
  font-size: clamp(29px, 2.04vw, 34px);
  line-height: 1.28;
}

.follow-insight-head p {
  max-width: 420px;
  margin: 10px 0 0;
  color: rgba(238, 248, 252, 0.7);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.follow-rhythm-system {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 13px;
  min-height: 0;
}

.follow-signal-rail {
  display: grid;
  grid-template-columns: 80px repeat(3, minmax(0, 1fr));
  gap: 7px;
  align-items: center;
  min-height: 74px;
  padding: 11px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 20px;
  background:
    linear-gradient(90deg, rgba(96, 174, 222, 0.12), rgba(255, 255, 255, 0.055)),
    rgba(255, 255, 255, 0.045);
}

.follow-signal-rail span {
  color: rgba(194, 228, 247, 0.62);
  font-size: 13px;
  font-weight: 900;
}

.follow-signal-rail b {
  display: grid;
  place-items: center;
  min-height: 42px;
  padding: 8px 7px;
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(248, 251, 252, 0.94);
  font-size: 14px;
  font-weight: 900;
  line-height: 1.28;
  text-align: center;
}

.follow-priority-dial {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(160, 202, 226, 0.12);
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 48%, rgba(96, 174, 222, 0.16), transparent 42%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.065), rgba(255, 255, 255, 0.035));
}

.priority-orbit {
  position: absolute;
  width: 196px;
  height: 196px;
  border: 1px dashed rgba(160, 202, 226, 0.28);
  border-radius: 50%;
  transform: translateX(-18px);
}

.priority-orbit::before,
.priority-orbit::after {
  position: absolute;
  inset: 24px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 50%;
  content: "";
}

.priority-orbit::after {
  inset: 54px;
  border-color: rgba(240, 168, 95, 0.18);
}

.priority-orbit i {
  position: absolute;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: #62b5e7;
  box-shadow: 0 0 0 7px rgba(98, 181, 231, 0.1);
}

.priority-orbit i:nth-child(1) { top: 16px; left: 50%; }
.priority-orbit i:nth-child(2) { top: 50%; right: 15px; background: #f0a85f; }
.priority-orbit i:nth-child(3) { bottom: 15px; left: 50%; }
.priority-orbit i:nth-child(4) { top: 50%; left: 15px; background: #f0a85f; }

.priority-core {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 122px;
  height: 122px;
  padding: 14px;
  border: 1px solid rgba(98, 181, 231, 0.42);
  border-radius: 50%;
  background: rgba(8, 20, 28, 0.88);
  box-shadow: 0 20px 46px rgba(3, 10, 16, 0.28);
  text-align: center;
  transform: translateX(-18px);
}

.priority-core small {
  color: rgba(194, 228, 247, 0.6);
  font-size: 11px;
  font-weight: 900;
}

.priority-core strong {
  color: #ffffff;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.26;
  white-space: nowrap;
}

.priority-core span {
  color: rgba(238, 248, 252, 0.58);
  font-size: 9px;
  font-weight: 760;
  line-height: 1.28;
}

.priority-card {
  position: absolute;
  z-index: 3;
  display: grid;
  gap: 4px;
  width: 126px;
  padding: 10px 12px;
  border: 1px solid rgba(160, 202, 226, 0.13);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.075);
}

.priority-card small {
  color: rgba(240, 168, 95, 0.82);
  font-size: 10px;
  font-weight: 900;
}

.priority-card b {
  color: rgba(248, 251, 252, 0.94);
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
}

.priority-card.hot {
  top: 18px;
  left: 18px;
}

.priority-card.warm {
  right: 8px;
  top: 82px;
}

.priority-card.adjust {
  bottom: 20px;
  left: 36px;
}

.follow-cadence-lane {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  min-height: 92px;
  padding-top: 8px;
  border-top: 1px solid rgba(160, 202, 226, 0.12);
}

.follow-cadence-lane article {
  position: relative;
  display: grid;
  align-content: center;
  gap: 4px;
  padding: 10px 9px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.075);
}

.follow-cadence-lane article:not(:last-child)::after {
  position: absolute;
  top: 50%;
  right: 3px;
  width: 8px;
  height: 2px;
  background: rgba(240, 168, 95, 0.42);
  content: "";
}

.follow-cadence-lane small {
  color: rgba(240, 168, 95, 0.86);
  font-size: 11px;
  font-weight: 950;
}

.follow-cadence-lane b {
  color: #ffffff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.12;
}

.follow-cadence-lane span {
  color: rgba(238, 248, 252, 0.58);
  font-size: 11px;
  font-weight: 760;
}

.media-robot-proof .case-image-slot.robot-trial-report-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 16px;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.98), transparent 26%),
    radial-gradient(circle at 84% 12%, rgba(120, 178, 216, 0.24), transparent 32%),
    linear-gradient(135deg, #f7fbff 0%, #edf5fb 46%, #fff9ef 100%);
}

.media-robot-proof .robot-trial-report-image::before,
.robot-command-console .robot-trial-report-image::after {
  content: none;
}

.robot-trial-report-image strong,
.robot-trial-report-image span,
.robot-trial-report-image i {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.trial-report-dashboard {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  gap: 10px;
  height: 100%;
  min-height: 0;
  padding: 4px;
  overflow: hidden;
  border-radius: 20px;
}

.trial-report-head {
  display: grid;
  gap: 7px;
}

.trial-report-head strong {
  color: #172631;
  font-family: var(--display);
  font-size: clamp(29px, 2.1vw, 34px);
  font-weight: 900;
  line-height: 1.06;
}

.trial-report-head p {
  max-width: 620px;
  margin: 0;
  color: rgba(29, 47, 58, 0.62);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.42;
}

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

.trial-report-summary article,
.trial-map-card,
.trial-alert-card,
.trial-conversion-card,
.trial-report-flow span {
  border: 1px solid rgba(66, 126, 165, 0.12);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(30, 62, 80, 0.07);
}

.trial-report-summary article {
  display: grid;
  gap: 4px;
  min-height: 70px;
  padding: 10px;
  border-radius: 16px;
}

.trial-report-summary b {
  color: #172631;
  font-size: 22px;
  font-weight: 950;
  line-height: 1;
}

.trial-report-summary span {
  color: rgba(29, 47, 58, 0.6);
  font-size: 11px;
  font-weight: 820;
  line-height: 1.25;
}

.trial-report-main {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-height: 0;
}

.trial-map-card,
.trial-alert-card,
.trial-conversion-flow article {
  border: 1px solid rgba(66, 126, 165, 0.12);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(30, 62, 80, 0.07);
}

.trial-map-card,
.trial-alert-card {
  min-height: 0;
  padding: 14px;
  border-radius: 20px;
}

.trial-map-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 9px;
}

.trial-alert-card {
  display: grid;
  align-content: center;
  gap: 8px;
  padding-right: 24px;
}

.trial-analysis-stack {
  display: grid;
  grid-template-rows: 0.8fr 1.2fr;
  gap: 9px;
  min-height: 0;
}

.trial-alert-card h4,
.trial-map-card h4,
.trial-radar-card h4 {
  margin: 0;
  color: #172631;
  font-size: 15px;
  font-weight: 950;
}

.trial-route-map {
  position: relative;
  min-height: 214px;
  overflow: hidden;
  border-radius: 16px;
  background:
    linear-gradient(135deg, transparent 0 16%, rgba(45, 115, 152, 0.08) 16% 17%, transparent 17% 42%, rgba(45, 115, 152, 0.06) 42% 43%, transparent 43%),
    linear-gradient(45deg, transparent 0 31%, rgba(45, 115, 152, 0.06) 31% 32%, transparent 32% 68%, rgba(45, 115, 152, 0.06) 68% 69%, transparent 69%),
    linear-gradient(90deg, rgba(39, 97, 127, 0.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(39, 97, 127, 0.08) 1px, transparent 1px),
    radial-gradient(circle at 78% 22%, rgba(98, 181, 231, 0.18), transparent 26%),
    rgba(239, 247, 252, 0.78);
  background-size: 42px 42px, 42px 42px, auto, auto;
}

.trial-route-map::before {
  position: absolute;
  top: 38px;
  left: 34px;
  width: 72%;
  height: 122px;
  border: 3px solid rgba(45, 115, 152, 0.36);
  border-left-style: dashed;
  border-bottom-style: dashed;
  border-radius: 46px 28px 52px 34px;
  transform: rotate(-6deg);
  content: "";
}

.trial-route-map::after {
  position: absolute;
  right: 42px;
  bottom: 35px;
  width: 36%;
  height: 52px;
  border: 3px dashed rgba(239, 154, 58, 0.5);
  border-top: 0;
  border-radius: 0 0 48px 48px;
  content: "";
}

.trial-route-map em {
  position: absolute;
  display: block;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.58);
  box-shadow: inset 0 0 0 1px rgba(66, 126, 165, 0.08);
}

.trial-route-map em:nth-of-type(1) { left: 18px; top: 18px; width: 84px; height: 42px; }
.trial-route-map em:nth-of-type(2) { left: 124px; top: 22px; width: 76px; height: 64px; }
.trial-route-map em:nth-of-type(3) { right: 22px; top: 28px; width: 92px; height: 54px; }
.trial-route-map em:nth-of-type(4) { left: 28px; bottom: 28px; width: 108px; height: 62px; }
.trial-route-map em:nth-of-type(5) { left: 46%; bottom: 24px; width: 74px; height: 74px; }
.trial-route-map em:nth-of-type(6) { right: 30px; bottom: 22px; width: 98px; height: 64px; }

.trial-route-map i {
  position: absolute;
  display: grid;
  place-items: center;
  width: 17px;
  height: 17px;
  border: 3px solid rgba(255, 255, 255, 0.88);
  border-radius: 50%;
  background: #2d7398;
  box-shadow: 0 8px 20px rgba(45, 115, 152, 0.22);
}

.trial-route-map i:nth-of-type(1) { left: 34px; top: 70px; }
.trial-route-map i:nth-of-type(2) { left: 35%; top: 46px; }
.trial-route-map i:nth-of-type(3) { right: 42px; top: 76px; }
.trial-route-map i:nth-of-type(4) { right: 30%; bottom: 52px; background: #ef9a3a; }
.trial-route-map i:nth-of-type(5) { left: 25%; bottom: 42px; background: #62b5e7; }

.trial-route-map span {
  position: absolute;
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: rgba(29, 47, 58, 0.72);
  font-size: 11px;
  font-weight: 820;
}

.trial-route-map span:nth-of-type(1) { left: 18px; top: 94px; }
.trial-route-map span:nth-of-type(2) { left: 29%; top: 70px; }
.trial-route-map span:nth-of-type(3) { right: 22px; top: 100px; }
.trial-route-map span:nth-of-type(4) { right: 17%; bottom: 76px; }
.trial-route-map span:nth-of-type(5) { right: 34%; bottom: 24px; }

.trial-route-metrics {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto minmax(0, 1fr);
  align-items: baseline;
  gap: 5px 7px;
  min-height: 34px;
  padding: 7px 9px;
  border-radius: 13px;
  background: rgba(243, 248, 251, 0.82);
}

.trial-route-metrics b {
  color: #172631;
  font-size: 18px;
  font-weight: 950;
}

.trial-route-metrics span {
  color: rgba(29, 47, 58, 0.58);
  font-size: 11px;
  font-weight: 820;
}

.trial-alert-card div {
  display: grid;
  grid-template-columns: 60px minmax(138px, 1fr) 40px;
  align-items: center;
  gap: 9px;
}

.trial-radar-card {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 4px;
  min-height: 0;
  padding: 11px 10px 9px;
  border: 1px solid rgba(66, 126, 165, 0.12);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 12px 28px rgba(30, 62, 80, 0.07);
}

.trial-radar {
  position: relative;
  display: grid;
  min-height: 140px;
}

.trial-radar svg {
  width: 100%;
  height: 100%;
  min-height: 140px;
  overflow: visible;
}

.trial-radar-grid polygon,
.trial-radar-grid line {
  fill: none;
  stroke: rgba(29, 47, 58, 0.14);
  stroke-width: 1.2;
}

.trial-radar svg text {
  fill: rgba(29, 47, 58, 0.66);
  font-size: 13px;
  font-weight: 860;
}

.trial-radar .trial-radar-tick {
  fill: rgba(29, 47, 58, 0.38);
  font-size: 10px;
  font-weight: 760;
}

.trial-radar .radar-base,
.trial-radar .radar-trial {
  fill: none;
  stroke-linecap: round;
  stroke-linejoin: round;
  stroke-width: 4;
}

.trial-radar .radar-base {
  stroke: rgba(45, 115, 152, 0.88);
}

.trial-radar .radar-trial {
  stroke: rgba(239, 154, 58, 0.82);
}

.trial-alert-card b {
  color: rgba(29, 47, 58, 0.72);
  font-size: 12px;
  font-weight: 860;
}

.trial-alert-card i {
  display: block;
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(85, 135, 166, 0.12);
}

.trial-alert-card i::before {
  display: block;
  width: var(--w);
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #62b5e7, #2d7398);
  content: "";
}

.trial-alert-card span {
  color: #27617f;
  font-size: 12px;
  font-weight: 920;
  text-align: right;
  padding-right: 8px;
}

.trial-conversion-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.trial-conversion-flow article {
  position: relative;
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 2px 8px;
  align-items: center;
  min-height: 58px;
  padding: 9px 10px;
  border-radius: 16px;
}

.trial-conversion-flow b {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(98, 181, 231, 0.14);
  color: #27617f;
  font-size: 11px;
  font-weight: 950;
}

.trial-conversion-flow strong {
  color: #172631;
  font-size: 13px;
  font-weight: 940;
  line-height: 1.12;
}

.trial-conversion-flow span {
  color: rgba(29, 47, 58, 0.58);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
}

.beauty-agent-room .case-tab-stage,
.beauty-agent-room .case-tab-stage.reverse,
.edu-skill-console .case-tab-stage,
.edu-skill-console .case-tab-stage.reverse {
  grid-template-columns: minmax(300px, 0.72fr) minmax(0, 1.28fr);
  gap: 28px;
  height: 690px;
  min-height: 690px;
  max-height: 690px;
  align-items: stretch;
}

.beauty-agent-room .case-tab-stage.reverse,
.edu-skill-console .case-tab-stage.reverse {
  grid-template-columns: minmax(0, 1.28fr) minmax(300px, 0.72fr);
}

.beauty-agent-room .case-tab-copy {
  background: rgba(255, 255, 255, 0.74);
}

.beauty-agent-room .case-tab-copy.dark {
  background: #101010;
}

.beauty-agent-room .case-media-panel {
  background: rgba(255, 255, 255, 0.72);
}

.beauty-agent-room .case-tab-copy,
.beauty-agent-room .case-media-panel {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.beauty-agent-room .case-image-slot {
  min-height: 570px;
  align-content: start;
  background:
    linear-gradient(135deg, rgba(232, 247, 232, 0.92), rgba(255, 240, 246, 0.96)),
    #ffffff;
}

.beauty-agent-room .case-image-slot::after {
  position: absolute;
  right: 34px;
  bottom: 34px;
  left: 34px;
  height: 248px;
  border-radius: 16px;
  background:
    linear-gradient(#111111, #111111) 0 0 / 100% 48px no-repeat,
    linear-gradient(#111111, #111111) 0 66px / 100% 48px no-repeat,
    linear-gradient(#111111, #111111) 0 132px / 100% 48px no-repeat,
    linear-gradient(#111111, #111111) 0 198px / 100% 48px no-repeat;
  opacity: 0.94;
  content: "";
}

.beauty-agent-room .case-tab-copy.beauty-local-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  align-content: center;
  gap: 18px;
  padding: 26px;
  background:
    radial-gradient(circle at 20% 18%, rgba(255, 255, 255, 0.92), transparent 34%),
    radial-gradient(circle at 84% 86%, rgba(121, 177, 139, 0.14), transparent 36%),
    linear-gradient(145deg, rgba(250, 255, 249, 0.94), rgba(238, 248, 240, 0.84));
  color: #261f1d;
}

.beauty-local-insight-head {
  display: grid;
  gap: 10px;
}

.beauty-local-insight-head > span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(121, 177, 139, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.68);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 900;
}

.beauty-local-insight-head h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(32px, 2.5vw, 38px);
  font-weight: 900;
  line-height: 1.34;
}

.beauty-local-insight-head p {
  max-width: 390px;
  margin: 0;
  color: rgba(38, 31, 29, 0.64);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.5;
}

.beauty-local-prescription {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 0;
}

.local-growth-formula,
.local-action-script,
.local-action-results article {
  border: 1px solid rgba(121, 177, 139, 0.16);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.local-growth-formula {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px 6px;
  align-items: center;
  min-height: 104px;
  padding: 14px;
  border-radius: 22px;
}

.local-growth-formula span {
  display: grid;
  place-items: center;
  min-height: 38px;
  padding: 8px 6px;
  border-radius: 13px;
  background: rgba(239, 249, 241, 0.86);
  color: rgba(38, 31, 29, 0.78);
  font-size: 13px;
  font-weight: 900;
}

.local-growth-formula b {
  display: none;
}

.local-growth-formula strong {
  grid-column: 1 / -1;
  display: grid;
  place-items: center;
  min-height: 34px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(121, 177, 139, 0.2), rgba(217, 163, 106, 0.13));
  color: #4f7f5e;
  font-size: 16px;
  font-weight: 950;
}

.local-action-script {
  position: relative;
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 0;
  padding: 10px 14px;
  overflow: hidden;
  border-radius: 24px;
}

.local-action-script::before {
  position: absolute;
  top: 48px;
  bottom: 36px;
  left: 31px;
  width: 2px;
  background: linear-gradient(180deg, rgba(121, 177, 139, 0.34), rgba(217, 163, 106, 0.2));
  content: "";
}

.local-action-script > span {
  color: #5f8f6a;
  font-size: 15px;
  font-weight: 950;
}

.local-action-script article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 3px 10px;
  align-items: center;
  min-height: 54px;
  padding: 4px 8px 4px 0;
}

.local-action-script small {
  display: grid;
  grid-row: span 2;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #79b18b;
  color: #ffffff;
  font-size: 11px;
  font-weight: 950;
  box-shadow: 0 0 0 7px rgba(121, 177, 139, 0.12);
}

.local-action-script strong {
  color: #261f1d;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.16;
}

.local-action-script p {
  margin: 0;
  color: rgba(38, 31, 29, 0.58);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.3;
}

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

.local-action-results article {
  display: grid;
  gap: 4px;
  align-content: center;
  min-height: 72px;
  padding: 12px;
  border-radius: 16px;
}

.local-action-results small {
  color: rgba(95, 143, 106, 0.82);
  font-size: 11px;
  font-weight: 950;
}

.local-action-results strong {
  color: #261f1d;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.1;
}

.beauty-agent-room .case-tab-copy.beauty-consult-insight {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr) auto;
  align-content: center;
  gap: 12px;
  padding: 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 82% 12%, rgba(121, 177, 139, 0.18), transparent 34%),
    radial-gradient(circle at 18% 88%, rgba(211, 157, 91, 0.16), transparent 34%),
    linear-gradient(145deg, #0c1511 0%, #101010 58%, #132018 100%);
}

.beauty-consult-insight-head {
  display: grid;
  gap: 9px;
}

.beauty-consult-insight-head > span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(121, 177, 139, 0.28);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.06);
  color: #a8d4b2;
  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.02em;
}

.beauty-consult-insight-head h3 {
  margin: 0;
  color: #f8f6f0;
  font-family: var(--display);
  font-size: clamp(29px, 2.25vw, 34px);
  font-weight: 900;
  line-height: 1.22;
}

.beauty-consult-insight-head p {
  margin: 0;
  color: rgba(229, 241, 231, 0.7);
  font-size: 14px;
  font-weight: 780;
  line-height: 1.46;
}

.consult-measure-board {
  display: grid;
  gap: 8px;
  min-height: 0;
  padding: 12px;
  border: 1px solid rgba(121, 177, 139, 0.16);
  border-radius: 22px;
  background:
    radial-gradient(circle at 86% 18%, rgba(121, 177, 139, 0.18), transparent 36%),
    rgba(255, 255, 255, 0.055);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.035);
}

.consult-measure-title {
  display: grid;
  gap: 3px;
}

.consult-measure-title small {
  color: rgba(168, 212, 178, 0.84);
  font-size: 12px;
  font-weight: 950;
}

.consult-measure-title strong {
  color: #f8f6f0;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.18;
}

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

.consult-measure-grid article {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 3px 8px;
  align-items: center;
  min-height: 58px;
  padding: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.07);
}

.consult-measure-grid span {
  display: grid;
  grid-row: span 2;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: 11px;
  background: #21382a;
  color: #a8d4b2;
  font-size: 10px;
  font-weight: 950;
}

.consult-measure-grid b {
  color: #ffffff;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.consult-measure-grid small {
  color: rgba(229, 241, 231, 0.62);
  font-size: 10.5px;
  font-weight: 760;
  line-height: 1.25;
}

.consult-measure-layers {
  display: grid;
  align-content: center;
  gap: 6px;
  min-height: 0;
}

.consult-measure-layers article {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  gap: 3px 10px;
  align-items: center;
  min-height: 52px;
  padding: 7px 12px;
  border: 1px solid rgba(121, 177, 139, 0.14);
  border-radius: 17px;
  background:
    linear-gradient(90deg, rgba(121, 177, 139, 0.13), rgba(255, 255, 255, 0.07));
}

.consult-measure-layers span {
  display: grid;
  grid-row: span 2;
  place-items: center;
  min-height: 36px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: #a8d4b2;
  font-size: 12px;
  font-weight: 950;
}

.consult-measure-layers strong {
  color: #f8f6f0;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.14;
}

.consult-measure-layers small {
  color: rgba(229, 241, 231, 0.64);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.28;
}

.consult-dialogue-map {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 46px minmax(0, 1fr);
  grid-template-rows: auto repeat(3, minmax(0, 1fr));
  gap: 8px 9px;
  min-height: 0;
  padding: 14px;
  border: 1px solid rgba(121, 177, 139, 0.16);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.055);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.035);
}

.consult-dialogue-map::before {
  position: absolute;
  top: 48px;
  bottom: 18px;
  left: 50%;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(121, 177, 139, 0.34), transparent);
  content: "";
  transform: translateX(-50%);
}

.dialogue-axis-label {
  color: rgba(168, 212, 178, 0.8);
  font-size: 12px;
  font-weight: 950;
}

.dialogue-axis-label.ai {
  text-align: center;
}

.dialogue-axis-label.action {
  text-align: right;
}

.dialogue-card {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 82px;
  padding: 12px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 17px;
  background: rgba(255, 255, 255, 0.075);
}

.dialogue-card.customer {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.09), rgba(121, 177, 139, 0.08));
}

.dialogue-card.advisor {
  background:
    linear-gradient(135deg, rgba(121, 177, 139, 0.16), rgba(255, 255, 255, 0.075));
}

.dialogue-card strong {
  color: #ffffff;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.12;
}

.dialogue-card small {
  color: rgba(229, 241, 231, 0.66);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.28;
}

.dialogue-rule {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
}

.dialogue-rule span {
  display: grid;
  place-items: center;
  width: 42px;
  height: 42px;
  border: 1px solid rgba(121, 177, 139, 0.3);
  border-radius: 50%;
  background: #21382a;
  color: #d9eede;
  font-size: 12px;
  font-weight: 950;
  box-shadow: 0 0 0 8px rgba(121, 177, 139, 0.08);
}

.consult-conversion-results {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.consult-conversion-results span {
  display: grid;
  place-items: center;
  min-height: 54px;
  padding: 8px 6px;
  border: 1px solid rgba(121, 177, 139, 0.14);
  border-radius: 15px;
  background: rgba(255, 255, 255, 0.08);
  color: #f8f6f0;
  font-size: 13px;
  font-weight: 950;
  text-align: center;
}

.media-beauty-revisit .case-image-slot.beauty-revisit-retention-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.98), transparent 26%),
    radial-gradient(circle at 88% 18%, rgba(121, 177, 139, 0.18), transparent 32%),
    linear-gradient(135deg, #f4fbf6 0%, #f9fcf4 54%, #fff8ed 100%);
}

.media-beauty-revisit .beauty-revisit-retention-image::before,
.media-beauty-revisit .beauty-revisit-retention-image::after {
  content: none;
}

.beauty-revisit-retention-image strong,
.beauty-revisit-retention-image span,
.beauty-revisit-retention-image small,
.beauty-revisit-retention-image b,
.beauty-revisit-retention-image p {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.beauty-revisit-dashboard {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  color: #261f1d;
}

.beauty-revisit-head {
  display: grid;
  gap: 7px;
}

.beauty-revisit-head > span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(121, 177, 139, 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.beauty-revisit-head strong {
  display: block;
  min-height: 42px;
  font-family: var(--display);
  font-size: clamp(30px, 2.2vw, 36px);
  font-weight: 900;
  line-height: 1.2;
}

.beauty-revisit-head p {
  max-width: 640px;
  color: rgba(38, 31, 29, 0.62);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.revisit-asset-command {
  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(0, 0.92fr);
  gap: 12px;
  min-height: 0;
}

.revisit-asset-pool,
.revisit-task-tower,
.revisit-command-strip article {
  border: 1px solid rgba(121, 177, 139, 0.15);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.revisit-asset-pool {
  display: grid;
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 0;
  padding: 16px;
  overflow: hidden;
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 42%, rgba(121, 177, 139, 0.16), transparent 42%),
    rgba(255, 255, 255, 0.72);
}

.asset-pool-ring {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
}

.asset-pool-ring::before,
.asset-pool-ring::after {
  position: absolute;
  border-radius: 50%;
  content: "";
}

.asset-pool-ring::before {
  width: 226px;
  height: 226px;
  border: 16px solid rgba(121, 177, 139, 0.12);
}

.asset-pool-ring::after {
  width: 276px;
  height: 276px;
  border: 1px dashed rgba(121, 177, 139, 0.26);
}

.asset-pool-ring i {
  position: absolute;
  z-index: 2;
  display: block;
  width: 74px;
  min-height: 34px;
  border-radius: 999px;
  background: #ffffff;
  box-shadow: 0 12px 28px rgba(76, 116, 83, 0.09);
}

.asset-pool-ring i:nth-child(1) { top: 34px; left: 28px; }
.asset-pool-ring i:nth-child(2) { top: 38px; right: 34px; background: #f8fbf6; }
.asset-pool-ring i:nth-child(3) { bottom: 42px; left: 46px; background: #fff8ed; }
.asset-pool-ring i:nth-child(4) { right: 32px; bottom: 38px; background: #f3faf2; }

.asset-pool-core {
  position: relative;
  z-index: 3;
  display: grid;
  place-items: center;
  width: 154px;
  height: 154px;
  border: 1px solid rgba(121, 177, 139, 0.22);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.88);
  box-shadow: 0 26px 56px rgba(76, 116, 83, 0.12);
  text-align: center;
}

.asset-pool-core small {
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 950;
}

.asset-pool-core strong {
  display: block;
  min-height: 58px;
  color: #261f1d;
  font-size: 48px;
  font-weight: 950;
  line-height: 1.05;
}

.asset-pool-core span {
  color: rgba(38, 31, 29, 0.58);
  font-size: 12px;
  font-weight: 780;
}

.asset-pool-tags {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.asset-pool-tags span {
  display: grid;
  place-items: center;
  min-height: 40px;
  border-radius: 14px;
  background: rgba(247, 252, 245, 0.88);
  color: rgba(38, 31, 29, 0.72);
  font-size: 12px;
  font-weight: 850;
  text-align: center;
}

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

.revisit-card-head span {
  color: #5f8f6a;
  font-size: 15px;
  font-weight: 950;
}

.revisit-card-head small {
  color: rgba(38, 31, 29, 0.52);
  font-size: 10.5px;
  font-weight: 780;
  line-height: 1.2;
  text-align: right;
}

.revisit-task-tower {
  display: grid;
  grid-template-rows: auto repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-content: center;
  min-height: 0;
  padding: 16px;
  border-radius: 24px;
}

.revisit-task-tower article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 48px;
  gap: 4px 10px;
  align-items: center;
  min-height: 78px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(247, 252, 245, 0.86);
  box-shadow: inset 0 0 0 1px rgba(121, 177, 139, 0.12);
}

.revisit-task-tower b {
  color: #261f1d;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.revisit-task-tower em {
  color: rgba(38, 31, 29, 0.58);
  font-size: 11px;
  font-style: normal;
  font-weight: 780;
  line-height: 1.25;
}

.revisit-task-tower strong {
  grid-row: span 2;
  display: grid;
  place-items: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(121, 177, 139, 0.14);
  color: #261f1d;
  font-size: 19px;
  font-weight: 950;
}

.revisit-command-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.revisit-command-strip article {
  display: grid;
  gap: 4px;
  place-items: center;
  min-height: 60px;
  padding: 9px 8px;
  border-radius: 15px;
  text-align: center;
}

.revisit-command-strip small {
  color: rgba(95, 143, 106, 0.82);
  font-size: 10px;
  font-weight: 950;
}

.revisit-command-strip strong {
  color: rgba(38, 31, 29, 0.88);
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.beauty-agent-room .case-tab-copy.beauty-revisit-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  align-content: center;
  gap: 16px;
  padding: 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 20% 14%, rgba(255, 255, 255, 0.96), transparent 34%),
    radial-gradient(circle at 84% 88%, rgba(121, 177, 139, 0.16), transparent 34%),
    linear-gradient(145deg, rgba(250, 255, 249, 0.95), rgba(238, 248, 240, 0.86));
  color: #261f1d;
}

.beauty-revisit-insight-head {
  display: grid;
  gap: 10px;
}

.beauty-revisit-insight-head > span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(121, 177, 139, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 950;
}

.beauty-revisit-insight-head h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(30px, 2.35vw, 36px);
  font-weight: 900;
  line-height: 1.26;
}

.beauty-revisit-insight-head p {
  margin: 0;
  color: rgba(38, 31, 29, 0.64);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.46;
}

.retention-ledger-board {
  display: grid;
  grid-template-columns: 48px minmax(0, 1fr);
  gap: 10px;
  min-height: 0;
  padding: 12px;
  border: 1px solid rgba(121, 177, 139, 0.16);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.ledger-spine {
  display: grid;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.ledger-spine span {
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: #5f8f6a;
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
  writing-mode: vertical-rl;
  letter-spacing: 0.08em;
}

.ledger-pages {
  display: grid;
  gap: 9px;
  min-height: 0;
}

.ledger-pages article {
  position: relative;
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 92px;
  padding: 12px 14px 12px 18px;
  overflow: hidden;
  border: 1px solid rgba(121, 177, 139, 0.14);
  border-radius: 18px;
  background:
    linear-gradient(90deg, rgba(121, 177, 139, 0.16), transparent 5px),
    rgba(247, 252, 245, 0.88);
}

.ledger-pages article::after {
  position: absolute;
  top: 10px;
  right: 12px;
  width: 32px;
  height: 6px;
  border-radius: 999px;
  background: rgba(121, 177, 139, 0.2);
  content: "";
}

.ledger-pages small {
  color: #5f8f6a;
  font-size: 11px;
  font-weight: 950;
}

.ledger-pages strong {
  color: #261f1d;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.14;
}

.ledger-pages p {
  max-width: 260px;
  margin: 0;
  color: rgba(38, 31, 29, 0.58);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.34;
}

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

.retention-rule-grid article {
  display: grid;
  gap: 4px;
  align-content: center;
  min-height: 68px;
  padding: 11px;
  border: 1px solid rgba(121, 177, 139, 0.15);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.retention-rule-grid small {
  color: rgba(95, 143, 106, 0.84);
  font-size: 11px;
  font-weight: 950;
}

.retention-rule-grid strong {
  color: #261f1d;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.1;
}

.beauty-agent-room .case-tab-copy.beauty-training-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  align-content: center;
  gap: 16px;
  padding: 26px;
  overflow: hidden;
  background:
    radial-gradient(circle at 18% 14%, rgba(255, 255, 255, 0.96), transparent 34%),
    radial-gradient(circle at 84% 86%, rgba(121, 177, 139, 0.16), transparent 34%),
    linear-gradient(145deg, rgba(250, 255, 249, 0.95), rgba(238, 248, 240, 0.86));
  color: #261f1d;
}

.beauty-training-insight-head {
  display: grid;
  gap: 10px;
}

.beauty-training-insight-head > span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(121, 177, 139, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 950;
}

.beauty-training-insight-head h3 {
  margin: 0;
  min-height: 86px;
  font-family: var(--display);
  font-size: clamp(29px, 2.3vw, 35px);
  font-weight: 900;
  line-height: 1.34;
}

.beauty-training-insight-head p {
  margin: 0;
  color: rgba(38, 31, 29, 0.64);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.46;
}

.training-method-library {
  display: grid;
  grid-template-rows: auto auto minmax(0, 1fr);
  gap: 10px;
  min-height: 0;
  padding: 12px;
  border: 1px solid rgba(121, 177, 139, 0.16);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.method-bookshelf {
  display: grid;
  gap: 10px;
}

.method-shelf-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}

.method-shelf-head span {
  color: #5f8f6a;
  font-size: 15px;
  font-weight: 950;
}

.method-shelf-head small {
  color: rgba(38, 31, 29, 0.52);
  font-size: 10.5px;
  font-weight: 780;
  text-align: right;
}

.method-book-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
  align-items: end;
  min-height: 104px;
  padding: 8px 8px 0;
  border-bottom: 8px solid rgba(121, 177, 139, 0.18);
}

.method-book-grid article {
  display: grid;
  align-content: end;
  gap: 8px;
  min-height: 82px;
  padding: 10px 7px;
  border-radius: 14px 14px 6px 6px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(239, 249, 241, 0.86));
  box-shadow: inset 0 0 0 1px rgba(121, 177, 139, 0.14);
  text-align: center;
}

.method-book-grid article:nth-child(2) {
  min-height: 94px;
}

.method-book-grid article:nth-child(3) {
  min-height: 88px;
  background:
    linear-gradient(180deg, rgba(255, 248, 237, 0.86), rgba(239, 249, 241, 0.86));
}

.method-book-grid small {
  color: rgba(95, 143, 106, 0.84);
  font-size: 10px;
  font-weight: 950;
}

.method-book-grid strong {
  color: #261f1d;
  font-size: 13px;
  font-weight: 950;
  line-height: 1.12;
}

.method-skill-converter {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  min-height: 58px;
  padding: 10px;
  border-radius: 17px;
  background:
    linear-gradient(90deg, rgba(121, 177, 139, 0.18), rgba(255, 255, 255, 0.82));
}

.method-skill-converter span {
  display: grid;
  place-items: center;
  min-height: 36px;
  border-radius: 999px;
  background: #5f8f6a;
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.method-skill-converter strong {
  color: #261f1d;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.18;
}

.method-readiness {
  display: grid;
  align-content: center;
  gap: 8px;
  min-height: 0;
}

.method-readiness div {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.method-readiness span {
  color: rgba(38, 31, 29, 0.64);
  font-size: 12px;
  font-weight: 900;
}

.method-readiness i {
  position: relative;
  display: block;
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(121, 177, 139, 0.12);
}

.method-readiness i::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w);
  border-radius: inherit;
  background: linear-gradient(90deg, #79b18b, rgba(217, 163, 106, 0.82));
  content: "";
}

.training-method-results {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.training-method-results article {
  display: grid;
  gap: 4px;
  align-content: center;
  min-height: 68px;
  padding: 11px;
  border: 1px solid rgba(121, 177, 139, 0.15);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.training-method-results small {
  color: rgba(95, 143, 106, 0.84);
  font-size: 11px;
  font-weight: 950;
}

.training-method-results strong {
  color: #261f1d;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.media-beauty-training .case-image-slot.beauty-training-coach-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 16% 16%, rgba(255, 255, 255, 0.98), transparent 26%),
    radial-gradient(circle at 84% 84%, rgba(121, 177, 139, 0.18), transparent 34%),
    linear-gradient(135deg, #f4fbf6 0%, #f8fcf4 52%, #fff8ed 100%);
}

.media-beauty-training .beauty-training-coach-image::before,
.media-beauty-training .beauty-training-coach-image::after {
  content: none;
}

.beauty-training-coach-image strong,
.beauty-training-coach-image span,
.beauty-training-coach-image small,
.beauty-training-coach-image b,
.beauty-training-coach-image em,
.beauty-training-coach-image p {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.beauty-training-cockpit {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  color: #261f1d;
}

.beauty-training-head {
  display: grid;
  gap: 7px;
}

.beauty-training-head > span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(121, 177, 139, 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.beauty-training-head strong {
  display: block;
  min-height: 42px;
  font-family: var(--display);
  font-size: clamp(30px, 2.2vw, 36px);
  font-weight: 900;
  line-height: 1.2;
}

.beauty-training-head p {
  max-width: 650px;
  color: rgba(38, 31, 29, 0.62);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.training-cockpit-body {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr);
  gap: 12px;
  min-height: 0;
}

.training-radar-card,
.training-drill-stack,
.training-loop-strip article {
  border: 1px solid rgba(121, 177, 139, 0.15);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.training-radar-card,
.training-drill-stack {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 8px;
  min-height: 0;
  padding: 14px;
  border-radius: 24px;
}

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

.training-card-head span {
  color: #5f8f6a;
  font-size: 15px;
  font-weight: 950;
}

.training-card-head small {
  color: rgba(38, 31, 29, 0.52);
  font-size: 10.5px;
  font-weight: 780;
  line-height: 1.2;
  text-align: right;
}

.training-radar-wrap {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  border-radius: 18px;
  background:
    radial-gradient(circle at 50% 50%, rgba(121, 177, 139, 0.12), transparent 52%),
    rgba(247, 252, 245, 0.76);
}

.training-radar {
  width: min(260px, 88%);
  height: 210px;
}

.training-radar line,
.training-radar .radar-grid {
  fill: none;
  stroke: rgba(121, 177, 139, 0.24);
  stroke-width: 1.5;
}

.training-radar .radar-score {
  fill: rgba(121, 177, 139, 0.24);
  stroke: #79b18b;
  stroke-width: 5;
  stroke-linejoin: round;
}

.training-radar-wrap .axis {
  position: absolute;
  color: rgba(38, 31, 29, 0.62);
  font-size: 13px;
  font-weight: 850;
}

.training-radar-wrap .axis-1 { top: 10px; left: 50%; transform: translateX(-50%); }
.training-radar-wrap .axis-2 { top: 76px; right: 8px; }
.training-radar-wrap .axis-3 { right: 28px; bottom: 14px; }
.training-radar-wrap .axis-4 { bottom: 14px; left: 24px; }
.training-radar-wrap .axis-5 { top: 76px; left: 10px; }

.training-drill-stack {
  grid-template-rows: auto repeat(3, minmax(0, 1fr));
  gap: 7px;
  background:
    radial-gradient(circle at 90% 20%, rgba(217, 163, 106, 0.14), transparent 34%),
    rgba(255, 255, 255, 0.72);
}

.training-drill-stack article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 74px;
  grid-template-rows: auto auto;
  gap: 4px 10px;
  align-items: center;
  min-height: 0;
  padding: 9px 12px;
  border-radius: 16px;
  background: rgba(247, 252, 245, 0.86);
  box-shadow: inset 0 0 0 1px rgba(121, 177, 139, 0.12);
}

.training-drill-stack b {
  color: #261f1d;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.training-drill-stack em {
  color: rgba(38, 31, 29, 0.58);
  font-size: 11px;
  font-style: normal;
  font-weight: 780;
  line-height: 1.25;
}

.training-drill-stack strong {
  grid-column: 2;
  grid-row: 1 / 3;
  align-self: center;
  display: grid;
  place-items: center;
  min-height: 48px;
  border-radius: 14px;
  background: rgba(121, 177, 139, 0.14);
  color: #261f1d;
  font-size: 16px;
  font-weight: 950;
  text-align: center;
}

.training-loop-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.training-loop-strip article {
  display: grid;
  gap: 4px;
  place-items: center;
  min-height: 60px;
  padding: 9px 8px;
  border-radius: 15px;
  text-align: center;
}

.training-loop-strip small {
  color: rgba(95, 143, 106, 0.82);
  font-size: 10px;
  font-weight: 950;
}

.training-loop-strip strong {
  color: rgba(38, 31, 29, 0.88);
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.media-beauty-local .case-image-slot.beauty-local-acquisition-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 18% 16%, rgba(255, 255, 255, 0.98), transparent 28%),
    radial-gradient(circle at 88% 82%, rgba(121, 177, 139, 0.16), transparent 34%),
    linear-gradient(135deg, #f4fbf6 0%, #f7fcf5 52%, #fff9ef 100%);
}

.media-beauty-local .beauty-local-acquisition-image::before,
.media-beauty-local .beauty-local-acquisition-image::after {
  content: none;
}

.beauty-local-acquisition-image strong,
.beauty-local-acquisition-image span,
.beauty-local-acquisition-image i {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.beauty-local-growth-map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  color: #261f1d;
}

.beauty-local-head {
  display: grid;
  gap: 7px;
  max-width: 690px;
}

.beauty-local-head span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(121, 177, 139, 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.beauty-local-head strong {
  font-family: var(--display);
  font-size: clamp(30px, 2.2vw, 36px);
  font-weight: 900;
  line-height: 1.04;
}

.beauty-local-head p {
  max-width: 650px;
  margin: 0;
  color: rgba(38, 31, 29, 0.62);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.beauty-local-body {
  display: grid;
  grid-template-columns: minmax(190px, 0.8fr) minmax(210px, 0.85fr) minmax(210px, 0.9fr);
  gap: 12px;
  min-height: 0;
}

.beauty-channel-signals,
.beauty-ai-local-core,
.beauty-lead-queue,
.beauty-local-result-row span {
  border: 1px solid rgba(121, 177, 139, 0.15);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.beauty-channel-signals,
.beauty-lead-queue {
  display: grid;
  align-content: center;
  gap: 10px;
  min-height: 0;
  padding: 16px;
  border-radius: 22px;
}

.beauty-channel-signals > span,
.beauty-lead-queue > span {
  color: #5f8f6a;
  font-size: 16px;
  font-weight: 950;
}

.beauty-channel-signals article,
.beauty-lead-queue article {
  display: grid;
  gap: 4px;
  min-height: 74px;
  padding: 13px 14px;
  border-radius: 16px;
  background:
    linear-gradient(90deg, rgba(239, 249, 241, 0.9), rgba(255, 255, 255, 0.72));
}

.beauty-channel-signals b,
.beauty-lead-queue b {
  color: #261f1d;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.12;
}

.beauty-channel-signals small,
.beauty-lead-queue small {
  color: rgba(38, 31, 29, 0.58);
  font-size: 12px;
  font-weight: 780;
  line-height: 1.3;
}

.beauty-ai-local-core {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 0;
  overflow: hidden;
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 46%, rgba(121, 177, 139, 0.16), transparent 38%),
    rgba(255, 255, 255, 0.68);
}

.beauty-ai-local-core::before,
.beauty-ai-local-core::after {
  position: absolute;
  width: 1px;
  height: 74%;
  background: linear-gradient(180deg, transparent, rgba(121, 177, 139, 0.2), transparent);
  content: "";
}

.beauty-ai-local-core::before {
  left: 28px;
}

.beauty-ai-local-core::after {
  right: 28px;
}

.local-core-orbit {
  position: absolute;
  z-index: 3;
  width: 212px;
  height: 212px;
  border: 1px dashed rgba(121, 177, 139, 0.34);
  border-radius: 50%;
  pointer-events: none;
}

.local-core-orbit::before {
  position: absolute;
  inset: 34px;
  border: 1px solid rgba(121, 177, 139, 0.2);
  border-radius: 50%;
  content: "";
}

.media-beauty-local .beauty-local-acquisition-image .local-core-orbit i {
  position: absolute;
  z-index: 4;
  display: block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #79b18b;
  box-shadow: 0 0 0 8px rgba(121, 177, 139, 0.13);
  opacity: 1;
}

.media-beauty-local .beauty-local-acquisition-image .local-core-orbit i:nth-child(1) { top: 14px; left: 50%; }
.media-beauty-local .beauty-local-acquisition-image .local-core-orbit i:nth-child(2) { right: 16px; bottom: 48px; background: #92c39f; }
.media-beauty-local .beauty-local-acquisition-image .local-core-orbit i:nth-child(3) { bottom: 42px; left: 22px; background: #d9a36a; }

.local-core-card {
  position: relative;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 154px;
  height: 154px;
  padding: 18px;
  border: 1px solid rgba(121, 177, 139, 0.24);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 24px 56px rgba(76, 116, 83, 0.12);
  text-align: center;
}

.local-core-card::before {
  content: none;
}

.local-core-card::after {
  content: none;
}

.local-core-card small {
  color: #5f8f6a;
  font-size: 11px;
  font-weight: 950;
}

.local-core-card strong {
  color: #261f1d;
  font-size: 24px;
  font-weight: 950;
  line-height: 1.1;
}

.local-core-card span {
  color: rgba(38, 31, 29, 0.58);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.28;
}

.beauty-local-result-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.beauty-local-result-row span {
  display: grid;
  place-items: center;
  min-height: 60px;
  padding: 10px 8px;
  border-radius: 15px;
  color: rgba(38, 31, 29, 0.86);
  font-size: 15px;
  font-weight: 950;
  text-align: center;
}

.media-beauty-consult .case-image-slot.beauty-consult-conversion-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.98), transparent 28%),
    radial-gradient(circle at 84% 86%, rgba(121, 177, 139, 0.16), transparent 34%),
    linear-gradient(135deg, #f5fbf4 0%, #f8fcf5 54%, #fff9ef 100%);
}

.media-beauty-consult .beauty-consult-conversion-image::before,
.media-beauty-consult .beauty-consult-conversion-image::after {
  content: none;
}

.beauty-consult-conversion-image strong,
.beauty-consult-conversion-image span,
.beauty-consult-conversion-image em,
.beauty-consult-conversion-image small {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.beauty-consult-map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  color: #261f1d;
}

.beauty-consult-head {
  display: grid;
  gap: 7px;
  max-width: 690px;
}

.beauty-consult-head span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(121, 177, 139, 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.03em;
  text-transform: uppercase;
}

.beauty-consult-head strong {
  font-family: var(--display);
  font-size: clamp(30px, 2.2vw, 36px);
  font-weight: 900;
  line-height: 1.22;
}

.beauty-consult-head p {
  max-width: 650px;
  margin: 0;
  color: rgba(38, 31, 29, 0.62);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.consult-conversion-canvas {
  display: grid;
  grid-template-columns: minmax(175px, 0.75fr) minmax(260px, 1.25fr) minmax(165px, 0.7fr);
  gap: 12px;
  min-height: 0;
}

.consult-signal-stack,
.consult-brief-card,
.consult-action-ladder,
.consult-result-row span {
  border: 1px solid rgba(121, 177, 139, 0.15);
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.consult-signal-stack,
.consult-action-ladder {
  display: grid;
  align-content: center;
  gap: 10px;
  min-height: 0;
  padding: 16px;
  border-radius: 22px;
}

.consult-signal-stack > span,
.consult-action-ladder > span {
  color: #5f8f6a;
  font-size: 16px;
  font-weight: 950;
}

.consult-signal-stack article {
  display: grid;
  gap: 4px;
  min-height: 76px;
  padding: 14px;
  border-radius: 16px;
  background: linear-gradient(90deg, rgba(239, 249, 241, 0.92), rgba(255, 255, 255, 0.76));
}

.consult-signal-stack b,
.consult-action-ladder b,
.consult-brief-grid b {
  color: #261f1d;
  font-weight: 950;
}

.consult-signal-stack b {
  font-size: 18px;
  line-height: 1.12;
}

.consult-signal-stack small,
.consult-action-ladder em,
.consult-brief-grid span {
  color: rgba(38, 31, 29, 0.58);
  font-size: 12px;
  font-style: normal;
  font-weight: 780;
  line-height: 1.3;
}

.consult-brief-card {
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
  min-height: 0;
  padding: 14px;
  overflow: hidden;
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 24%, rgba(121, 177, 139, 0.18), transparent 34%),
    rgba(255, 255, 255, 0.76);
}

.consult-brief-card::before {
  position: absolute;
  inset: 18px;
  border: 1px dashed rgba(121, 177, 139, 0.22);
  border-radius: 18px;
  content: "";
  pointer-events: none;
}

.consult-brief-title {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  padding: 12px 14px;
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(239, 249, 241, 0.92), rgba(255, 255, 255, 0.78));
}

.consult-brief-title small {
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 950;
}

.consult-brief-title strong {
  color: #261f1d;
  font-size: 22px;
  font-weight: 950;
  line-height: 1.2;
}

.consult-brief-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-height: 0;
}

.consult-brief-grid article {
  display: grid;
  align-content: center;
  gap: 6px;
  min-height: 88px;
  padding: 11px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: inset 0 0 0 1px rgba(121, 177, 139, 0.12);
}

.consult-brief-grid b {
  font-size: 16px;
}

.consult-action-ladder {
  position: relative;
}

.consult-action-ladder::before {
  position: absolute;
  top: 58px;
  bottom: 42px;
  left: 31px;
  width: 2px;
  background: linear-gradient(180deg, rgba(121, 177, 139, 0.34), rgba(217, 163, 106, 0.2));
  content: "";
}

.consult-action-ladder article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 4px 10px;
  align-items: center;
  min-height: 72px;
}

.consult-action-ladder small {
  display: grid;
  grid-row: span 2;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: #79b18b;
  color: #ffffff;
  font-size: 11px;
  font-weight: 950;
  box-shadow: 0 0 0 7px rgba(121, 177, 139, 0.12);
}

.consult-action-ladder b {
  font-size: 17px;
  line-height: 1.36;
}

.consult-result-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.consult-result-row span {
  display: grid;
  place-items: center;
  min-height: 60px;
  padding: 10px 8px;
  border-radius: 15px;
  color: rgba(38, 31, 29, 0.86);
  font-size: 15px;
  font-weight: 950;
  text-align: center;
}

.consult-workbench {
  display: grid;
  grid-template-areas:
    "voice sheet"
    "trust sheet";
  grid-template-columns: minmax(318px, 0.98fr) minmax(0, 1.02fr);
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
  min-height: 0;
}

.consult-voice-strip,
.consult-translation-sheet,
.consult-trust-panel {
  border: 1px solid rgba(121, 177, 139, 0.15);
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 16px 34px rgba(76, 116, 83, 0.07);
}

.consult-voice-strip {
  grid-area: voice;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
  align-items: center;
  min-height: 116px;
  padding: 12px;
  border-radius: 22px;
}

.consult-voice-strip > span {
  grid-column: 1 / -1;
  color: #5f8f6a;
  font-size: 15px;
  font-weight: 950;
}

.consult-voice-strip article {
  display: grid;
  gap: 4px;
  min-height: 64px;
  padding: 9px 8px;
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(239, 249, 241, 0.92), rgba(255, 255, 255, 0.76));
}

.consult-voice-strip b {
  color: #261f1d;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.consult-voice-strip small {
  color: rgba(38, 31, 29, 0.58);
  font-size: 10.5px;
  font-weight: 780;
  line-height: 1.28;
}

.consult-translation-sheet {
  grid-area: sheet;
  position: relative;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 18px;
  min-height: 0;
  padding: 20px 18px 18px;
  overflow: hidden;
  border-radius: 24px;
  background:
    radial-gradient(circle at 82% 12%, rgba(121, 177, 139, 0.15), transparent 30%),
    rgba(255, 255, 255, 0.78);
}

.consult-translation-sheet::before {
  position: absolute;
  top: 24px;
  right: 22px;
  width: 78px;
  height: 78px;
  border: 1px dashed rgba(121, 177, 139, 0.28);
  border-radius: 50%;
  content: "";
}

.translation-sheet-head {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
  max-width: 280px;
  margin-bottom: 2px;
}

.translation-sheet-head small {
  color: #5f8f6a;
  font-size: 12px;
  font-weight: 950;
}

.translation-sheet-head strong {
  color: #261f1d;
  font-size: 26px;
  font-weight: 950;
  line-height: 1.14;
}

.translation-rows {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 9px;
  min-height: 0;
}

.translation-rows article {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 4px 12px;
  align-items: center;
  min-height: 72px;
  padding: 10px;
  border-radius: 18px;
  background: rgba(247, 252, 245, 0.86);
  box-shadow: inset 0 0 0 1px rgba(121, 177, 139, 0.12);
}

.translation-rows span {
  display: grid;
  grid-row: span 2;
  place-items: center;
  width: 40px;
  height: 40px;
  border-radius: 16px;
  background: #79b18b;
  color: #ffffff;
  font-size: 13px;
  font-weight: 950;
}

.translation-rows b {
  color: #261f1d;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.14;
}

.translation-rows em {
  color: rgba(38, 31, 29, 0.58);
  font-size: 12px;
  font-style: normal;
  font-weight: 780;
  line-height: 1.3;
}

.consult-trust-panel {
  grid-area: trust;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 8px;
  min-height: 0;
  padding: 14px;
  overflow: hidden;
  border-radius: 22px;
}

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

.trust-panel-head span {
  color: #5f8f6a;
  font-size: 15px;
  font-weight: 950;
}

.trust-panel-head b {
  color: rgba(38, 31, 29, 0.74);
  font-size: 13px;
  font-weight: 900;
}

.trust-chart {
  position: relative;
  min-height: 96px;
  overflow: hidden;
  border-radius: 16px;
  background:
    linear-gradient(90deg, rgba(121, 177, 139, 0.08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(121, 177, 139, 0.08) 1px, transparent 1px),
    rgba(247, 252, 245, 0.72);
  background-size: 42px 42px;
}

.media-beauty-consult .beauty-consult-conversion-image .trust-chart i {
  position: absolute;
  z-index: 1;
  display: block;
  width: 4px;
  height: 100%;
  border-radius: 0;
  background: rgba(255, 255, 255, 0.48);
  opacity: 1;
}

.media-beauty-consult .beauty-consult-conversion-image .trust-chart i:nth-child(1) { left: 18%; }
.media-beauty-consult .beauty-consult-conversion-image .trust-chart i:nth-child(2) { left: 40%; }
.media-beauty-consult .beauty-consult-conversion-image .trust-chart i:nth-child(3) { left: 62%; }
.media-beauty-consult .beauty-consult-conversion-image .trust-chart i:nth-child(4) { left: 84%; }

.trust-chart svg {
  position: relative;
  z-index: 2;
  display: block;
  width: 100%;
  height: 96px;
  min-height: 0;
}

.trust-chart path {
  fill: none;
  stroke: #79b18b;
  stroke-width: 6;
  stroke-linecap: round;
}

.trust-chart circle {
  fill: #ffffff;
  stroke: #79b18b;
  stroke-width: 4;
}

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

.trust-metrics article {
  display: grid;
  gap: 3px;
  min-height: 54px;
  padding: 8px;
  border-radius: 14px;
  background: rgba(247, 252, 245, 0.88);
}

.trust-metrics small {
  color: rgba(38, 31, 29, 0.58);
  font-size: 10px;
  font-weight: 820;
}

.trust-metrics b {
  color: #261f1d;
  font-size: 20px;
  font-weight: 950;
  line-height: 1;
}

.vision-care-record .case-tab-stage,
.vision-care-record .case-tab-stage.reverse {
  grid-template-columns: minmax(0, 1.28fr) minmax(300px, 0.72fr);
  gap: 28px;
  min-height: 690px;
}

.vision-care-record .case-media-panel {
  order: -1;
  background: rgba(255, 255, 255, 0.86);
}

.vision-care-record .case-tab-copy.dark {
  background: #10212a;
}

.vision-care-record .case-tab-copy {
  background: rgba(255, 255, 255, 0.72);
}

.vision-care-record .case-image-slot {
  min-height: 570px;
  align-content: start;
  background:
    linear-gradient(180deg, rgba(78, 136, 164, 0.11) 0 82px, transparent 82px),
    repeating-linear-gradient(180deg, transparent 0 58px, rgba(78, 136, 164, 0.12) 58px 59px),
    #fbfefe;
}

.vision-care-record .case-image-slot::after {
  position: absolute;
  right: 36px;
  bottom: 36px;
  width: min(270px, 40%);
  height: 172px;
  border: 1px solid rgba(78, 136, 164, 0.22);
  border-radius: 22px;
  background:
    radial-gradient(circle at 48% 44%, rgba(78, 136, 164, 0.32), transparent 38%),
    linear-gradient(135deg, #edf8ff, #f2faed);
  content: "";
}

.edu-skill-console .case-tab-copy {
  background: #111111;
  color: #f8f6f0;
}

.edu-skill-console .case-tab-copy > span,
.edu-skill-console .case-tab-copy p {
  color: rgba(248, 246, 240, 0.7);
}

.edu-skill-console .case-media-panel {
  background: rgba(255, 255, 255, 0.82);
}

.edu-skill-console .case-tab-copy,
.edu-skill-console .case-media-panel {
  height: 100%;
  min-height: 0;
  overflow: hidden;
}

.edu-skill-console .case-image-slot {
  min-height: 570px;
  align-content: center;
  background:
    linear-gradient(180deg, rgba(17, 17, 17, 0.03), transparent 34%),
    linear-gradient(135deg, #fff8e8, #edf1ff);
}

.edu-skill-console .case-tab-copy.edu-motive-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 16px;
  align-content: stretch;
  padding: 26px;
  background:
    radial-gradient(circle at 82% 14%, rgba(139, 113, 72, 0.2), transparent 28%),
    linear-gradient(145deg, #111111, #171615);
  color: #f8f6f0;
}

.edu-motive-insight-head {
  display: grid;
  gap: 10px;
}

.edu-motive-insight-head span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(255, 244, 224, 0.2);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #d8b479;
  font-size: 12px;
  font-weight: 950;
}

.edu-motive-insight-head h3 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(27px, 1.95vw, 30px);
  font-weight: 900;
  line-height: 1.22;
}

.edu-motive-insight-head p {
  margin: 0;
  color: rgba(248, 246, 240, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.48;
}

.edu-routing-matrix {
  position: relative;
  isolation: isolate;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 8px;
  min-height: 0;
  padding: 20px 14px 34px 48px;
  border: 1px solid rgba(255, 244, 224, 0.12);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.055);
}

.edu-routing-matrix::before,
.edu-routing-matrix::after {
  position: absolute;
  z-index: 0;
  content: "";
  background: rgba(255, 244, 224, 0.1);
}

.edu-routing-matrix::before {
  top: 20px;
  bottom: 34px;
  left: calc(50% + 17px);
  width: 1px;
}

.edu-routing-matrix::after {
  top: calc(50% - 7px);
  right: 14px;
  left: 48px;
  height: 1px;
}

.routing-axis-y,
.routing-axis-x {
  position: absolute;
  z-index: 2;
  color: rgba(216, 180, 121, 0.78);
  font-size: 10px;
  font-weight: 950;
  letter-spacing: 0;
}

.routing-axis-y {
  top: 50%;
  left: 18px;
  writing-mode: vertical-rl;
  transform: translateY(-50%);
  transform-origin: center;
}

.routing-axis-x {
  left: calc(50% + 18px);
  right: auto;
  bottom: 12px;
  transform: translateX(-50%);
}

.edu-routing-matrix article {
  position: relative;
  z-index: 1;
  display: grid;
  align-content: center;
  gap: 6px;
  min-height: 0;
  padding: 12px;
  border: 1px solid rgba(255, 244, 224, 0.11);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.07);
}

.edu-routing-matrix article.routing-hot {
  background:
    linear-gradient(135deg, rgba(216, 180, 121, 0.2), rgba(126, 151, 214, 0.12)),
    rgba(255, 255, 255, 0.08);
}

.edu-routing-matrix small {
  color: rgba(216, 180, 121, 0.86);
  font-size: 10px;
  font-weight: 950;
  line-height: 1.1;
}

.edu-routing-matrix strong {
  color: #ffffff;
  font-size: 20px;
  font-weight: 950;
  line-height: 1.08;
}

.edu-routing-matrix b {
  color: rgba(248, 246, 240, 0.62);
  font-size: 11px;
  font-weight: 820;
  line-height: 1.2;
}

.edu-routing-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.edu-routing-actions article {
  display: grid;
  gap: 5px;
  min-height: 74px;
  padding: 12px 10px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
}

.edu-routing-actions small {
  color: rgba(216, 180, 121, 0.88);
  font-size: 10px;
  font-weight: 950;
}

.edu-routing-actions strong {
  color: #ffffff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.2;
}

.edu-skill-console .case-tab-copy.edu-value-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 14px;
  align-content: stretch;
  padding: 26px;
  background:
    radial-gradient(circle at 17% 18%, rgba(126, 151, 214, 0.18), transparent 30%),
    radial-gradient(circle at 88% 84%, rgba(216, 180, 121, 0.18), transparent 28%),
    linear-gradient(145deg, #101010, #171615);
  color: #f8f6f0;
}

.edu-value-insight-head {
  display: grid;
  gap: 10px;
}

.edu-value-insight-head span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(216, 180, 121, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #d8b479;
  font-size: 12px;
  font-weight: 950;
}

.edu-value-insight-head h3 {
  margin: 0;
  color: #ffffff;
  font-family: var(--display);
  font-size: clamp(27px, 1.95vw, 31px);
  font-weight: 900;
  line-height: 1.34;
}

.edu-value-insight-head p {
  margin: 0;
  color: rgba(248, 246, 240, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.48;
}

.value-priority-board {
  display: grid;
  grid-template-columns: 126px minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
  padding: 16px;
  border: 1px solid rgba(255, 244, 224, 0.12);
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.04)),
    rgba(255, 255, 255, 0.045);
}

.value-priority-core {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 7px;
  min-height: 0;
  padding: 14px;
  border: 1px solid rgba(216, 180, 121, 0.2);
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 50%, rgba(17, 17, 17, 0.92) 0 42%, transparent 43%),
    conic-gradient(from -30deg, rgba(216, 180, 121, 0.92) 0 92deg, rgba(126, 151, 214, 0.45) 92deg 238deg, rgba(255, 255, 255, 0.14) 238deg 360deg);
  text-align: center;
}

.value-priority-core small {
  color: rgba(216, 180, 121, 0.9);
  font-size: 11px;
  font-weight: 950;
}

.value-priority-core strong {
  color: #ffffff;
  font-size: 24px;
  font-weight: 950;
  line-height: 1.24;
}

.value-priority-core span {
  color: rgba(248, 246, 240, 0.66);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.3;
}

.value-rank-list {
  display: grid;
  gap: 9px;
  min-height: 0;
}

.value-rank-list article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  grid-template-rows: auto 9px;
  gap: 7px 10px;
  align-content: center;
  min-height: 0;
  padding: 11px 12px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.07);
}

.value-rank-list article b {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: rgba(216, 180, 121, 0.16);
  color: #d8b479;
  font-size: 11px;
  font-weight: 950;
}

.value-rank-list article div {
  display: grid;
  gap: 3px;
}

.value-rank-list article strong {
  color: #ffffff;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.12;
}

.value-rank-list article span {
  color: rgba(248, 246, 240, 0.58);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
}

.value-rank-list article i {
  position: relative;
  overflow: hidden;
  height: 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.11);
}

.value-rank-list article i::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w);
  border-radius: inherit;
  background: linear-gradient(90deg, #d8b479, #7e97d6);
  content: "";
}

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

.value-action-loop article {
  display: grid;
  gap: 6px;
  align-content: center;
  min-height: 76px;
  padding: 12px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
}

.value-action-loop small {
  color: rgba(216, 180, 121, 0.9);
  font-size: 11px;
  font-weight: 950;
}

.value-action-loop strong {
  color: #ffffff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.25;
}

.value-result-strip {
  display: grid;
  grid-template-columns: 44px repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-items: center;
  min-height: 52px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 244, 224, 0.1);
}

.value-result-strip span {
  color: rgba(216, 180, 121, 0.9);
  font-size: 12px;
  font-weight: 950;
}

.value-result-strip b {
  display: grid;
  place-items: center;
  min-height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.edu-skill-console .case-tab-copy.edu-decision-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 14px;
  align-content: stretch;
  padding: 26px;
  background:
    radial-gradient(circle at 18% 16%, rgba(58, 113, 151, 0.22), transparent 30%),
    radial-gradient(circle at 86% 82%, rgba(216, 180, 121, 0.18), transparent 28%),
    linear-gradient(145deg, #0d1113, #15191a);
  color: #f8f6f0;
}

.decision-insight-head {
  display: grid;
  gap: 10px;
}

.decision-insight-head span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(119, 178, 220, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #9ac7e7;
  font-size: 12px;
  font-weight: 950;
}

.decision-insight-head h3 {
  margin: 0;
  color: #ffffff;
  font-family: var(--display);
  font-size: clamp(27px, 1.95vw, 31px);
  font-weight: 900;
  line-height: 1.34;
}

.decision-insight-head p {
  margin: 0;
  color: rgba(248, 246, 240, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.48;
}

.decision-engine-panel {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px;
  gap: 12px;
  min-height: 0;
  padding: 15px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 24px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.035)),
    rgba(255, 255, 255, 0.04);
}

.decision-signal-stack {
  display: grid;
  grid-template-rows: auto repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-height: 0;
}

.decision-signal-stack > span {
  color: rgba(154, 199, 231, 0.9);
  font-size: 12px;
  font-weight: 950;
}

.decision-signal-stack article {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  align-items: center;
  min-height: 0;
  padding: 8px 10px;
  border: 1px solid rgba(119, 178, 220, 0.11);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.07);
}

.decision-signal-stack small {
  color: rgba(216, 180, 121, 0.86);
  font-size: 10px;
  font-weight: 950;
}

.decision-signal-stack strong {
  color: #ffffff;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.18;
}

.decision-engine-core {
  position: relative;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 7px;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(119, 178, 220, 0.16);
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 50%, rgba(13, 17, 19, 0.94) 0 42%, transparent 43%),
    conic-gradient(from 12deg, rgba(119, 178, 220, 0.82), rgba(216, 180, 121, 0.72), rgba(255, 255, 255, 0.14), rgba(119, 178, 220, 0.82));
  text-align: center;
}

.decision-engine-core i {
  position: absolute;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #9ac7e7;
}

.decision-engine-core i:nth-child(1) {
  top: 24px;
  right: 25px;
}

.decision-engine-core i:nth-child(2) {
  bottom: 27px;
  right: 18px;
  background: #d8b479;
}

.decision-engine-core i:nth-child(3) {
  bottom: 22px;
  left: 24px;
}

.decision-engine-core small {
  color: rgba(154, 199, 231, 0.92);
  font-size: 11px;
  font-weight: 950;
}

.decision-engine-core strong {
  color: #ffffff;
  font-size: 22px;
  font-weight: 950;
  line-height: 1.28;
}

.decision-engine-core span {
  color: rgba(248, 246, 240, 0.66);
  font-size: 10px;
  font-weight: 820;
}

.decision-dispatch-queue {
  display: grid;
  gap: 9px;
}

.decision-dispatch-queue article {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 3px 11px;
  align-items: center;
  min-height: 70px;
  padding: 11px 12px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 17px;
  background: rgba(255, 255, 255, 0.08);
}

.decision-dispatch-queue b {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(119, 178, 220, 0.18);
  color: #9ac7e7;
  font-size: 11px;
  font-weight: 950;
}

.decision-dispatch-queue strong {
  color: #ffffff;
  font-size: 17px;
  font-weight: 950;
  line-height: 1.12;
}

.decision-dispatch-queue span {
  color: rgba(248, 246, 240, 0.6);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.24;
}

.decision-result-rail {
  display: grid;
  grid-template-columns: 44px repeat(3, minmax(0, 1fr));
  gap: 8px;
  align-items: center;
  min-height: 52px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 244, 224, 0.1);
}

.decision-result-rail span {
  color: rgba(154, 199, 231, 0.9);
  font-size: 12px;
  font-weight: 950;
}

.decision-result-rail b {
  display: grid;
  place-items: center;
  min-height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.decision-control-head {
  display: grid;
  gap: 10px;
}

.decision-control-head span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(119, 178, 220, 0.22);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #9ac7e7;
  font-size: 12px;
  font-weight: 950;
}

.decision-control-head h3 {
  margin: 0;
  color: #ffffff;
  font-family: var(--display);
  font-size: clamp(28px, 2vw, 32px);
  font-weight: 900;
  line-height: 1.3;
}

.decision-control-head p {
  margin: 0;
  color: rgba(248, 246, 240, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.48;
}

.decision-console-panel {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 0;
  padding: 16px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 26px;
  background:
    radial-gradient(circle at 18% 20%, rgba(119, 178, 220, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.035)),
    rgba(255, 255, 255, 0.04);
}

.decision-control-gauges {
  display: grid;
  grid-row: 1 / 3;
  gap: 10px;
  min-height: 0;
}

.decision-control-gauges article {
  display: grid;
  grid-template-columns: 1fr 28px;
  grid-template-rows: auto 10px;
  gap: 6px 8px;
  align-content: center;
  min-height: 0;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.075);
}

.decision-control-gauges span {
  color: rgba(248, 246, 240, 0.72);
  font-size: 11px;
  font-weight: 900;
}

.decision-control-gauges i {
  position: relative;
  grid-column: 1 / 3;
  overflow: hidden;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
}

.decision-control-gauges i::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--level);
  border-radius: inherit;
  background: linear-gradient(90deg, #9ac7e7, #d8b479);
  content: "";
}

.decision-control-gauges b {
  color: #d8b479;
  font-size: 11px;
  font-weight: 950;
  text-align: right;
}

.decision-ticket {
  display: grid;
  gap: 8px;
  align-content: center;
  min-height: 168px;
  padding: 18px;
  border: 1px solid rgba(119, 178, 220, 0.14);
  border-radius: 22px;
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.055)),
    rgba(255, 255, 255, 0.04);
}

.decision-ticket small,
.decision-trigger-dial span {
  color: rgba(154, 199, 231, 0.92);
  font-size: 11px;
  font-weight: 950;
}

.decision-ticket strong {
  color: #ffffff;
  font-family: var(--display);
  font-size: 28px;
  font-weight: 900;
  line-height: 1.28;
}

.decision-ticket p {
  margin: 0;
  color: rgba(248, 246, 240, 0.62);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.38;
}

.decision-trigger-dial {
  display: grid;
  grid-template-columns: 68px minmax(0, 1fr);
  gap: 4px 12px;
  align-content: center;
  min-height: 74px;
  padding: 12px 14px;
  border-radius: 18px;
  background:
    radial-gradient(circle at 30px 50%, rgba(216, 180, 121, 0.2) 0 28px, transparent 29px),
    rgba(255, 255, 255, 0.075);
}

.decision-trigger-dial span {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 58px;
  height: 58px;
  border: 1px solid rgba(216, 180, 121, 0.2);
  border-radius: 50%;
  text-align: center;
}

.decision-trigger-dial strong {
  color: #ffffff;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.1;
}

.decision-trigger-dial b {
  color: rgba(248, 246, 240, 0.62);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.28;
}

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

.decision-console-flow article {
  position: relative;
  display: grid;
  gap: 5px;
  align-content: center;
  min-height: 76px;
  padding: 12px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.08);
}

.decision-console-flow article + article::before {
  position: absolute;
  top: 50%;
  left: -12px;
  width: 14px;
  height: 1px;
  background: rgba(154, 199, 231, 0.34);
  content: "";
}

.decision-console-flow small {
  color: rgba(154, 199, 231, 0.9);
  font-size: 10px;
  font-weight: 950;
}

.decision-console-flow strong {
  color: #ffffff;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.decision-console-result {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-height: 46px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 244, 224, 0.1);
}

.decision-console-result b {
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.edu-skill-console .case-tab-copy.edu-skill-insight {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  align-content: stretch;
  padding: 26px;
  background:
    radial-gradient(circle at 18% 16%, rgba(216, 180, 121, 0.18), transparent 30%),
    radial-gradient(circle at 84% 78%, rgba(74, 115, 145, 0.22), transparent 28%),
    linear-gradient(145deg, #10100f, #181715);
  color: #f8f6f0;
}

.skill-insight-head {
  display: grid;
  gap: 10px;
}

.skill-insight-head span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(216, 180, 121, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #d8b479;
  font-size: 12px;
  font-weight: 950;
}

.skill-insight-head h3 {
  margin: 0;
  color: #ffffff;
  font-family: var(--display);
  font-size: clamp(27px, 1.95vw, 31px);
  font-weight: 900;
  line-height: 1.32;
}

.skill-insight-head p {
  margin: 0;
  color: rgba(248, 246, 240, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.48;
}

.skill-coach-board {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr);
  grid-template-rows: minmax(0, 1fr) auto;
  gap: 12px;
  min-height: 0;
  padding: 16px;
  border: 1px solid rgba(255, 244, 224, 0.11);
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.035)),
    rgba(255, 255, 255, 0.045);
}

.skill-gap-panel,
.skill-mission-panel {
  position: relative;
  display: grid;
  gap: 10px;
  min-height: 0;
  padding: 14px;
  border: 1px solid rgba(255, 244, 224, 0.1);
  border-radius: 21px;
  background: rgba(255, 255, 255, 0.065);
}

.skill-gap-panel small,
.skill-mission-panel small {
  color: rgba(216, 180, 121, 0.9);
  font-size: 12px;
  font-weight: 950;
}

.skill-gap-panel article {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 30px;
  grid-template-rows: auto 10px;
  gap: 6px 8px;
  align-content: center;
  min-height: 54px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.07);
}

.skill-gap-panel b {
  color: #ffffff;
  font-size: 13px;
  font-weight: 950;
  line-height: 1.12;
}

.skill-gap-panel span {
  color: #d8b479;
  font-size: 13px;
  font-weight: 950;
  text-align: right;
}

.skill-gap-panel i {
  position: relative;
  grid-column: 1 / 3;
  overflow: hidden;
  height: 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
}

.skill-gap-panel i::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--level);
  border-radius: inherit;
  background: linear-gradient(90deg, #d8b479, #7aa9ca);
  content: "";
}

.skill-mission-panel article {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  grid-template-rows: auto auto;
  gap: 3px 10px;
  align-content: center;
  min-height: 58px;
  padding: 10px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.07);
}

.skill-mission-panel b {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: rgba(122, 169, 202, 0.18);
  color: #9ac7e7;
  font-size: 10px;
  font-weight: 950;
}

.skill-mission-panel strong {
  color: #ffffff;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.skill-mission-panel span {
  color: rgba(248, 246, 240, 0.6);
  font-size: 10px;
  font-weight: 820;
  line-height: 1.2;
}

.skill-coach-loop {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 244, 224, 0.1);
}

.skill-coach-loop article {
  position: relative;
  display: grid;
  place-items: center;
  gap: 3px;
  min-height: 62px;
  border-radius: 17px;
  background: rgba(255, 255, 255, 0.08);
}

.skill-coach-loop article + article::before {
  position: absolute;
  top: 50%;
  left: -9px;
  width: 10px;
  height: 1px;
  background: rgba(216, 180, 121, 0.34);
  content: "";
}

.skill-coach-loop b {
  color: #ffffff;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.skill-coach-loop span {
  color: rgba(216, 180, 121, 0.78);
  font-size: 10px;
  font-weight: 900;
}

.skill-insight-result {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-height: 46px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 244, 224, 0.1);
}

.skill-insight-result b {
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: #ffffff;
  font-size: 12px;
  font-weight: 950;
}

.edu-skill-console .case-tab-copy.edu-skill-flywheel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  align-content: stretch;
  padding: 26px;
  background:
    radial-gradient(circle at 18% 18%, rgba(216, 180, 121, 0.18), transparent 30%),
    radial-gradient(circle at 84% 76%, rgba(74, 115, 145, 0.22), transparent 28%),
    linear-gradient(145deg, #10100f, #181715);
  color: #f8f6f0;
}

.skill-flywheel-head {
  display: grid;
  gap: 10px;
}

.skill-flywheel-head span {
  width: fit-content;
  padding: 7px 12px;
  border: 1px solid rgba(216, 180, 121, 0.24);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #d8b479;
  font-size: 12px;
  font-weight: 950;
}

.skill-flywheel-head h3 {
  margin: 0;
  color: #ffffff;
  font-family: var(--display);
  font-size: clamp(28px, 2vw, 32px);
  font-weight: 900;
  line-height: 1.28;
}

.skill-flywheel-head p {
  margin: 0;
  color: rgba(248, 246, 240, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.48;
}

.skill-flywheel-body {
  position: relative;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(255, 244, 224, 0.11);
  border-radius: 28px;
  background:
    radial-gradient(circle at 50% 50%, rgba(216, 180, 121, 0.08), transparent 44%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.08), rgba(255, 255, 255, 0.035)),
    rgba(255, 255, 255, 0.045);
}

.skill-flywheel-ring {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 224px;
  height: 224px;
  border: 1px dashed rgba(216, 180, 121, 0.22);
  border-radius: 50%;
  transform: translate(-50%, -50%);
}

.skill-flywheel-ring::before,
.skill-flywheel-ring::after {
  position: absolute;
  border-radius: 50%;
  content: "";
}

.skill-flywheel-ring::before {
  inset: 18px;
  border: 14px solid rgba(122, 169, 202, 0.08);
  border-top-color: rgba(216, 180, 121, 0.42);
  border-right-color: rgba(122, 169, 202, 0.24);
}

.skill-flywheel-ring::after {
  inset: 54px;
  border: 1px solid rgba(255, 244, 224, 0.12);
}

.skill-flywheel-core {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 5px;
  width: 110px;
  height: 110px;
  border: 1px solid rgba(122, 169, 202, 0.18);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 42%, rgba(122, 169, 202, 0.22), transparent 48%),
    linear-gradient(145deg, rgba(15, 24, 31, 0.96), rgba(31, 45, 54, 0.92));
  box-shadow: 0 18px 38px rgba(0, 0, 0, 0.18);
  text-align: center;
  transform: translate(-50%, -50%);
}

.skill-flywheel-core small {
  color: rgba(154, 199, 231, 0.92);
  font-size: 10px;
  font-weight: 950;
}

.skill-flywheel-core strong {
  color: #ffffff;
  font-size: 22px;
  font-weight: 950;
  line-height: 1.08;
}

.skill-flywheel-core span {
  color: rgba(216, 180, 121, 0.82);
  font-size: 10px;
  font-weight: 900;
}

.skill-flywheel-node {
  position: absolute;
  display: grid;
  align-content: center;
  gap: 4px;
  width: 112px;
  min-height: 62px;
  padding: 10px 12px;
  border: 1px solid rgba(255, 244, 224, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.085);
  box-shadow: 0 14px 26px rgba(0, 0, 0, 0.1);
}

.skill-flywheel-node::before {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d8b479;
  content: "";
}

.skill-flywheel-node b {
  color: #ffffff;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.skill-flywheel-node span {
  color: rgba(248, 246, 240, 0.6);
  font-size: 10px;
  font-weight: 820;
  line-height: 1.18;
}

.skill-flywheel-node.node-input {
  top: 16px;
  left: 50%;
  width: 132px;
  transform: translateX(-50%);
}

.skill-flywheel-node.node-card {
  top: 116px;
  right: 4px;
}

.skill-flywheel-node.node-cue {
  right: 42px;
  bottom: 24px;
}

.skill-flywheel-node.node-score {
  bottom: 24px;
  left: 42px;
}

.skill-flywheel-node.node-version {
  top: 116px;
  left: 4px;
}

.skill-daily-board {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  min-height: 72px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 244, 224, 0.1);
}

.skill-daily-board article {
  display: grid;
  place-items: center;
  gap: 4px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.09);
  text-align: center;
}

.skill-daily-board small {
  color: rgba(216, 180, 121, 0.82);
  font-size: 10px;
  font-weight: 900;
}

.skill-daily-board strong {
  display: grid;
  place-items: center;
  min-height: 28px;
  color: #ffffff;
  font-size: 22px;
  font-weight: 950;
  line-height: 1.1;
}

.case-image-slot img {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-lizi-skin .case-image-slot img {
  object-fit: contain;
  object-position: center center;
}

.case-image-slot.case-image-photo {
  background: #ffffff;
}

.case-image-slot.case-image-photo::before,
.particle-growth-lab .case-image-slot.case-image-photo::after {
  content: none;
}

.case-photo-caption {
  position: absolute;
  bottom: 30px;
  left: 30px;
  z-index: 3;
  display: grid;
  gap: 8px;
  max-width: min(380px, calc(100% - 60px));
  padding: 16px 18px 17px;
  border: 1px solid rgba(255, 224, 212, 0.72);
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(255, 252, 248, 0.82), rgba(255, 236, 232, 0.58));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.72),
    0 18px 48px rgba(93, 61, 50, 0.13);
}

.case-photo-caption small {
  width: fit-content;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255, 247, 233, 0.86);
  color: #9b5b06;
  font-size: 12px;
  font-weight: 900;
}

.case-photo-caption strong {
  font-family: var(--display);
  color: rgba(17, 17, 17, 0.88);
  font-size: clamp(29px, 2.25vw, 40px);
  line-height: 1;
}

.case-photo-caption span {
  color: rgba(35, 27, 24, 0.62);
  font-size: 13px;
  font-weight: 820;
}

.media-lizi-skin .case-photo-caption {
  max-width: min(340px, calc(100% - 60px));
  padding: 14px 16px 15px;
  border-color: rgba(255, 218, 226, 0.68);
  background: linear-gradient(135deg, rgba(255, 252, 249, 0.84), rgba(255, 239, 245, 0.62));
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.78),
    0 16px 42px rgba(120, 70, 78, 0.12);
}

.media-lizi-skin .case-photo-caption small {
  background: rgba(255, 244, 248, 0.9);
  color: #9a536a;
}

.media-lizi-skin .case-photo-caption strong {
  font-size: clamp(24px, 1.8vw, 32px);
}

.media-lizi-skin .case-photo-caption span {
  color: rgba(70, 51, 49, 0.6);
  font-size: 12px;
}

@media (max-width: 900px) {
  .case-photo-caption {
    bottom: 20px;
    left: 20px;
    max-width: calc(100% - 40px);
  }
}

@media (max-width: 560px) {
  .case-photo-caption {
    gap: 6px;
    padding: 12px 13px 13px;
    border-radius: 16px;
  }

  .case-photo-caption small {
    font-size: 11px;
  }

  .case-photo-caption strong {
    font-size: 25px;
  }

  .case-photo-caption span {
    font-size: 12px;
  }
}

.edu-skill-console .case-image-slot::after {
  position: absolute;
  inset: 48px 42px auto 42px;
  height: 230px;
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(17, 17, 17, 0.08) 0 32%, transparent 32% 36%, rgba(17, 17, 17, 0.08) 36% 68%, transparent 68% 72%, rgba(17, 17, 17, 0.08) 72% 100%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(255, 255, 255, 0.42));
  content: "";
}

.edu-skill-console .case-image-slot.edu-motive-map {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 0;
  border-color: rgba(139, 113, 72, 0.14);
  background:
    radial-gradient(circle at 15% 16%, rgba(255, 255, 255, 0.92), transparent 28%),
    radial-gradient(circle at 84% 84%, rgba(126, 151, 214, 0.14), transparent 32%),
    linear-gradient(135deg, rgba(255, 248, 232, 0.96), rgba(238, 242, 255, 0.96));
}

.edu-skill-console .case-image-slot.edu-motive-map::before,
.edu-skill-console .case-image-slot.edu-motive-map::after {
  content: none;
}

.edu-motive-map strong,
.edu-motive-map span,
.edu-motive-map small,
.edu-motive-map b,
.edu-motive-map p,
.edu-motive-map h4,
.edu-motive-map i {
  position: static;
  z-index: auto;
  margin: 0;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.edu-motive-map i {
  display: block;
  width: auto;
  height: auto;
  border-radius: 0;
  background: transparent;
  opacity: 1;
}

.edu-motive-board {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  height: 100%;
  min-height: 0;
  padding: 24px;
  color: #201b17;
}

.edu-motive-head {
  display: grid;
  gap: 7px;
}

.edu-motive-head span {
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(139, 113, 72, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: #8b7148;
  font-size: 11px;
  font-weight: 950;
}

.edu-motive-head strong {
  display: block;
  max-width: 580px;
  min-height: 48px;
  color: #201b17;
  font-family: var(--display);
  font-size: clamp(28px, 2.7vw, 43px);
  font-weight: 900;
  line-height: 1.14;
}

.edu-motive-head p {
  max-width: 620px;
  color: rgba(32, 27, 23, 0.6);
  font-size: 14px;
  font-weight: 780;
  line-height: 1.42;
}

.edu-motive-grid {
  display: grid;
  grid-template-columns: minmax(150px, 0.9fr) minmax(150px, 0.9fr) minmax(170px, 1fr);
  gap: 12px;
  min-height: 0;
}

.edu-motive-inbox,
.edu-motive-output {
  display: grid;
  align-content: stretch;
  gap: 8px;
  min-height: 0;
  padding: 14px;
  border: 1px solid rgba(139, 113, 72, 0.12);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.66);
  box-shadow: 0 18px 34px rgba(93, 75, 52, 0.06);
}

.edu-motive-inbox h4,
.edu-motive-output h4 {
  color: #8b7148;
  font-size: 14px;
  font-weight: 950;
}

.edu-motive-inbox article {
  display: grid;
  gap: 5px;
  min-height: 78px;
  padding: 11px 12px;
  border: 1px solid rgba(139, 113, 72, 0.12);
  border-radius: 16px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.86), rgba(255, 248, 235, 0.72));
}

.edu-motive-inbox article small {
  color: rgba(139, 113, 72, 0.82);
  font-size: 11px;
  font-weight: 950;
}

.edu-motive-inbox article b {
  color: #201b17;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.16;
}

.edu-motive-inbox article span {
  color: rgba(32, 27, 23, 0.55);
  font-size: 11px;
  font-weight: 800;
}

.edu-motive-core {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 12px;
  min-height: 0;
  border: 1px solid rgba(126, 151, 214, 0.16);
  border-radius: 24px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.92), rgba(244, 237, 224, 0.68) 54%, rgba(238, 242, 255, 0.68));
  overflow: hidden;
}

.motive-core-ring {
  position: relative;
  display: grid;
  place-items: center;
  width: 178px;
  aspect-ratio: 1;
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.96) 0 42%, transparent 43%),
    conic-gradient(from 210deg, rgba(139, 113, 72, 0.3), rgba(126, 151, 214, 0.48), rgba(139, 113, 72, 0.18), rgba(139, 113, 72, 0.3));
  box-shadow:
    inset 0 0 0 1px rgba(139, 113, 72, 0.1),
    0 18px 42px rgba(93, 75, 52, 0.08);
}

.motive-core-ring i {
  position: absolute;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: #8b7148;
  box-shadow: 0 0 0 8px rgba(139, 113, 72, 0.1);
}

.edu-skill-console .edu-motive-map .motive-core-ring i {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  opacity: 1;
}

.motive-core-ring i:nth-child(1) {
  top: 20px;
  left: 50%;
  transform: translateX(-50%);
}

.motive-core-ring i:nth-child(2) {
  right: 22px;
  bottom: 42px;
  background: #7e97d6;
  box-shadow: 0 0 0 8px rgba(126, 151, 214, 0.12);
}

.motive-core-ring i:nth-child(3) {
  bottom: 38px;
  left: 22px;
}

.motive-core-ring span {
  display: grid;
  place-items: center;
  width: 92px;
  height: 92px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.86);
  color: #201b17;
  font-size: 21px;
  font-weight: 950;
  line-height: 1.16;
  text-align: center;
}

.motive-core-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 7px;
  padding: 0 14px;
}

.motive-core-tags b {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(32, 27, 23, 0.08);
  color: rgba(32, 27, 23, 0.72);
  font-size: 12px;
  font-weight: 920;
}

.edu-motive-output {
  gap: 10px;
}

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

.motive-bar span {
  color: rgba(32, 27, 23, 0.68);
  font-size: 12px;
  font-weight: 900;
}

.motive-bar i {
  position: relative;
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(126, 151, 214, 0.12);
}

.edu-skill-console .edu-motive-map .motive-bar i {
  inset: auto;
  width: auto;
  height: 12px;
  border-radius: 999px;
  opacity: 1;
}

.motive-bar i::before {
  position: absolute;
  inset: 0 auto 0 0;
  width: var(--w);
  border-radius: inherit;
  background: linear-gradient(90deg, #8b7148, #7e97d6);
  content: "";
}

.motive-bar b {
  color: #201b17;
  font-size: 12px;
  font-weight: 950;
  text-align: right;
}

.edu-motive-path {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.edu-motive-path article {
  display: grid;
  gap: 5px;
  min-height: 72px;
  padding: 11px 12px;
  border: 1px solid rgba(139, 113, 72, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 14px 28px rgba(93, 75, 52, 0.05);
}

.edu-motive-path small {
  color: rgba(139, 113, 72, 0.78);
  font-size: 10px;
  font-weight: 950;
}

.edu-motive-path strong {
  color: #201b17;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.1;
}

.edu-motive-path span {
  color: rgba(32, 27, 23, 0.55);
  font-size: 11px;
  font-weight: 800;
}

.edu-skill-console .case-image-slot.edu-value-anchor {
  min-height: 570px;
  align-content: stretch;
  padding: 20px 22px;
  background:
    radial-gradient(circle at 15% 20%, rgba(139, 113, 72, 0.12), transparent 26%),
    radial-gradient(circle at 86% 18%, rgba(126, 151, 214, 0.15), transparent 32%),
    linear-gradient(135deg, #fffaf1 0%, #f6f8ff 100%);
}

.edu-skill-console .case-image-slot.edu-value-anchor::before,
.edu-skill-console .case-image-slot.edu-value-anchor::after {
  content: none;
}

.edu-value-anchor strong,
.edu-value-anchor span,
.edu-value-anchor small,
.edu-value-anchor b,
.edu-value-anchor p,
.edu-value-anchor h4,
.edu-value-anchor article,
.edu-value-anchor div,
.edu-value-anchor section {
  position: static;
  inset: auto;
  z-index: auto;
  width: auto;
  height: auto;
  margin: 0;
  transform: none;
  opacity: 1;
  letter-spacing: 0;
  box-shadow: none;
}

.edu-value-board {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.edu-value-head {
  display: grid;
  gap: 8px;
}

.edu-value-head span {
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(139, 113, 72, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #8b7148;
  font-size: 11px;
  font-weight: 950;
}

.edu-value-head strong {
  color: #201b17;
  font-family: var(--display);
  font-size: 34px;
  font-weight: 900;
  line-height: 1.36;
}

.edu-value-head p {
  max-width: 560px;
  color: rgba(32, 27, 23, 0.58);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.edu-value-canvas {
  display: grid;
  grid-template-columns: 152px minmax(0, 1fr) 170px;
  gap: 12px;
  min-height: 0;
}

.value-question-rail,
.value-proof-stack,
.value-answer-card {
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(139, 113, 72, 0.11);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.62);
}

.value-question-rail {
  display: grid;
  grid-template-rows: auto repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 14px;
}

.value-question-rail h4,
.value-proof-title small,
.value-answer-card span {
  color: rgba(139, 113, 72, 0.82);
  font-size: 12px;
  font-weight: 950;
}

.value-question-rail article {
  display: grid;
  align-content: center;
  gap: 4px;
  min-height: 0;
  padding: 9px 10px;
  border-radius: 14px;
  background: rgba(255, 249, 239, 0.82);
}

.value-question-rail b {
  color: #201b17;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.12;
}

.value-question-rail small {
  color: rgba(32, 27, 23, 0.48);
  font-size: 10px;
  font-weight: 820;
}

.value-proof-stack {
  position: relative;
  display: grid;
  grid-template-rows: auto repeat(4, minmax(0, 1fr));
  gap: 8px;
  min-height: 0;
  padding: 14px;
  overflow: hidden;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(255, 244, 230, 0.46)),
    rgba(255, 255, 255, 0.54);
}

.value-proof-title {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 3px;
}

.value-proof-title strong {
  color: #201b17;
  font-size: 18px;
  font-weight: 950;
  line-height: 1.35;
}

.value-proof-stack article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr);
  grid-template-rows: auto auto;
  column-gap: 8px;
  align-content: center;
  min-height: 0;
  margin-left: calc((var(--step) - 1) * 10px);
  margin-right: calc((4 - var(--step)) * 10px);
  padding: 8px 10px;
  border: 1px solid rgba(126, 151, 214, 0.12);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.82);
  box-shadow: 0 14px 26px rgba(76, 72, 66, 0.05);
}

.value-proof-stack article span {
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: linear-gradient(135deg, rgba(139, 113, 72, 0.18), rgba(126, 151, 214, 0.2));
  color: #8b7148;
  font-size: 11px;
  font-weight: 950;
}

.value-proof-stack article b {
  color: #201b17;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.value-proof-stack article small {
  color: rgba(32, 27, 23, 0.52);
  font-size: 10px;
  font-weight: 780;
  line-height: 1.2;
}

.value-answer-card {
  display: grid;
  align-content: center;
  gap: 12px;
  padding: 18px;
  background:
    radial-gradient(circle at 50% 20%, rgba(126, 151, 214, 0.16), transparent 38%),
    rgba(255, 255, 255, 0.64);
}

.value-answer-card strong {
  color: #201b17;
  font-family: var(--display);
  font-size: 26px;
  font-weight: 900;
  line-height: 1.32;
}

.value-answer-card p {
  color: rgba(32, 27, 23, 0.55);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.38;
}

.value-answer-card div {
  display: grid;
  gap: 8px;
}

.value-answer-card b {
  padding: 9px 10px;
  border-radius: 999px;
  background: rgba(32, 27, 23, 0.08);
  color: #201b17;
  font-size: 12px;
  font-weight: 950;
  text-align: center;
}

.edu-value-footer {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}

.edu-value-footer article {
  display: grid;
  gap: 4px;
  min-height: 58px;
  align-content: center;
  padding: 10px 12px;
  border: 1px solid rgba(139, 113, 72, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.7);
}

.edu-value-footer strong {
  color: #201b17;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.3;
}

.edu-value-footer span {
  color: rgba(32, 27, 23, 0.5);
  font-size: 10px;
  font-weight: 820;
}

.edu-skill-console .case-image-slot.edu-decision-path {
  min-height: 570px;
  align-content: stretch;
  padding: 20px 22px;
  background:
    radial-gradient(circle at 14% 82%, rgba(216, 180, 121, 0.16), transparent 30%),
    radial-gradient(circle at 86% 20%, rgba(126, 151, 214, 0.18), transparent 31%),
    linear-gradient(135deg, #f7fbff 0%, #fff7eb 100%);
}

.edu-skill-console .case-image-slot.edu-decision-path::before,
.edu-skill-console .case-image-slot.edu-decision-path::after {
  content: none;
}

.edu-decision-path strong,
.edu-decision-path span,
.edu-decision-path small,
.edu-decision-path b,
.edu-decision-path p,
.edu-decision-path h4,
.edu-decision-path article,
.edu-decision-path div,
.edu-decision-path section,
.edu-decision-path i {
  position: static;
  inset: auto;
  z-index: auto;
  width: auto;
  height: auto;
  margin: 0;
  transform: none;
  opacity: 1;
  letter-spacing: 0;
  box-shadow: none;
}

.edu-decision-board {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  gap: 13px;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.edu-decision-head {
  display: grid;
  gap: 8px;
}

.edu-decision-head span {
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(49, 87, 124, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #31577c;
  font-size: 11px;
  font-weight: 950;
}

.edu-decision-head strong {
  color: #17202a;
  font-family: var(--display);
  font-size: 33px;
  font-weight: 900;
  line-height: 1.32;
}

.edu-decision-head p {
  max-width: 590px;
  color: rgba(23, 32, 42, 0.58);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.decision-cockpit {
  display: grid;
  grid-template-columns: 170px minmax(0, 1fr);
  gap: 12px;
  min-height: 0;
}

.decision-state-panel,
.decision-route-panel {
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(49, 87, 124, 0.12);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.66);
}

.decision-state-panel {
  display: grid;
  grid-template-rows: auto repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 14px;
}

.decision-state-panel h4,
.decision-route-title small,
.decision-task-row span {
  color: rgba(49, 87, 124, 0.78);
  font-size: 12px;
  font-weight: 950;
}

.decision-state-panel article {
  display: grid;
  align-content: center;
  gap: 5px;
  min-height: 0;
  padding: 10px 12px;
  border-radius: 15px;
  background: linear-gradient(135deg, rgba(236, 245, 255, 0.86), rgba(255, 249, 239, 0.72));
}

.decision-state-panel small {
  color: rgba(139, 113, 72, 0.82);
  font-size: 10px;
  font-weight: 950;
}

.decision-state-panel b {
  color: #17202a;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.decision-route-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
  padding: 15px 16px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.78), rgba(237, 244, 255, 0.5)),
    rgba(255, 255, 255, 0.62);
}

.decision-route-title {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}

.decision-route-title b {
  color: #17202a;
  font-size: 18px;
  font-weight: 950;
}

.decision-route-road {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  align-items: center;
  gap: 8px;
  min-height: 0;
  padding: 22px 0 10px;
}

.edu-decision-path .decision-road-line {
  position: absolute;
  top: 56px;
  right: 8%;
  left: 8%;
  z-index: 0;
  height: 4px;
  border-radius: 999px;
  background: linear-gradient(90deg, #31577c, #7e97d6 62%, #d8b479);
}

.decision-route-road article {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  align-content: start;
  gap: 7px;
  min-height: 132px;
  padding-top: calc((var(--p) % 2) * 34px);
}

.decision-route-road article small {
  display: grid;
  place-items: center;
  width: 50px;
  height: 50px;
  border: 4px solid rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  background: linear-gradient(135deg, #31577c, #7e97d6);
  color: #ffffff;
  font-size: 11px;
  font-weight: 950;
  text-align: center;
  box-shadow: 0 14px 28px rgba(49, 87, 124, 0.16);
}

.decision-route-road article:nth-child(6) small {
  background: linear-gradient(135deg, #8b7148, #d8b479);
}

.decision-route-road article strong {
  color: #17202a;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.12;
  text-align: center;
}

.decision-route-road article span {
  color: rgba(23, 32, 42, 0.54);
  font-size: 10px;
  font-weight: 820;
  line-height: 1.2;
  text-align: center;
}

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

.decision-task-row article {
  display: grid;
  gap: 6px;
  min-height: 88px;
  padding: 12px 13px;
  border: 1px solid rgba(49, 87, 124, 0.11);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
}

.decision-task-row strong {
  color: #17202a;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.decision-task-row small {
  color: rgba(23, 32, 42, 0.52);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.32;
}

.decision-output-bar {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 9px;
}

.decision-output-bar b {
  display: grid;
  place-items: center;
  min-height: 42px;
  border: 1px solid rgba(49, 87, 124, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: #17202a;
  font-size: 12px;
  font-weight: 950;
}

.edu-decision-map-board {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 13px;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.decision-map-head {
  display: grid;
  gap: 8px;
}

.decision-map-head span {
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(49, 87, 124, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #31577c;
  font-size: 11px;
  font-weight: 950;
}

.decision-map-head strong {
  color: #17202a;
  font-family: var(--display);
  font-size: 33px;
  font-weight: 900;
  line-height: 1.32;
}

.decision-map-head p {
  max-width: 590px;
  color: rgba(23, 32, 42, 0.58);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.decision-route-map {
  position: relative;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(49, 87, 124, 0.12);
  border-radius: 28px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.84), rgba(238, 246, 255, 0.5)),
    rgba(255, 255, 255, 0.62);
}

.decision-route-map::before {
  content: none;
}

.decision-map-line {
  position: absolute;
  inset: 34px 26px 24px;
  width: calc(100% - 52px);
  height: calc(100% - 58px);
  fill: none;
}

.decision-map-line path {
  stroke: rgba(49, 87, 124, 0.16);
  stroke-linecap: round;
  stroke-width: 20;
}

.decision-map-line .decision-map-line-active {
  stroke: url("#unused");
  stroke: #31577c;
  stroke-dasharray: 430 900;
  stroke-width: 8;
}

.route-stop {
  position: absolute;
  display: grid;
  gap: 4px;
  width: 128px;
  min-height: 80px;
  padding: 10px 12px;
  border: 1px solid rgba(49, 87, 124, 0.12);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.86);
  box-shadow: 0 18px 34px rgba(49, 87, 124, 0.08);
}

.route-stop::before {
  position: absolute;
  top: -10px;
  left: 18px;
  width: 18px;
  height: 18px;
  border: 4px solid rgba(255, 255, 255, 0.9);
  border-radius: 50%;
  background: #31577c;
  box-shadow: 0 8px 18px rgba(49, 87, 124, 0.18);
  content: "";
}

.route-stop small {
  color: rgba(49, 87, 124, 0.78);
  font-size: 10px;
  font-weight: 950;
}

.route-stop strong {
  color: #17202a;
  font-size: 16px;
  font-weight: 950;
  line-height: 1.12;
}

.route-stop span {
  color: rgba(23, 32, 42, 0.54);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.25;
}

.route-stop-1 {
  left: 22px;
  bottom: 26px;
}

.route-stop-2 {
  top: 12px;
  left: 188px;
}

.route-stop-3 {
  right: 74px;
  bottom: 80px;
}

.route-stop-4 {
  top: 18px;
  right: 22px;
}

.route-stop-4::before {
  background: #d8b479;
}

.decision-dispatch-card {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  gap: 6px;
  width: 210px;
  min-height: 108px;
  padding: 13px 16px;
  border: 1px solid rgba(49, 87, 124, 0.16);
  border-radius: 28px;
  background:
    radial-gradient(circle at 50% 10%, rgba(126, 151, 214, 0.2), transparent 42%),
    rgba(255, 255, 255, 0.9);
  text-align: center;
  transform: translate(-50%, -50%);
  box-shadow: 0 22px 42px rgba(49, 87, 124, 0.1);
}

.decision-dispatch-card small {
  color: rgba(49, 87, 124, 0.78);
  font-size: 11px;
  font-weight: 950;
}

.decision-dispatch-card strong {
  color: #17202a;
  font-family: var(--display);
  font-size: 21px;
  font-weight: 900;
  line-height: 1.18;
}

.decision-dispatch-card span {
  color: rgba(23, 32, 42, 0.54);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.2;
  white-space: nowrap;
}

.decision-risk-note {
  position: absolute;
  right: 224px;
  bottom: 20px;
  display: grid;
  gap: 4px;
  width: 154px;
  padding: 10px 12px;
  border-left: 4px solid #d8b479;
  border-radius: 16px;
  background: rgba(255, 250, 240, 0.88);
}

.decision-risk-note b {
  color: #8b7148;
  font-size: 13px;
  font-weight: 950;
}

.decision-risk-note span {
  color: rgba(23, 32, 42, 0.54);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.28;
}

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

.decision-map-actions article {
  display: grid;
  gap: 5px;
  min-height: 72px;
  align-content: center;
  padding: 10px 12px;
  border: 1px solid rgba(49, 87, 124, 0.11);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.7);
}

.decision-map-actions small {
  color: rgba(49, 87, 124, 0.78);
  font-size: 10px;
  font-weight: 950;
}

.decision-map-actions strong {
  color: #17202a;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
}

.decision-map-actions span {
  color: rgba(23, 32, 42, 0.52);
  font-size: 10px;
  font-weight: 780;
  line-height: 1.26;
}

.edu-decision-path .edu-decision-map-board {
  position: relative;
  display: grid;
}

.edu-decision-path .decision-route-map {
  position: relative;
  display: block;
  overflow: hidden;
}

.edu-decision-path .decision-map-line {
  position: absolute;
}

.edu-decision-path .route-stop {
  position: absolute;
  display: grid;
  width: 128px;
  min-height: 80px;
}

.edu-decision-path .route-stop-1 {
  left: 22px;
  bottom: 26px;
}

.edu-decision-path .route-stop-2 {
  top: 12px;
  left: 188px;
}

.edu-decision-path .route-stop-3 {
  right: 74px;
  bottom: 80px;
}

.edu-decision-path .route-stop-4 {
  top: 18px;
  right: 22px;
}

.edu-decision-path .decision-dispatch-card {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  width: 210px;
  min-height: 108px;
  transform: translate(-50%, -50%);
}

.edu-decision-path .decision-risk-note {
  position: absolute;
  right: 224px;
  bottom: 20px;
  display: grid;
  width: 154px;
}

.edu-decision-path .decision-map-actions {
  display: grid;
}

.edu-decision-path .decision-map-actions article {
  display: grid;
}

.edu-skill-console .case-image-slot.edu-skill-replica {
  min-height: 570px;
  align-content: stretch;
  padding: 20px 22px;
  background:
    radial-gradient(circle at 15% 18%, rgba(216, 180, 121, 0.16), transparent 30%),
    radial-gradient(circle at 88% 76%, rgba(97, 134, 166, 0.18), transparent 32%),
    linear-gradient(135deg, #fffaf0 0%, #eef5fb 100%);
}

.edu-skill-console .case-image-slot.edu-skill-replica::before,
.edu-skill-console .case-image-slot.edu-skill-replica::after {
  content: none;
}

.edu-skill-replica strong,
.edu-skill-replica span,
.edu-skill-replica small,
.edu-skill-replica b,
.edu-skill-replica p,
.edu-skill-replica h4,
.edu-skill-replica article,
.edu-skill-replica div,
.edu-skill-replica section {
  position: static;
  inset: auto;
  z-index: auto;
  width: auto;
  height: auto;
  margin: 0;
  transform: none;
  opacity: 1;
  letter-spacing: 0;
  box-shadow: none;
}

.edu-skill-replica-board {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 13px;
  width: 100%;
  height: 100%;
  min-height: 0;
}

.skill-replica-head {
  display: grid;
  gap: 8px;
}

.skill-replica-head span {
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(139, 113, 72, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: #8b7148;
  font-size: 11px;
  font-weight: 950;
}

.skill-replica-head strong {
  color: #201b17;
  font-family: var(--display);
  font-size: 33px;
  font-weight: 900;
  line-height: 1.32;
}

.skill-replica-head p {
  max-width: 590px;
  color: rgba(32, 27, 23, 0.58);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.45;
}

.skill-workbench {
  position: relative;
  display: grid;
  grid-template-columns: 158px minmax(0, 1fr) 156px;
  gap: 12px;
  min-height: 0;
}

.skill-source-notes,
.skill-base-stack,
.skill-training-ring {
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(139, 113, 72, 0.11);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.65);
}

.skill-source-notes {
  display: grid;
  grid-template-rows: auto repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 14px;
}

.skill-source-notes h4 {
  color: rgba(139, 113, 72, 0.82);
  font-size: 12px;
  font-weight: 950;
}

.skill-source-notes article {
  display: grid;
  gap: 4px;
  align-content: center;
  min-height: 0;
  padding: 9px 10px;
  border-radius: 15px;
  background: rgba(255, 248, 238, 0.82);
}

.skill-source-notes small {
  color: rgba(139, 113, 72, 0.8);
  font-size: 10px;
  font-weight: 950;
}

.skill-source-notes b {
  color: #201b17;
  font-size: 13px;
  font-weight: 900;
  line-height: 1.22;
}

.skill-base-stack {
  position: relative;
  display: grid;
  place-items: center;
  padding: 18px;
  background:
    radial-gradient(circle at 50% 36%, rgba(216, 180, 121, 0.2), transparent 42%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.84), rgba(241, 246, 251, 0.62));
}

.skill-card-layer,
.skill-card-main,
.skill-version-chip {
  position: absolute;
}

.skill-card-layer {
  width: 196px;
  height: 138px;
  border: 1px solid rgba(97, 134, 166, 0.12);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.56);
}

.layer-one {
  transform: translate(18px, 22px) rotate(4deg);
}

.layer-two {
  transform: translate(-18px, 10px) rotate(-5deg);
}

.skill-card-main {
  display: grid;
  place-items: center;
  gap: 7px;
  width: 220px;
  min-height: 154px;
  padding: 20px;
  border: 1px solid rgba(139, 113, 72, 0.16);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.9);
  text-align: center;
  box-shadow: 0 18px 38px rgba(70, 66, 58, 0.08);
}

.skill-card-main small {
  color: rgba(139, 113, 72, 0.86);
  font-size: 11px;
  font-weight: 950;
}

.skill-card-main strong {
  color: #201b17;
  font-family: var(--display);
  font-size: 30px;
  font-weight: 900;
  line-height: 1.42;
}

.skill-card-main span {
  color: rgba(32, 27, 23, 0.56);
  font-size: 11px;
  font-weight: 820;
  line-height: 1.3;
}

.skill-version-chip {
  right: 16px;
  bottom: 15px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(32, 27, 23, 0.08);
  color: #31577c;
  font-size: 11px;
  font-weight: 950;
}

.skill-training-ring {
  position: relative;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 255, 255, 0.9) 0 36%, transparent 37%),
    conic-gradient(from -30deg, rgba(49, 87, 124, 0.17), rgba(216, 180, 121, 0.2), rgba(97, 134, 166, 0.16), rgba(49, 87, 124, 0.17));
}

.skill-ring-core {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  gap: 5px;
  width: 102px;
  height: 102px;
  border: 1px solid rgba(97, 134, 166, 0.12);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.86);
  text-align: center;
  transform: translate(-50%, -50%);
}

.skill-ring-core span {
  color: rgba(49, 87, 124, 0.74);
  font-size: 10px;
  font-weight: 950;
}

.skill-ring-core strong {
  color: #201b17;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.15;
}

.ring-agent {
  position: absolute;
  display: grid;
  place-items: center;
  min-width: 70px;
  min-height: 34px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #201b17;
  font-size: 11px;
  font-weight: 950;
  box-shadow: 0 12px 24px rgba(49, 87, 124, 0.08);
}

.ring-agent-1 {
  top: 25px;
  left: 50%;
  transform: translateX(-50%);
}

.ring-agent-2 {
  right: 11px;
  bottom: 78px;
}

.ring-agent-3 {
  bottom: 25px;
  left: 17px;
}

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

.skill-replica-footer article {
  display: grid;
  gap: 5px;
  min-height: 66px;
  align-content: center;
  padding: 10px 12px;
  border: 1px solid rgba(139, 113, 72, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.7);
}

.skill-replica-footer strong {
  color: #201b17;
  font-size: 15px;
  font-weight: 950;
  line-height: 1.18;
}

.skill-replica-footer span {
  color: rgba(32, 27, 23, 0.5);
  font-size: 10px;
  font-weight: 820;
}

.skill-compiler-canvas {
  position: relative;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(49, 87, 124, 0.1);
  border-radius: 28px;
  background:
    radial-gradient(circle at 18% 24%, rgba(216, 180, 121, 0.2), transparent 28%),
    radial-gradient(circle at 78% 76%, rgba(49, 87, 124, 0.14), transparent 32%),
    rgba(255, 255, 255, 0.62);
}

.skill-compiler-grid {
  position: absolute;
  inset: 18px;
  border-radius: 22px;
  background:
    linear-gradient(90deg, rgba(49, 87, 124, 0.08) 1px, transparent 1px),
    linear-gradient(180deg, rgba(49, 87, 124, 0.08) 1px, transparent 1px);
  background-size: 42px 42px;
  mask-image: radial-gradient(circle at 50% 48%, #000 0 52%, transparent 82%);
}

.skill-sample-pane,
.skill-compiler-core,
.skill-score-pane,
.skill-chip,
.skill-version-ribbon {
  position: absolute;
}

.skill-sample-pane {
  top: 24px;
  left: 22px;
  display: grid;
  gap: 8px;
  width: 186px;
  min-height: 126px;
  padding: 15px;
  border: 1px solid rgba(139, 113, 72, 0.12);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.84);
}

.skill-sample-pane span,
.skill-score-pane span {
  color: rgba(139, 113, 72, 0.85);
  font-size: 11px;
  font-weight: 950;
}

.skill-sample-pane p {
  color: rgba(32, 27, 23, 0.62);
  font-size: 12px;
  font-weight: 780;
  line-height: 1.42;
}

.skill-sample-pane b {
  width: fit-content;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(255, 246, 232, 0.86);
  color: #8b7148;
  font-size: 11px;
  font-weight: 950;
}

.skill-compiler-core {
  top: 54px;
  left: 48%;
  display: grid;
  gap: 9px;
  width: 258px;
  min-height: 168px;
  padding: 15px 18px;
  border: 1px solid rgba(49, 87, 124, 0.14);
  border-radius: 26px;
  background:
    linear-gradient(145deg, rgba(20, 31, 40, 0.94), rgba(36, 52, 63, 0.9)),
    #17202a;
  color: #ffffff;
  transform: translateX(-50%);
  box-shadow: 0 22px 42px rgba(49, 87, 124, 0.12);
}

.skill-compiler-core small {
  color: #9ac7e7;
  font-size: 11px;
  font-weight: 950;
}

.skill-compiler-core strong {
  color: #ffffff;
  font-family: var(--display);
  font-size: 26px;
  font-weight: 900;
  line-height: 1.36;
}

.compiler-rule-lines {
  display: grid;
  gap: 7px;
}

.compiler-rule-lines span {
  display: block;
  padding: 8px 10px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(248, 246, 240, 0.78);
  font-size: 10px;
  font-weight: 800;
  line-height: 1.25;
}

.skill-score-pane {
  right: 18px;
  bottom: 54px;
  display: grid;
  gap: 8px;
  width: 174px;
  min-height: 142px;
  padding: 14px;
  border: 1px solid rgba(49, 87, 124, 0.12);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.84);
}

.skill-score-pane div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(239, 246, 251, 0.86);
}

.skill-score-pane b {
  color: rgba(32, 27, 23, 0.62);
  font-size: 11px;
  font-weight: 880;
}

.skill-score-pane strong {
  color: #31577c;
  font-size: 21px;
  font-weight: 950;
  line-height: 1.28;
}

.skill-score-pane small {
  color: rgba(32, 27, 23, 0.5);
  font-size: 10px;
  font-weight: 780;
  line-height: 1.25;
}

.skill-chip {
  display: grid;
  place-items: center;
  min-width: 78px;
  min-height: 34px;
  padding: 8px 11px;
  border: 1px solid rgba(139, 113, 72, 0.12);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #201b17;
  font-size: 12px;
  font-weight: 950;
  box-shadow: 0 12px 24px rgba(49, 87, 124, 0.07);
}

.skill-chip::before {
  display: inline-block;
  width: 7px;
  height: 7px;
  margin-right: 7px;
  border-radius: 50%;
  background: #d8b479;
  content: "";
}

.skill-chip-1 {
  top: 188px;
  left: 42px;
}

.skill-chip-2 {
  top: 246px;
  left: 112px;
}

.skill-chip-3 {
  right: 78px;
  top: 38px;
}

.skill-chip-4 {
  right: 218px;
  bottom: 34px;
}

.skill-chip-5 {
  left: 222px;
  bottom: 27px;
}

.skill-version-ribbon {
  left: 24px;
  bottom: 34px;
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(32, 27, 23, 0.08);
  color: #31577c;
  font-size: 11px;
  font-weight: 950;
}

.skill-compiler-footer {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 9px;
}

.skill-compiler-footer b {
  display: grid;
  place-items: center;
  min-height: 44px;
  border: 1px solid rgba(49, 87, 124, 0.1);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: #201b17;
  font-size: 12px;
  font-weight: 950;
}

.edu-skill-replica .skill-compiler-canvas {
  position: relative;
  display: block;
  overflow: hidden;
}

.edu-skill-replica .skill-compiler-grid,
.edu-skill-replica .skill-sample-pane,
.edu-skill-replica .skill-compiler-core,
.edu-skill-replica .skill-score-pane,
.edu-skill-replica .skill-chip,
.edu-skill-replica .skill-version-ribbon {
  position: absolute;
}

.edu-skill-replica .skill-compiler-grid {
  inset: 18px;
}

.edu-skill-replica .skill-sample-pane {
  top: 22px;
  left: 22px;
  display: grid;
  width: 168px;
}

.edu-skill-replica .skill-compiler-core {
  top: 52px;
  left: 50%;
  display: grid;
  width: 238px;
  min-height: 168px;
  transform: translateX(-50%);
}

.edu-skill-replica .skill-score-pane {
  top: 112px;
  right: 18px;
  bottom: auto;
  display: grid;
  width: 166px;
}

.edu-skill-replica .compiler-rule-lines {
  display: grid;
  gap: 7px;
}

.edu-skill-replica .compiler-rule-lines span {
  display: block;
}

.edu-skill-replica .skill-chip {
  display: grid;
}

.edu-skill-replica .skill-chip-1 {
  top: 218px;
  left: 24px;
}

.edu-skill-replica .skill-chip-2 {
  top: 218px;
  left: 112px;
}

.edu-skill-replica .skill-chip-3 {
  top: 34px;
  right: 92px;
}

.edu-skill-replica .skill-chip-4 {
  right: 120px;
  bottom: 24px;
}

.edu-skill-replica .skill-chip-5 {
  right: 22px;
  bottom: 24px;
  left: auto;
}

.edu-skill-replica .skill-version-ribbon {
  bottom: 24px;
  left: 22px;
}

@media (max-width: 1180px) {
  .particle-growth-lab .case-tab-stage,
  .particle-growth-lab .case-tab-stage.reverse,
  .robot-command-console .case-tab-stage,
  .robot-command-console .case-tab-stage.reverse,
  .beauty-agent-room .case-tab-stage,
  .beauty-agent-room .case-tab-stage.reverse,
  .vision-care-record .case-tab-stage,
  .vision-care-record .case-tab-stage.reverse,
  .edu-skill-console .case-tab-stage,
  .edu-skill-console .case-tab-stage.reverse {
    grid-template-columns: 1fr;
    height: auto;
    min-height: auto;
  }

  .robot-command-console .case-media-panel,
  .vision-care-record .case-media-panel {
    order: initial;
  }
}

@media (max-width: 900px) {
  .particle-growth-lab,
  .robot-command-console,
  .beauty-agent-room,
  .vision-care-record,
  .edu-skill-console {
    padding: 18px;
    border-radius: 26px;
  }

  .case-tabs-block .case-tab-list {
    flex-wrap: nowrap;
    overflow-x: auto;
    margin-bottom: 18px;
    border-radius: 999px;
  }

  .particle-growth-lab .case-image-slot,
  .robot-command-console .case-image-slot,
  .beauty-agent-room .case-image-slot,
  .vision-care-record .case-image-slot,
  .edu-skill-console .case-image-slot {
    min-height: 380px;
  }
}

@media (max-width: 560px) {
  .particle-growth-lab,
  .robot-command-console,
  .beauty-agent-room,
  .vision-care-record,
  .edu-skill-console {
    padding: 12px;
  }

  .case-tabs-block .case-tab-button {
    min-height: 42px;
    padding: 0 15px;
    font-size: 13px;
  }

  .particle-growth-lab .case-image-slot,
  .robot-command-console .case-image-slot,
  .beauty-agent-room .case-image-slot,
  .vision-care-record .case-image-slot,
  .edu-skill-console .case-image-slot {
    min-height: 310px;
  }

  .robot-command-console .case-image-slot::after,
  .beauty-agent-room .case-image-slot::after,
  .vision-care-record .case-image-slot::after,
  .edu-skill-console .case-image-slot::after {
    opacity: 0.58;
  }
}

@media (max-width: 1080px) {
  .skill-benchmark-stage {
    grid-template-columns: 1fr;
    aspect-ratio: auto;
  }

  .architecture-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .product-stage,
  .product-fran .product-stage,
  .product-ops .product-stage,
  .product-train .product-stage {
    grid-template-columns: 1fr;
  }

  .product-ops .product-task-panel,
  .product-ops .product-visual-panel {
    order: initial;
  }

  .screen-body {
    grid-template-columns: 1fr;
  }

  .screen-workspace {
    grid-template-columns: 150px minmax(0, 1fr);
  }

  .shot-screen {
    min-height: 620px;
  }
}

@media (max-width: 820px) {
  .architecture-flow {
    grid-template-columns: 1fr;
  }

  .flow-card,
  .benchmark-card,
  .product-system-grid .method-card {
    min-height: auto;
  }

  .flow-card strong {
    margin-top: 28px;
  }

  .product-stage {
    height: auto;
    min-height: auto;
    padding: 18px;
    border-radius: 24px;
  }

  .product-task-panel {
    min-height: auto;
    padding: 22px;
  }

  .shot-screen {
    min-height: auto;
  }

  .screen-frame {
    min-height: auto;
  }

  .screen-workspace {
    grid-template-columns: 1fr;
  }

  .screen-sidebar {
    display: flex;
    min-height: auto;
    overflow-x: auto;
    scrollbar-width: none;
  }

  .screen-sidebar::-webkit-scrollbar {
    display: none;
  }

  .screen-sidebar span {
    flex: 0 0 auto;
    white-space: nowrap;
  }

  .screen-metrics,
  .shot-switcher {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .screen-graphic {
    min-height: 210px;
  }
}

@media (max-width: 560px) {
  body.products-page .product-hero {
    padding-bottom: 54px;
  }

  .product-tab-list {
    width: 100%;
  }

  .product-stage {
    padding: 14px;
  }

  .product-task-panel {
    padding: 18px;
  }

  .product-task-panel h3 {
    font-size: 30px;
  }

  .screen-top,
  .screen-title-area,
  .screen-workspace,
  .screen-metrics,
  .screen-body {
    padding-right: 16px;
    padding-left: 16px;
  }

  .shot-switcher {
    grid-template-columns: 1fr;
  }

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

  .screen-metric {
    min-height: 62px;
    padding: 10px 8px;
  }

  .screen-metric strong {
    font-size: 18px;
  }

  .screen-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .screen-list li {
    min-height: 52px;
    padding: 10px;
    font-size: 12px;
  }

  .screen-title-area {
    align-items: start;
    flex-direction: column;
  }

  .screen-toolbar {
    display: none;
  }

  .screen-title-area h3 {
    font-size: 26px;
  }

  .screen-graphic {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    min-height: 180px;
    padding: 14px;
  }
}

/* Services page rebuilt around consulting, Agent + Skill, AI-APP workflows, and cooperation scope. */
body.service-page .main {
  background:
    linear-gradient(180deg, #fbfaf7 0%, #ffffff 18%, #fbfaf7 100%);
}

.service-hero {
  padding: 104px 0 90px;
}

.service-hero-copy {
  max-width: 1060px;
  margin: 0 auto;
  text-align: center;
}

.service-hero-copy .display-title {
  max-width: 1040px;
  margin: 0 auto;
  font-size: clamp(54px, 7.6vw, 116px);
  line-height: 0.98;
}

.service-hero-copy .hero-lede {
  max-width: 1060px;
}

.service-anchor-row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  margin-top: 24px;
}

.service-anchor-row a {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 16px;
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: var(--muted);
  font-size: 14px;
  font-weight: 750;
}

.service-hero-stage {
  position: relative;
  display: grid;
  grid-template-columns: minmax(260px, 0.9fr) minmax(0, 1.2fr) minmax(220px, 0.72fr);
  gap: 26px;
  align-items: stretch;
  min-height: 620px;
  margin: 78px 0 0;
  padding: 34px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 34px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(135deg, #f4f0ea 0%, #ffffff 46%, #e8f1ff 100%);
  background-size: 72px 72px, 72px 72px, auto;
  box-shadow: var(--shadow);
}

.service-hero-stage::before {
  position: absolute;
  inset: 34px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 26px;
  content: "";
  pointer-events: none;
}

.service-stage-top {
  position: absolute;
  top: 28px;
  left: 34px;
  right: 34px;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 14px;
}

.service-stage-top span {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  padding: 0 13px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.7);
  color: var(--muted);
  font-size: 13px;
  font-weight: 850;
}

.service-command-card,
.service-result-stack,
.service-orbit-map {
  position: relative;
  z-index: 1;
  align-self: end;
}

.service-command-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 430px;
  padding: 30px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: #111111;
  color: #f8f6f0;
}

.service-command-card small,
.service-app-copy span,
.service-skill-flow article span,
.service-timeline article > span {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.service-command-card small {
  color: rgba(248, 246, 240, 0.62);
}

.service-command-card strong {
  max-width: 300px;
  font-family: var(--display);
  font-size: clamp(30px, 3vw, 44px);
  font-weight: 650;
  line-height: 1.06;
}

.service-orbit-map {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-content: center;
  min-height: 430px;
  padding: 34px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 28px;
  background:
    linear-gradient(90deg, transparent 0 49%, rgba(20, 20, 20, 0.1) 49% 51%, transparent 51%),
    linear-gradient(0deg, transparent 0 49%, rgba(20, 20, 20, 0.1) 49% 51%, transparent 51%),
    rgba(255, 255, 255, 0.66);
}

.service-orbit-map i {
  display: block;
  min-height: 146px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background:
    linear-gradient(rgba(255, 255, 255, 0.9) 0 0) 18px 20px / 54% 12px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.74) 0 0) 18px 48px / 72% 9px no-repeat,
    linear-gradient(135deg, var(--blue-soft), var(--paper) 54%, var(--green-soft));
  box-shadow: 0 14px 38px rgba(33, 29, 23, 0.08);
}

.service-orbit-map i:nth-child(2) {
  background:
    linear-gradient(rgba(255, 255, 255, 0.9) 0 0) 18px 20px / 54% 12px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.74) 0 0) 18px 48px / 72% 9px no-repeat,
    linear-gradient(135deg, var(--green-soft), var(--paper) 54%, var(--orange-soft));
}

.service-orbit-map i:nth-child(3) {
  background:
    linear-gradient(rgba(255, 255, 255, 0.9) 0 0) 18px 20px / 54% 12px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.74) 0 0) 18px 48px / 72% 9px no-repeat,
    linear-gradient(135deg, var(--orange-soft), var(--paper) 54%, var(--purple-soft));
}

.service-orbit-map i:nth-child(4) {
  background:
    linear-gradient(rgba(255, 255, 255, 0.9) 0 0) 18px 20px / 54% 12px no-repeat,
    linear-gradient(rgba(255, 255, 255, 0.74) 0 0) 18px 48px / 72% 9px no-repeat,
    linear-gradient(135deg, var(--purple-soft), var(--paper) 54%, var(--blue-soft));
}

.service-result-stack {
  display: grid;
  gap: 14px;
  align-content: end;
  min-height: 430px;
}

.service-result-stack span {
  display: grid;
  align-items: center;
  min-height: 124px;
  padding: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--ink);
  font-family: var(--display);
  font-size: 28px;
  font-weight: 650;
  box-shadow: 0 14px 40px rgba(33, 29, 23, 0.08);
}

.service-section-heading {
  text-align: center;
}

.service-principle-rows {
  margin-top: 76px;
  border-top: 1px solid var(--line);
}

.service-principle-row {
  display: grid;
  grid-template-columns: 80px minmax(0, 1.08fr) minmax(260px, 0.72fr);
  gap: 46px;
  align-items: start;
  padding: 54px 0;
  border-bottom: 1px solid var(--line);
}

.service-row-index {
  color: var(--muted-2);
  font-family: var(--display);
  font-size: 34px;
  line-height: 1;
}

.service-principle-row h3,
.service-timeline h3,
.service-app-copy h3 {
  margin: 0;
  font-family: var(--display);
  font-weight: 650;
  line-height: 1.08;
}

.service-principle-row h3 {
  font-size: clamp(30px, 3.1vw, 44px);
}

.service-principle-row p {
  max-width: 650px;
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 20px;
  line-height: 1.5;
}

.service-principle-row ul {
  display: grid;
  gap: 12px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.service-principle-row li {
  min-height: 48px;
  padding: 12px 15px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--ink-soft);
  font-weight: 800;
}

.service-split-heading {
  display: grid;
  grid-template-columns: minmax(0, 0.98fr) minmax(320px, 0.72fr);
  gap: 78px;
  align-items: end;
}

.service-split-heading p,
.service-scope-copy p {
  margin: 0;
  color: var(--muted);
  font-size: 20px;
  line-height: 1.55;
}

.service-consulting-stage {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 68px;
  padding: 28px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 32px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(135deg, #f6f2ec, #ffffff 50%, #eff8f2);
  background-size: 70px 70px, 70px 70px, auto;
  box-shadow: var(--shadow);
}

.consulting-node {
  display: grid;
  align-content: space-between;
  min-height: 360px;
  padding: 26px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.76);
}

.consulting-node.primary {
  background: #111111;
  color: #f8f6f0;
}

.consulting-node small {
  color: var(--muted-2);
  font-weight: 900;
}

.consulting-node.primary small,
.consulting-node.primary span {
  color: rgba(248, 246, 240, 0.65);
}

.consulting-node strong {
  margin-top: 118px;
  font-family: var(--display);
  font-size: clamp(28px, 3vw, 42px);
  line-height: 1.05;
}

.consulting-node span {
  color: var(--muted);
  font-weight: 750;
}

.service-skill-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 16px;
  margin-top: 70px;
}

.service-skill-flow article {
  display: flex;
  flex-direction: column;
  min-height: 330px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 18px 54px rgba(33, 29, 23, 0.08);
}

.service-skill-flow article:nth-child(2) {
  background: linear-gradient(135deg, var(--green-soft), rgba(255, 255, 255, 0.82));
}

.service-skill-flow article:nth-child(3) {
  background: linear-gradient(135deg, var(--blue-soft), rgba(255, 255, 255, 0.82));
}

.service-skill-flow article strong {
  margin-top: auto;
  font-family: var(--display);
  font-size: 34px;
  line-height: 1.05;
}

.service-skill-flow article p {
  margin: 18px 0 0;
  color: var(--muted);
}

.service-app-tabs {
  margin-top: 64px;
}

.service-tab-list {
  margin-bottom: 28px;
}

.service-tab-list .tab-button:nth-child(1) .tab-dot {
  background: var(--blue);
}

.service-tab-list .tab-button:nth-child(2) .tab-dot {
  background: var(--green);
}

.service-tab-list .tab-button:nth-child(3) .tab-dot {
  background: var(--orange);
}

.service-tab-list .tab-button:nth-child(4) .tab-dot {
  background: var(--purple);
}

.service-app-stage {
  display: grid;
  grid-template-columns: minmax(320px, 0.74fr) minmax(0, 1.26fr);
  gap: 28px;
  min-height: 650px;
  padding: 30px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 34px;
  box-shadow: var(--shadow);
}

.service-app-growth {
  background: linear-gradient(135deg, #dfe8ff 0%, #ffffff 52%, #e5f7ee 100%);
}

.service-app-fran {
  background: linear-gradient(135deg, #dcf8e8 0%, #ffffff 52%, #fff0d9 100%);
}

.service-app-ops {
  background: linear-gradient(135deg, #ffe5c8 0%, #ffffff 52%, #f1e7ff 100%);
}

.service-app-train {
  background: linear-gradient(135deg, #eadfff 0%, #ffffff 52%, #e1ecff 100%);
}

.service-app-copy {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 590px;
  padding: 34px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.76);
}

.service-app-copy h3 {
  margin-top: auto;
  font-size: clamp(34px, 4.5vw, 64px);
}

.service-app-copy p {
  margin: 26px 0 0;
  color: var(--muted);
  font-size: 19px;
  line-height: 1.5;
}

.service-workflow-board {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px;
  align-content: center;
  min-height: 590px;
  padding: 34px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.045) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px),
    rgba(255, 255, 255, 0.56);
  background-size: 58px 58px, 58px 58px, auto;
}

.service-workflow-board strong {
  display: grid;
  place-items: center;
  min-height: 210px;
  padding: 18px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(26px, 3vw, 40px);
  font-weight: 650;
  text-align: center;
  box-shadow: 0 16px 46px rgba(33, 29, 23, 0.08);
}

.service-timeline {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 70px;
}

.service-timeline article {
  display: flex;
  flex-direction: column;
  min-height: 420px;
  padding: 30px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 16px 48px rgba(33, 29, 23, 0.07);
}

.service-timeline h3 {
  margin-top: 72px;
  font-size: 34px;
}

.service-timeline strong {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 36px;
  margin-top: 22px;
  padding: 0 13px;
  border-radius: 999px;
  background: #111111;
  color: #ffffff;
  font-size: 14px;
}

.service-timeline p {
  margin: auto 0 0;
  color: var(--muted);
  font-size: 18px;
}

.service-scope-panel {
  display: grid;
  grid-template-columns: minmax(320px, 0.76fr) minmax(0, 1.24fr);
  gap: 46px;
  padding: 56px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 32px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(135deg, #f7f3ed, #ffffff 50%, #e9f1ff);
  background-size: 72px 72px, 72px 72px, auto;
  box-shadow: var(--shadow);
}

.service-scope-copy {
  align-self: center;
}

.service-scope-title {
  margin: 0;
  color: var(--ink);
  font-family: var(--display);
  font-size: 28px;
  font-weight: 650;
  line-height: 1.08;
}

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

.service-scope-grid div {
  min-height: 160px;
  padding: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
}

.service-scope-grid strong {
  display: block;
  font-family: var(--display);
  font-size: 27px;
  line-height: 1.08;
}

.service-scope-grid span {
  display: block;
  margin-top: 18px;
  color: var(--muted);
}

@media (max-width: 1180px) {
  .service-hero-stage,
  .service-app-stage,
  .service-scope-panel,
  .service-split-heading {
    grid-template-columns: 1fr;
  }

  .service-command-card,
  .service-orbit-map,
  .service-result-stack,
  .service-app-copy,
  .service-workflow-board {
    min-height: auto;
  }

  .service-command-card {
    min-height: 320px;
  }

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

  .service-result-stack span {
    min-height: 112px;
  }

  .service-principle-row {
    grid-template-columns: 72px minmax(0, 1fr);
  }

  .service-principle-row ul {
    grid-column: 2;
  }

  .service-consulting-stage,
  .service-skill-flow,
  .service-timeline {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-timeline article:last-child {
    grid-column: 1 / -1;
  }
}

@media (max-width: 820px) {
  .service-hero {
    padding: 76px 0 64px;
  }

  .service-hero-copy .display-title {
    font-size: clamp(46px, 12vw, 70px);
  }

  .service-hero-stage,
  .service-app-stage,
  .service-scope-panel,
  .service-consulting-stage {
    padding: 18px;
    border-radius: 26px;
  }

  .service-stage-top {
    position: static;
    grid-column: 1;
    flex-wrap: wrap;
    margin-bottom: 10px;
  }

  .service-command-card,
  .service-orbit-map,
  .service-app-copy,
  .service-workflow-board {
    padding: 24px;
    border-radius: 20px;
  }

  .service-orbit-map,
  .service-workflow-board,
  .service-scope-grid,
  .service-consulting-stage,
  .service-skill-flow,
  .service-timeline {
    grid-template-columns: 1fr;
  }

  .service-orbit-map i,
  .service-workflow-board strong {
    min-height: 116px;
  }

  .service-result-stack {
    grid-template-columns: 1fr;
  }

  .service-principle-row {
    grid-template-columns: 1fr;
    gap: 22px;
    padding: 42px 0;
  }

  .service-principle-row ul {
    grid-column: 1;
  }

  .service-principle-row p,
  .service-split-heading p,
  .service-scope-copy p {
    font-size: 18px;
  }

  .consulting-node {
    min-height: 240px;
  }

  .consulting-node strong {
    margin-top: 54px;
  }

  .service-timeline article,
  .service-timeline article:last-child {
    grid-column: auto;
    min-height: 320px;
  }

  .service-timeline h3 {
    margin-top: 44px;
  }
}

@media (max-width: 560px) {
  .service-hero-stage,
  .service-app-stage,
  .service-scope-panel,
  .service-consulting-stage {
    margin-top: 46px;
    padding: 12px;
  }

  .service-anchor-row {
    justify-content: flex-start;
  }

  .service-command-card strong {
    font-size: 30px;
  }

  .service-result-stack span,
  .service-scope-grid strong {
    font-size: 24px;
  }

  .service-app-copy h3 {
    font-size: 34px;
  }

  .service-workflow-board strong {
    font-size: 26px;
  }

  .service-scope-grid div {
    min-height: auto;
  }
}

/* Services page polish pass: align with case page scale and clarify service structure. */
.service-page .display-title.page-title {
  max-width: 1120px;
  margin-right: auto;
  margin-left: auto;
  font-size: clamp(56px, 7.2vw, 104px);
  line-height: 0.96;
}

.service-page .section-title {
  font-size: clamp(42px, 4.8vw, 70px);
}

.service-hero {
  padding: 92px 0 72px;
}

.service-hero-copy {
  max-width: 1120px;
}

.service-hero-copy .display-title {
  max-width: 1120px;
  font-size: clamp(56px, 7.2vw, 104px);
  line-height: 0.96;
}

.service-hero-copy .title-line {
  display: block;
}

.service-hero-stage {
  min-height: 520px;
  margin-top: 64px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, #f4f0ea 0%, #ffffff 52%, #edf4ff 100%);
}

.service-command-card,
.service-orbit-map,
.service-result-stack {
  min-height: 340px;
}

.service-three-map {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  margin-top: 62px;
}

.service-map-card {
  display: grid;
  grid-template-rows: auto 78px 1fr;
  min-height: 250px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 54px rgba(33, 29, 23, 0.07);
}

.service-map-card:nth-child(1) {
  box-shadow: inset 0 5px 0 var(--blue), 0 18px 54px rgba(33, 29, 23, 0.07);
}

.service-map-card:nth-child(2) {
  box-shadow: inset 0 5px 0 var(--green), 0 18px 54px rgba(33, 29, 23, 0.07);
}

.service-map-card:nth-child(3) {
  box-shadow: inset 0 5px 0 var(--orange), 0 18px 54px rgba(33, 29, 23, 0.07);
}

.service-map-card span,
.service-detail-index {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 0;
  text-transform: uppercase;
}

.service-map-card strong {
  align-self: end;
  font-family: var(--display);
  font-size: clamp(30px, 3vw, 42px);
  line-height: 1.05;
}

.service-map-card p {
  margin: 18px 0 0;
  color: var(--muted);
  font-size: 17px;
}

.service-band {
  border-top: 1px solid var(--line);
}

.service-band-paper {
  background: #ffffff;
}

.service-band-warm {
  background: linear-gradient(180deg, #f7f4ee, #ffffff);
}

.service-detail {
  display: grid;
  grid-template-columns: minmax(320px, 0.72fr) minmax(0, 1.28fr);
  gap: 46px;
  align-items: stretch;
}

.service-detail-copy {
  display: grid;
  align-content: center;
  min-height: 520px;
}

.service-detail-copy p {
  margin: 24px 0 0;
  color: var(--muted);
  font-size: 20px;
  line-height: 1.55;
}

.service-detail-list {
  display: grid;
  gap: 12px;
  margin: 34px 0 0;
  padding: 0;
  list-style: none;
}

.service-detail-list li {
  padding: 14px 16px;
  border: 1px solid var(--line);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.74);
  color: var(--ink-soft);
  font-weight: 820;
}

.service-image-slot,
.service-app-visual {
  position: relative;
  min-width: 0;
  margin: 0;
  padding: 28px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 30px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, #f7f3ed, #ffffff 54%, #eef5ff);
  background-size: 64px 64px, 64px 64px, auto;
  box-shadow: var(--shadow);
}

.service-image-slot figcaption,
.service-app-visual figcaption {
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  margin-bottom: 20px;
  padding: 0 13px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
  font-size: 13px;
  font-weight: 800;
}

.service-consulting-stage {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  min-height: 520px;
  margin-top: 0;
  box-shadow: var(--shadow);
}

.service-consulting-stage figcaption {
  grid-column: 1 / -1;
}

.consulting-node {
  min-height: 190px;
}

.consulting-node strong {
  margin-top: 48px;
}

.service-detail-skill {
  grid-template-columns: minmax(280px, 0.58fr) minmax(0, 1.42fr);
}

.service-skill-panel {
  min-height: 520px;
}

.service-skill-panel .service-skill-flow {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin-top: 0;
}

.service-skill-panel .service-skill-flow article {
  display: grid;
  grid-template-rows: 28px 84px 1fr;
  min-height: 360px;
  padding: 24px;
  box-shadow: none;
}

.service-skill-panel .service-skill-flow article strong {
  align-self: end;
  margin-top: 0;
  font-size: 31px;
}

.service-skill-panel .service-skill-flow article p {
  align-self: start;
  margin-top: 18px;
}

.service-app-stage {
  grid-template-columns: minmax(0, 1.14fr) minmax(320px, 0.86fr);
  gap: 26px;
  min-height: 620px;
  padding: 26px;
}

.service-app-visual {
  min-height: 568px;
  box-shadow: none;
}

.service-workflow-board {
  min-height: 470px;
  padding: 26px;
}

.service-workflow-board strong {
  min-height: 180px;
}

.service-app-copy {
  min-height: 568px;
  justify-content: start;
}

.service-app-copy h3 {
  margin-top: 72px;
  font-size: clamp(38px, 4.2vw, 58px);
}

.service-cooperation {
  background: linear-gradient(180deg, #fbfaf7, #ffffff 34%, #f7f4ee);
  border-top: 1px solid var(--line);
}

.service-cooperation-title {
  white-space: normal;
}

.service-cooperation-panel {
  display: grid;
  gap: 24px;
  margin-top: 70px;
}

.service-cooperation-panel .service-timeline {
  margin-top: 0;
}

.service-timeline article {
  min-height: 360px;
  background: rgba(255, 255, 255, 0.82);
}

.service-timeline h3 {
  margin-top: 48px;
}

.service-scope-panel {
  grid-template-columns: minmax(280px, 0.62fr) minmax(0, 1.38fr);
  gap: 34px;
  padding: 32px;
  border-radius: 28px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    #ffffff;
  background-size: 64px 64px, 64px 64px, auto;
}

.service-scope-copy {
  display: grid;
  align-content: center;
}

.service-scope-grid div {
  min-height: 136px;
}

.service-final {
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(244, 240, 234, 0.82));
  color: var(--ink);
}

.service-final .section-title {
  color: var(--ink);
}

.service-final .section-lede {
  max-width: 1040px;
  color: var(--muted);
  text-wrap: auto;
}

.service-final-lede span {
  display: block;
}

.service-final-lede span:first-child {
  white-space: nowrap;
}

@media (max-width: 1180px) {
  .service-detail,
  .service-detail-skill,
  .service-app-stage,
  .service-scope-panel {
    grid-template-columns: 1fr;
  }

  .service-detail-copy,
  .service-app-copy,
  .service-app-visual {
    min-height: auto;
  }

  .service-three-map,
  .service-timeline {
    grid-template-columns: 1fr;
  }

  .service-timeline article:last-child {
    grid-column: auto;
  }

  .service-skill-panel .service-skill-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .service-page .display-title.page-title,
  .service-hero-copy .display-title {
    font-size: clamp(44px, 11vw, 62px);
    line-height: 1.02;
  }

  .service-page .section-title {
    font-size: clamp(34px, 8.2vw, 46px);
  }

  .service-hero {
    padding-top: 76px;
  }

  .service-map-card {
    min-height: 190px;
    grid-template-rows: auto auto 1fr;
  }

  .service-detail {
    gap: 28px;
  }

  .service-image-slot,
  .service-app-visual,
  .service-scope-panel {
    padding: 18px;
    border-radius: 24px;
  }

  .service-skill-panel .service-skill-flow,
  .service-scope-grid,
  .service-consulting-stage {
    grid-template-columns: 1fr;
  }

  .service-skill-panel .service-skill-flow article {
    min-height: 260px;
    grid-template-rows: auto auto 1fr;
  }

  .service-app-copy h3 {
    margin-top: 42px;
  }

  .service-workflow-board {
    min-height: auto;
  }
}

@media (max-width: 560px) {
  .service-hero-stage {
    margin-top: 48px;
  }

  .service-map-card {
    padding: 22px;
  }

  .service-detail-copy p,
  .service-app-copy p,
  .service-scope-copy p {
    font-size: 17px;
  }

  .service-workflow-board {
    grid-template-columns: 1fr;
  }

  .service-workflow-board strong {
    min-height: 96px;
  }
}

/* Services page refinement: larger image surfaces, tighter module copy, and consistent page-title rhythm. */
.service-page .display-title.page-title,
.service-hero-copy .display-title {
  line-height: 0.96;
}

.service-overview-layout {
  display: grid;
  gap: 42px;
  align-items: stretch;
}

.service-cooperation-layout {
  display: grid;
  grid-template-columns: minmax(300px, 0.62fr) minmax(0, 1.38fr);
  gap: 42px;
  align-items: stretch;
}

.service-overview-copy {
  display: grid;
  align-content: center;
  max-width: 1120px;
  min-height: auto;
  margin: 0 auto;
  text-align: center;
}

.service-overview-copy .section-title,
.service-overview-copy .section-lede {
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.service-content-hero {
  max-width: 1180px;
  margin: 0 auto;
  text-align: center;
}

.service-content-hero .section-kicker {
  margin-bottom: 24px;
}

.service-content-title {
  max-width: 1040px;
  margin: 0 auto;
  font-size: clamp(42px, 4.8vw, 70px);
  line-height: 1.14;
  letter-spacing: 0;
}

.service-content-hero .section-lede {
  max-width: 880px;
  margin-top: 28px;
}

.service-content-tags {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px;
  margin-top: 30px;
}

.service-content-tags a {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 42px;
  padding: 0 18px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink-soft);
  font-size: 14px;
  font-weight: 850;
  text-decoration: none;
  box-shadow: 0 12px 30px rgba(33, 29, 23, 0.06);
}

.service-content-tags a:nth-child(1) {
  border-color: rgba(201, 121, 16, 0.18);
  background: rgba(255, 241, 216, 0.86);
  color: #8a5a16;
}

.service-content-tags a:nth-child(2) {
  border-color: rgba(47, 102, 234, 0.16);
  background: rgba(232, 242, 255, 0.88);
  color: #315d9a;
}

.service-content-tags a:nth-child(3) {
  border-color: rgba(103, 142, 97, 0.18);
  background: rgba(232, 246, 229, 0.88);
  color: #3d6437;
}

.service-overview-visual {
  display: grid;
  grid-template-rows: auto 1fr;
  width: min(100%, 1200px);
  min-height: 530px;
  margin: 0 auto;
  padding: 32px 40px 40px;
}

.service-overview-visual .service-three-map {
  align-content: stretch;
  margin-top: 0;
}

.service-overview-visual .service-map-card {
  grid-template-rows: auto 112px 1fr;
  min-height: 360px;
  padding: 30px;
}

.service-map-card {
  min-height: 230px;
}

.service-map-card strong {
  font-size: clamp(26px, 2.5vw, 36px);
}

.service-map-card p,
.service-detail-copy p,
.service-app-copy p,
.service-scope-copy p,
.service-timeline p {
  font-size: 16px;
  line-height: 1.58;
}

.service-detail-copy p {
  max-width: 580px;
}

.service-detail-list li {
  font-size: 15px;
}

.service-image-slot figcaption,
.service-app-visual figcaption,
.service-scope-visual figcaption {
  min-height: 30px;
  margin-bottom: 16px;
  padding: 0 11px;
  font-size: 12px;
}

.service-consulting-stage {
  min-height: 560px;
}

.consulting-node {
  min-height: 176px;
  padding: 22px;
}

.consulting-node strong {
  margin-top: 34px;
  font-size: clamp(24px, 2.4vw, 34px);
}

.consulting-node span {
  font-size: 14px;
  line-height: 1.42;
}

.service-detail-consulting .service-consulting-title {
  max-width: 610px;
  font-size: clamp(32px, 2.8vw, 46px);
  line-height: 1.08;
}

.service-consulting-copy {
  align-content: center;
}

.consulting-left-map {
  max-width: 610px;
  margin-top: 24px;
}

.consulting-left-map > p {
  margin: 0;
  max-width: 610px;
}

.consulting-left-flow {
  position: relative;
  display: grid;
  gap: 12px;
  margin-top: 28px;
  padding-left: 0;
}

.consulting-left-flow article {
  position: relative;
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 82px;
  padding: 14px 16px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 38px rgba(33, 29, 23, 0.05);
}

.consulting-left-flow i {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(201, 121, 16, 0.2);
  border-radius: 999px;
  background: #fff7ea;
  color: #9b681d;
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}

.consulting-left-flow strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.25;
}

.consulting-left-flow span {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.42;
}

.service-detail-consulting .service-consulting-stage {
  grid-template-rows: auto minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
  min-height: 620px;
  padding: 28px;
}

.service-detail-consulting .service-consulting-stage figcaption {
  justify-self: start;
  min-height: 34px;
  margin: 0 0 4px;
  padding: 0 14px;
  border-color: rgba(201, 121, 16, 0.18);
  background: rgba(255, 241, 216, 0.88);
  color: #8a5a16;
  font-size: 13px;
}

.service-detail-consulting .consulting-node {
  display: grid;
  grid-template-rows: auto minmax(118px, 1fr);
  gap: 16px;
  align-content: stretch;
  min-height: 214px;
  padding: 22px;
}

.consulting-node-head {
  display: grid;
  gap: 8px;
  align-content: start;
}

.service-detail-consulting .consulting-node strong {
  margin-top: 0;
  font-size: clamp(22px, 1.75vw, 30px);
  line-height: 1.08;
}

.service-detail-consulting .consulting-node small {
  width: max-content;
  min-height: 28px;
  padding: 5px 12px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
  line-height: 1.2;
}

.service-detail-consulting .consulting-node.primary small {
  border-color: rgba(248, 246, 240, 0.16);
  background: rgba(255, 255, 255, 0.08);
  color: rgba(248, 246, 240, 0.72);
}

.consulting-node-visual {
  position: relative;
  align-self: end;
  min-height: 122px;
  padding: 12px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.78), rgba(244, 248, 255, 0.56));
}

.consulting-node.primary .consulting-node-visual {
  border-color: rgba(248, 246, 240, 0.1);
  background: rgba(255, 255, 255, 0.08);
}

.consulting-node-visual span,
.consulting-node-visual b {
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  min-height: 34px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.2;
  white-space: nowrap;
}

.diagnosis-goal-visual {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.diagnosis-goal-visual::before {
  position: absolute;
  inset: 50%;
  width: 54px;
  height: 54px;
  border: 1px solid rgba(248, 246, 240, 0.18);
  border-radius: 999px;
  background: rgba(248, 246, 240, 0.08);
  content: "";
  transform: translate(-50%, -50%);
}

.diagnosis-goal-visual span {
  border: 1px solid rgba(248, 246, 240, 0.12);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(248, 246, 240, 0.86);
}

.diagnosis-flow-visual {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  align-items: center;
}

.diagnosis-flow-visual::before {
  position: absolute;
  top: 50%;
  right: 18px;
  left: 18px;
  height: 1px;
  background: rgba(47, 102, 234, 0.16);
  content: "";
}

.diagnosis-flow-visual span {
  border: 1px solid rgba(47, 102, 234, 0.12);
  background: #f3f8ff;
  color: #315d9a;
}

.diagnosis-gap-visual {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 54px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.diagnosis-gap-visual span {
  min-height: 52px;
  border: 1px solid rgba(201, 121, 16, 0.12);
  border-radius: 16px;
  background: #fff8ed;
  color: #8a5a16;
}

.diagnosis-gap-visual b {
  width: 54px;
  height: 54px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: #ffffff;
  color: var(--ink);
}

.diagnosis-launch-visual {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 62px;
  gap: 8px;
  align-items: center;
}

.diagnosis-launch-visual span {
  min-height: 52px;
  border: 1px solid rgba(103, 142, 97, 0.13);
  border-radius: 16px;
  background: #f0f9ee;
  color: #3d6437;
}

.diagnosis-launch-visual b {
  width: 62px;
  height: 62px;
  border: 1px solid rgba(47, 102, 234, 0.13);
  border-radius: 18px;
  background: #f3f8ff;
  color: #315d9a;
}

.service-detail-consulting .diagnosis-goal-visual {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(34px, 1fr));
  gap: 8px;
  padding: 14px;
}

.service-detail-consulting .diagnosis-goal-visual::before {
  width: 68px;
  height: 68px;
  border-color: rgba(248, 246, 240, 0.22);
  background: rgba(248, 246, 240, 0.1);
}

.service-detail-consulting .diagnosis-goal-visual b {
  position: absolute;
  z-index: 2;
  top: 50%;
  left: 50%;
  min-height: 42px;
  padding: 0 13px;
  border: 1px solid rgba(248, 246, 240, 0.2);
  border-radius: 999px;
  background: #111111;
  color: #f8f6f0;
  transform: translate(-50%, -50%);
}

.service-detail-consulting .diagnosis-goal-visual i {
  position: absolute;
  inset: 50% auto auto 50%;
  z-index: 0;
  display: block;
  width: 1px;
  height: calc(100% - 26px);
  background: rgba(248, 246, 240, 0.12);
  content: "";
  transform: translate(-50%, -50%);
}

.service-detail-consulting .diagnosis-goal-visual i:last-child {
  width: calc(100% - 26px);
  height: 1px;
}

.service-detail-consulting .diagnosis-goal-visual span {
  min-height: 38px;
  border-radius: 14px;
}

.service-detail-consulting .diagnosis-flow-visual {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: minmax(42px, auto) minmax(32px, auto);
  gap: 12px;
  align-content: center;
}

.service-detail-consulting .diagnosis-flow-visual::before {
  top: 37px;
  right: 30px;
  left: 30px;
  background: rgba(47, 102, 234, 0.18);
}

.flow-route,
.flow-checks {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 8px;
}

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

.flow-route span {
  min-height: 38px;
  min-width: 0;
  padding: 0 4px;
  font-size: 11px;
}

.flow-checks {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  width: 100%;
  margin: 0 auto;
}

.flow-checks b {
  width: auto;
  height: auto;
  min-width: 0;
  min-height: 28px;
  padding: 0 4px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  background: rgba(255, 255, 255, 0.74);
  color: var(--muted);
  font-size: 10px;
}

.diagnosis-flow-visual i {
  position: absolute;
  right: 16px;
  bottom: 14px;
  width: 28px;
  height: 28px;
  border: 1px solid rgba(47, 102, 234, 0.16);
  border-radius: 999px;
  background: #ffffff;
  box-shadow: inset 0 0 0 8px rgba(47, 102, 234, 0.08);
}

.service-detail-consulting .diagnosis-gap-visual {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 74px minmax(0, 1fr);
  gap: 10px;
  align-items: center;
}

.gap-side {
  display: grid;
  grid-template-rows: auto repeat(3, 8px);
  gap: 7px;
  min-width: 0;
}

.gap-side span {
  min-height: 30px;
  border-radius: 12px;
}

.gap-side i {
  display: block;
  height: 8px;
  border-radius: 999px;
  background: rgba(201, 121, 16, 0.2);
}

.gap-side i:nth-child(2) {
  width: 92%;
}

.gap-side i:nth-child(3) {
  width: 76%;
}

.gap-side i:nth-child(4) {
  width: 64%;
}

.gap-side.current i {
  background: rgba(47, 102, 234, 0.18);
}

.gap-side.current i:nth-child(2) {
  width: 66%;
}

.gap-side.current i:nth-child(3) {
  width: 48%;
}

.gap-side.current i:nth-child(4) {
  width: 58%;
}

.service-detail-consulting .diagnosis-gap-visual b {
  width: 74px;
  min-height: 56px;
  height: auto;
  padding: 0 8px;
  border-radius: 18px;
  background: #ffffff;
  color: var(--ink);
  font-size: 11px;
  text-align: center;
  white-space: normal;
}

.service-detail-consulting .diagnosis-launch-visual {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto auto;
  gap: 12px;
  align-content: center;
}

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

.launch-score span {
  min-height: 30px;
  min-width: 0;
  padding: 0 2px;
  border: 1px solid rgba(103, 142, 97, 0.14);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 11px;
}

.launch-output {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) 54px;
  gap: 8px;
  align-items: stretch;
}

.launch-output b,
.launch-output em {
  display: grid;
  place-items: center;
  width: auto;
  height: auto;
  min-width: 0;
  min-height: 48px;
  padding: 0 4px;
  border-radius: 16px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.2;
  white-space: nowrap;
}

.launch-output b {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f7fbf4;
  color: #3d6437;
}

.launch-output em {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-style: normal;
}

.service-detail-consulting .service-consulting-title {
  max-width: 520px;
  font-size: clamp(30px, 2.25vw, 38px);
  line-height: 1.08;
}

.service-detail-consulting .service-consulting-title .title-line {
  display: block;
  white-space: nowrap;
}

.service-detail-consulting .consulting-node {
  grid-template-rows: auto minmax(150px, 1fr);
  gap: 12px;
}

.service-detail-consulting .consulting-node-head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head,
.service-detail-consulting .consulting-node-launch .consulting-node-head {
  justify-content: flex-end;
  text-align: right;
}

.service-detail-consulting .consulting-node strong {
  font-size: clamp(20px, 1.45vw, 25px);
  line-height: 1;
  white-space: nowrap;
}

.service-detail-consulting .consulting-node small {
  flex: 0 0 auto;
  min-height: 26px;
  padding: 4px 10px;
  font-size: 12px;
}

.service-detail-consulting .consulting-node-visual {
  min-height: 150px;
  padding: 12px;
}

.service-detail-consulting .diagnosis-goal-visual,
.service-detail-consulting .diagnosis-flow-visual,
.service-detail-consulting .diagnosis-gap-visual,
.service-detail-consulting .diagnosis-launch-visual {
  display: block;
}

.service-detail-consulting .diagnosis-goal-visual::before,
.service-detail-consulting .diagnosis-flow-visual::before {
  content: none;
}

.goal-matrix,
.flow-swimlane,
.benchmark-board,
.launch-priority-board {
  position: relative;
  height: 100%;
  min-height: 126px;
  overflow: hidden;
}

.goal-matrix {
  border: 1px solid rgba(248, 246, 240, 0.11);
  border-radius: 14px;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(248, 246, 240, 0.12) calc(50% - 1px), rgba(248, 246, 240, 0.12) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(248, 246, 240, 0.12) calc(50% - 1px), rgba(248, 246, 240, 0.12) calc(50% + 1px), transparent calc(50% + 1px));
}

.goal-axis-y,
.goal-axis-x {
  position: absolute;
  z-index: 1;
  display: block;
  min-height: auto;
  color: rgba(248, 246, 240, 0.46);
  font-size: 10px;
  font-weight: 850;
}

.goal-axis-y {
  top: 8px;
  left: 10px;
  width: 56px;
}

.goal-axis-x {
  right: 10px;
  bottom: 8px;
}

.goal-priority {
  position: absolute;
  z-index: 4;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  width: 70px;
  min-height: 34px;
  border: 1px solid rgba(248, 246, 240, 0.18);
  border-radius: 999px;
  background: #111111;
  color: #f8f6f0;
  font-size: 11px;
  transform: translate(-50%, -50%);
}

.service-detail-consulting .diagnosis-goal-visual .goal-point {
  position: absolute;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 78px;
  height: 28px;
  min-height: 0;
  border: 1px solid rgba(248, 246, 240, 0.13);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(248, 246, 240, 0.84);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  transform: none;
}

.goal-point-leads { top: 18px; left: 42px; }
.goal-point-fran { top: 18px; right: 28px; }
.goal-point-ops { bottom: 22px; left: 28px; }
.goal-point-train { right: 42px; bottom: 22px; }

.service-detail-consulting .diagnosis-goal-visual .goal-point:last-child {
  width: 78px;
  height: 28px;
}

.flow-swimlane {
  display: grid;
  grid-template-rows: 30px 34px 34px 26px;
  gap: 7px;
}

.flow-stage-head,
.flow-lane,
.flow-metrics {
  display: grid;
  grid-template-columns: 42px repeat(4, minmax(0, 1fr));
  gap: 6px;
  align-items: center;
}

.flow-stage-head {
  grid-template-columns: 42px repeat(4, minmax(0, 1fr));
}

.flow-stage-head::before {
  content: "阶段";
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
}

.flow-stage-head span,
.flow-lane span,
.flow-lane b,
.flow-metrics i {
  display: grid;
  place-items: center;
  min-height: 26px;
  min-width: 0;
  border-radius: 10px;
  font-size: 10px;
  font-weight: 900;
  line-height: 1.1;
  white-space: nowrap;
}

.flow-stage-head span {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
}

.flow-lane b {
  border: 1px solid rgba(20, 20, 20, 0.06);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
}

.flow-lane span {
  border: 1px solid rgba(20, 20, 20, 0.06);
  background: rgba(255, 255, 255, 0.58);
  color: var(--ink-soft);
}

.flow-lane.risk span {
  border-color: rgba(201, 121, 16, 0.12);
  background: #fff8ed;
  color: #8a5a16;
}

.flow-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  width: calc(100% - 48px);
  margin-left: auto;
}

.flow-metrics i {
  position: static;
  width: auto;
  height: auto;
  border: 1px solid rgba(103, 142, 97, 0.12);
  background: #f0f9ee;
  color: #3d6437;
  box-shadow: none;
  font-style: normal;
}

.benchmark-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 74px minmax(0, 1fr);
  gap: 8px;
  align-items: stretch;
}

.benchmark-col {
  display: grid;
  grid-template-rows: 26px repeat(3, 1fr);
  gap: 6px;
  min-width: 0;
  padding: 8px;
  border: 1px solid rgba(201, 121, 16, 0.12);
  border-radius: 14px;
  background: #fff8ed;
}

.benchmark-col.current {
  border-color: rgba(47, 102, 234, 0.12);
  background: #f3f8ff;
}

.benchmark-col small,
.benchmark-col span,
.benchmark-gap b,
.benchmark-gap i {
  display: grid;
  place-items: center;
  min-height: 0;
  border-radius: 999px;
  font-weight: 900;
  line-height: 1.1;
}

.benchmark-col small {
  color: #8a5a16;
  font-size: 10px;
}

.benchmark-col.current small {
  color: #315d9a;
}

.benchmark-col span {
  background: rgba(255, 255, 255, 0.76);
  color: var(--ink-soft);
  font-size: 10px;
}

.benchmark-gap {
  display: grid;
  grid-template-rows: 1fr 34px;
  gap: 8px;
  align-items: stretch;
}

.benchmark-gap b {
  width: auto;
  height: auto;
  min-height: 0;
  padding: 0 7px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  background: #ffffff;
  color: var(--ink);
  font-size: 10px;
  text-align: center;
  white-space: normal;
}

.benchmark-gap i {
  border: 1px solid rgba(201, 121, 16, 0.14);
  background: #fff7ea;
  color: #8a5a16;
  font-style: normal;
  font-size: 13px;
}

.launch-priority-board {
  display: grid;
  grid-template-rows: 30px 48px 34px;
  gap: 9px;
  align-content: center;
}

.launch-rubric,
.launch-scenes,
.launch-system {
  display: grid;
  gap: 7px;
}

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

.launch-scenes {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.launch-system {
  grid-template-columns: 54px 1fr 62px 1fr 42px;
  align-items: center;
}

.launch-rubric span,
.launch-scenes b,
.launch-system span {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 12px;
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
}

.launch-rubric span {
  border: 1px solid rgba(103, 142, 97, 0.14);
  background: #f0f9ee;
  color: #3d6437;
}

.launch-scenes b {
  border: 1px solid rgba(103, 142, 97, 0.14);
  background: #f7fbf4;
  color: #3d6437;
}

.launch-system span {
  min-height: 30px;
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
}

.launch-system i {
  display: block;
  height: 1px;
  background: rgba(47, 102, 234, 0.18);
}

.service-detail-consulting .service-detail-index {
  display: inline-flex;
  align-items: center;
  width: max-content;
  min-height: 34px;
  margin-bottom: 26px;
  padding: 0 14px;
  border: 1px solid rgba(201, 121, 16, 0.18);
  border-radius: 999px;
  background: rgba(255, 241, 216, 0.88);
  color: #8a5a16;
  font-size: 13px;
  font-weight: 900;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head,
.service-detail-consulting .consulting-node-launch .consulting-node-head {
  flex-direction: row-reverse;
  justify-content: flex-start;
}

.service-detail-consulting .diagnosis-action-matrix,
.service-detail-consulting .diagnosis-flow-board,
.service-detail-consulting .diagnosis-skill-board,
.service-detail-consulting .diagnosis-agent-board {
  height: 100%;
  min-height: 126px;
}

.diagnosis-action-matrix {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 10px;
  border: 1px solid rgba(248, 246, 240, 0.11);
  border-radius: 16px;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% + 1px), transparent calc(50% + 1px));
}

.diagnosis-action-matrix span,
.diagnosis-action-matrix b {
  display: grid;
  place-items: center;
  border-radius: 14px;
  font-weight: 900;
  line-height: 1.15;
}

.diagnosis-action-matrix span {
  min-height: 44px;
  border: 1px solid rgba(248, 246, 240, 0.13);
  background: rgba(255, 255, 255, 0.1);
  color: rgba(248, 246, 240, 0.86);
  font-size: 13px;
}

.diagnosis-action-matrix b {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: 78px;
  min-height: 36px;
  border: 1px solid rgba(248, 246, 240, 0.2);
  border-radius: 999px;
  background: #111111;
  color: #f8f6f0;
  font-size: 12px;
  transform: translate(-50%, -50%);
}

.diagnosis-flow-board {
  display: grid;
  grid-template-rows: repeat(3, minmax(28px, 1fr)) 30px;
  gap: 7px;
  align-content: center;
}

.flow-row {
  display: grid;
  grid-template-columns: 42px repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.flow-row b,
.flow-row span,
.flow-metric-row span {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 10px;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.1;
}

.flow-row b {
  border: 1px solid rgba(20, 20, 20, 0.06);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
}

.flow-row span {
  border: 1px solid rgba(47, 102, 234, 0.12);
  background: #f3f8ff;
  color: #315d9a;
}

.flow-row.muted span {
  border-color: rgba(20, 20, 20, 0.06);
  background: rgba(255, 255, 255, 0.68);
  color: var(--ink-soft);
}

.flow-row.risk span {
  border-color: rgba(201, 121, 16, 0.12);
  background: #fff8ed;
  color: #8a5a16;
}

.flow-metric-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  padding-left: 48px;
}

.flow-metric-row span {
  border: 1px solid rgba(103, 142, 97, 0.12);
  background: #f0f9ee;
  color: #3d6437;
}

.diagnosis-skill-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 24px 90px;
  gap: 10px;
  align-items: center;
}

.skill-source-list {
  display: grid;
  gap: 9px;
  min-width: 0;
  padding: 12px;
  border: 1px solid rgba(201, 121, 16, 0.14);
  border-radius: 16px;
  background: #fff8ed;
}

.skill-source-list span {
  display: grid;
  place-items: center;
  min-height: 30px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #8a5a16;
  font-size: 13px;
  font-weight: 900;
}

.diagnosis-skill-board > i {
  display: block;
  height: 2px;
  background: rgba(201, 121, 16, 0.28);
}

.skill-target-ring {
  display: grid;
  place-items: center;
  width: 88px;
  height: 88px;
  border: 13px solid rgba(201, 121, 16, 0.18);
  border-radius: 999px;
  background: #ffffff;
}

.skill-target-ring b {
  color: var(--ink);
  font-size: 17px;
  line-height: 1;
}

.skill-target-ring span {
  min-height: auto;
  color: var(--ink-soft);
  font-size: 11px;
  font-weight: 850;
}

.diagnosis-agent-board {
  display: grid;
  grid-template-columns: 70px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 10px;
  border: 1px solid rgba(126, 87, 194, 0.12);
  border-radius: 16px;
  background: rgba(245, 240, 255, 0.64);
}

.agent-pill {
  display: grid;
  place-items: center;
  min-height: 94px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.74);
}

.agent-pill::before {
  width: 30px;
  height: 30px;
  margin-bottom: 8px;
  border-radius: 999px;
  background: #b8a3f2;
  content: "";
}

.agent-pill b {
  color: #6b4bd4;
  font-size: 15px;
  line-height: 1;
}

.agent-task-panel {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  min-width: 0;
  padding: 10px;
  border: 1px solid rgba(126, 87, 194, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.56);
}

.agent-task-panel strong {
  grid-column: 1 / -1;
  min-height: 30px;
  color: var(--ink);
  font-size: 16px;
  line-height: 1;
}

.agent-task-panel span {
  display: grid;
  place-items: center;
  min-height: 28px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: #6b4bd4;
  font-size: 12px;
  font-weight: 900;
}

@media (max-width: 560px) {
  .flow-row b,
  .flow-row span,
  .flow-metric-row span,
  .agent-task-panel span {
    font-size: 10px;
    white-space: normal;
    text-align: center;
  }

  .agent-task-panel {
    gap: 6px;
    padding: 8px;
  }
}

.service-detail-consulting .consulting-node-flow .consulting-node-head,
.service-detail-consulting .consulting-node-launch .consulting-node-head {
  flex-direction: row;
  justify-content: flex-end;
  text-align: right;
}

.service-detail-consulting .consulting-node-visual {
  min-height: 158px;
  padding: 12px;
}

.consulting-priority-map,
.consulting-process-lanes,
.consulting-gap-bridge,
.consulting-launch-scorecard {
  position: relative;
  height: 100%;
  min-height: 134px;
  overflow: hidden;
}

.consulting-priority-map {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 16px 12px 14px;
  border: 1px solid rgba(248, 246, 240, 0.12);
  border-radius: 16px;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% - 1px), rgba(248, 246, 240, 0.14) calc(50% + 1px), transparent calc(50% + 1px));
}

.priority-axis-y,
.priority-axis-x {
  position: absolute;
  z-index: 3;
  color: rgba(248, 246, 240, 0.5);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
}

.priority-axis-y {
  top: 6px;
  left: 50%;
  transform: translateX(-50%);
}

.priority-axis-x {
  right: 12px;
  bottom: 4px;
}

.priority-cell {
  display: grid;
  align-content: center;
  gap: 5px;
  min-width: 0;
  min-height: 46px;
  padding: 8px 10px;
  border: 1px solid rgba(248, 246, 240, 0.13);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.1);
  color: rgba(248, 246, 240, 0.86);
}

.priority-cell div {
  font-size: 14px;
  font-weight: 900;
  line-height: 1.05;
}

.priority-cell p {
  margin: 0;
  color: rgba(248, 246, 240, 0.55);
  font-size: 11px;
  font-weight: 800;
  line-height: 1.2;
}

.priority-high {
  box-shadow: inset 0 0 0 1px rgba(248, 246, 240, 0.08);
}

.priority-decision {
  position: absolute;
  z-index: 4;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  width: 78px;
  min-height: 38px;
  border: 1px solid rgba(248, 246, 240, 0.2);
  border-radius: 999px;
  background: #111111;
  color: #f8f6f0;
  font-size: 12px;
  font-weight: 900;
  transform: translate(-50%, -50%);
}

.consulting-process-lanes {
  display: grid;
  grid-template-rows: 28px repeat(3, 27px) 28px;
  gap: 7px;
  align-content: center;
}

.lane-head,
.lane-row {
  display: grid;
  grid-template-columns: 44px repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.lane-head::before {
  display: grid;
  place-items: center;
  color: var(--muted);
  content: "阶段";
  font-size: 11px;
  font-weight: 900;
}

.lane-head div,
.lane-row div,
.lane-row em,
.lane-output div {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 10px;
  font-size: 12px;
  font-style: normal;
  font-weight: 900;
  line-height: 1.1;
  text-align: center;
}

.lane-head div {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
}

.lane-row em {
  border: 1px solid rgba(20, 20, 20, 0.06);
  background: rgba(255, 255, 255, 0.72);
  color: var(--muted);
}

.lane-row div {
  border: 1px solid rgba(20, 20, 20, 0.06);
  background: rgba(255, 255, 255, 0.64);
  color: var(--ink-soft);
}

.lane-row.risk div {
  border-color: rgba(201, 121, 16, 0.13);
  background: #fff8ed;
  color: #8a5a16;
}

.lane-output {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
  padding-left: 50px;
}

.lane-output div {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
}

.consulting-gap-bridge {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1fr) minmax(0, 0.9fr);
  grid-template-rows: 1fr 32px;
  gap: 8px;
}

.gap-column,
.gap-register {
  display: grid;
  gap: 6px;
  min-width: 0;
  padding: 9px;
  border-radius: 16px;
}

.gap-column {
  border: 1px solid rgba(201, 121, 16, 0.13);
  background: #fff8ed;
}

.gap-column.business {
  border-color: rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
}

.gap-register {
  border: 1px solid rgba(20, 20, 20, 0.07);
  background: rgba(255, 255, 255, 0.72);
}

.gap-column div,
.gap-register div {
  display: grid;
  place-items: center;
  min-height: 22px;
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
}

.gap-column p,
.gap-register p {
  display: grid;
  place-items: center;
  min-height: 21px;
  margin: 0;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink-soft);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.gap-register p {
  color: #8a5a16;
}

.gap-output-card {
  grid-column: 1 / -1;
  display: grid;
  place-items: center;
  border: 1px solid rgba(103, 142, 97, 0.13);
  border-radius: 999px;
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
  font-weight: 900;
}

.consulting-launch-scorecard {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(96px, 0.76fr);
  grid-template-rows: repeat(3, 26px) 36px;
  gap: 7px 10px;
  align-content: center;
}

.score-row {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) 44px;
  gap: 7px;
  align-items: center;
}

.score-row em,
.score-row p {
  display: grid;
  place-items: center;
  min-height: 24px;
  margin: 0;
  border-radius: 999px;
  font-style: normal;
  font-size: 11px;
  font-weight: 900;
}

.score-row em {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
}

.score-row div {
  height: 9px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(20, 20, 20, 0.06);
}

.score-row i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #8fc37b, #2f66ea);
}

.score-row p {
  color: var(--muted);
}

.launch-shortlist {
  grid-column: 2;
  grid-row: 1 / 4;
  display: grid;
  gap: 7px;
  padding: 8px;
  border: 1px solid rgba(103, 142, 97, 0.13);
  border-radius: 16px;
  background: #f7fbf4;
}

.launch-shortlist div,
.launch-shortlist p,
.launch-scope p {
  display: grid;
  place-items: center;
  margin: 0;
  border-radius: 999px;
  font-weight: 900;
  line-height: 1;
}

.launch-shortlist div {
  color: #3d6437;
  font-size: 11px;
}

.launch-shortlist p {
  min-height: 26px;
  background: rgba(255, 255, 255, 0.8);
  color: #3d6437;
  font-size: 11px;
}

.launch-scope {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.launch-scope p {
  min-height: 32px;
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 11px;
}

@media (max-width: 560px) {
  .priority-cell div {
    font-size: 12px;
  }

  .priority-cell p,
  .lane-head div,
  .lane-row div,
  .lane-row em,
  .lane-output div,
  .gap-column p,
  .gap-register p,
  .score-row em,
  .score-row p,
  .launch-shortlist p,
  .launch-scope p {
    font-size: 10px;
  }

  .consulting-launch-scorecard {
    grid-template-columns: minmax(0, 1fr) minmax(86px, 0.78fr);
  }
}

/* Consulting map correction: fixed module height and clearer diagnostic charts. */
.service-detail-consulting .service-consulting-stage {
  height: 620px;
  min-height: 620px;
  grid-template-rows: 34px repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.service-detail-consulting .consulting-node {
  min-height: 0;
  padding: 18px;
  overflow: hidden;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 12px;
}

.service-detail-consulting .consulting-node-visual {
  align-self: stretch;
  min-height: 0;
  height: 100%;
  padding: 10px;
}

.consulting-priority-map,
.consulting-process-flow,
.consulting-gap-bridge,
.consulting-launch-scorecard {
  height: 100%;
  min-height: 0;
}

.consulting-priority-map {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 24px 10px 10px;
  border-radius: 16px;
}

.priority-axis-y,
.priority-axis-x {
  top: 7px;
  bottom: auto;
  left: auto;
  right: auto;
  width: auto;
  transform: none;
  color: rgba(248, 246, 240, 0.55);
  font-size: 11px;
}

.priority-axis-y {
  left: 12px;
}

.priority-axis-x {
  right: 12px;
}

.priority-cell {
  min-height: 0;
  padding: 9px 10px;
  align-content: center;
  gap: 4px;
}

.priority-cell div {
  font-size: 13px;
}

.priority-cell p {
  font-size: 10px;
  line-height: 1.15;
}

.priority-decision {
  top: 50%;
  width: 74px;
  min-height: 32px;
  font-size: 11px;
}

.consulting-process-flow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 12px minmax(0, 1fr) 12px minmax(0, 1fr) 12px minmax(0, 1fr);
  grid-template-rows: minmax(64px, 1fr) 28px 28px;
  gap: 8px 6px;
  align-items: center;
}

.process-step {
  display: grid;
  align-content: center;
  gap: 4px;
  min-width: 0;
  height: 100%;
  min-height: 62px;
  padding: 8px 7px;
  border: 1px solid rgba(47, 102, 234, 0.13);
  border-radius: 14px;
  background: #f3f8ff;
  text-align: center;
}

.process-step b {
  color: #315d9a;
  font-size: 13px;
  line-height: 1;
}

.process-step span {
  min-height: auto;
  color: var(--ink);
  font-size: 11px;
  font-weight: 900;
  line-height: 1.1;
}

.process-step em {
  color: var(--muted);
  font-size: 10px;
  font-style: normal;
  font-weight: 850;
  line-height: 1;
}

.consulting-process-flow > i {
  display: block;
  width: 100%;
  height: 2px;
  border-radius: 999px;
  background: rgba(47, 102, 234, 0.25);
}

.process-breakpoints,
.process-metrics {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 6px;
}

.process-metrics {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 0 32px;
}

.process-breakpoints span,
.process-metrics span {
  display: grid;
  place-items: center;
  min-height: 26px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.process-breakpoints span {
  border: 1px solid rgba(201, 121, 16, 0.13);
  background: #fff8ed;
  color: #8a5a16;
}

.process-metrics span {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
}

.consulting-gap-bridge {
  grid-template-rows: minmax(0, 1fr) 28px;
  gap: 7px;
}

.gap-column,
.gap-register {
  gap: 5px;
  padding: 8px;
}

.gap-column div,
.gap-register div {
  min-height: 20px;
  font-size: 11px;
}

.gap-column p,
.gap-register p {
  min-height: 19px;
  font-size: 10px;
}

.gap-output-card {
  font-size: 11px;
}

.consulting-launch-scorecard {
  grid-template-rows: repeat(3, 24px) 30px;
  gap: 6px 9px;
}

.score-row {
  grid-template-columns: 34px minmax(0, 1fr) 42px;
  gap: 6px;
}

.score-row em,
.score-row p,
.launch-shortlist div,
.launch-shortlist p,
.launch-scope p {
  font-size: 10px;
}

.launch-shortlist {
  gap: 6px;
  padding: 7px;
}

.launch-shortlist p {
  min-height: 24px;
}

.launch-scope {
  gap: 6px;
}

.launch-scope p {
  min-height: 28px;
}

@media (max-width: 560px) {
  .service-detail-consulting .service-consulting-stage {
    height: auto;
    min-height: auto;
  }

  .consulting-process-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(2, minmax(58px, auto)) auto auto;
  }

  .consulting-process-flow > i {
    display: none;
  }

  .process-breakpoints,
  .process-metrics {
    grid-column: 1 / -1;
  }

  .process-breakpoints span,
  .process-metrics span {
    font-size: 10px;
    white-space: normal;
  }
}

.consulting-process-flow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18px minmax(0, 1fr);
  grid-template-rows: 48px 12px 48px 24px 24px;
  gap: 5px 7px;
  align-content: center;
}

.consulting-process-flow .process-step {
  min-height: 0;
  height: auto;
  padding: 6px 8px;
  border-radius: 13px;
}

.consulting-process-flow .process-step b {
  font-size: 13px;
}

.consulting-process-flow .process-step span {
  font-size: 11px;
  line-height: 1;
  white-space: nowrap;
}

.consulting-process-flow .process-step em {
  font-size: 10px;
}

.consulting-process-flow > .process-step:nth-child(1) {
  grid-column: 1;
  grid-row: 1;
}

.consulting-process-flow > i:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
  width: 18px;
  height: 3px;
  align-self: center;
  background: rgba(47, 102, 234, 0.42);
}

.consulting-process-flow > i:nth-child(2)::after,
.consulting-process-flow > i:nth-child(4)::after,
.consulting-process-flow > i:nth-child(6)::after {
  display: block;
  width: 7px;
  height: 7px;
  margin-left: auto;
  border-top: 2px solid rgba(47, 102, 234, 0.56);
  border-right: 2px solid rgba(47, 102, 234, 0.56);
  content: "";
  transform: translateY(-2px) rotate(45deg);
}

.consulting-process-flow > .process-step:nth-child(3) {
  grid-column: 3;
  grid-row: 1;
}

.consulting-process-flow > i:nth-child(4) {
  grid-column: 3;
  grid-row: 2;
  width: 3px;
  height: 12px;
  justify-self: center;
  background: rgba(47, 102, 234, 0.42);
}

.consulting-process-flow > i:nth-child(4)::after {
  margin: 5px 0 0 -2px;
  transform: rotate(135deg);
}

.consulting-process-flow > .process-step:nth-child(5) {
  grid-column: 3;
  grid-row: 3;
}

.consulting-process-flow > i:nth-child(6) {
  grid-column: 2;
  grid-row: 3;
  width: 18px;
  height: 3px;
  align-self: center;
  background: rgba(47, 102, 234, 0.42);
}

.consulting-process-flow > i:nth-child(6)::after {
  margin-left: 0;
  transform: translateY(-2px) rotate(-135deg);
}

.consulting-process-flow > .process-step:nth-child(7) {
  grid-column: 1;
  grid-row: 3;
}

.process-breakpoints,
.process-metrics {
  grid-column: 1 / -1;
  display: grid;
  gap: 5px;
  padding: 0;
}

.process-breakpoints {
  grid-row: 4;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.process-metrics {
  grid-row: 5;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.process-breakpoints span,
.process-metrics span {
  min-height: 22px;
  font-size: 10px;
}

/* Consulting map final polish: keep the original stage height and clean the four diagnostic graphics. */
.service-detail-consulting .service-consulting-stage {
  height: 620px;
  min-height: 620px;
}

.service-detail-consulting .consulting-node {
  min-height: 0;
}

.service-detail-consulting .consulting-node-visual {
  min-height: 0;
  overflow: hidden;
}

.consulting-priority-map {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 20px 8px 8px;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.consulting-priority-map::before,
.consulting-priority-map::after {
  content: none;
}

.priority-axis-y,
.priority-axis-x {
  top: 0;
  color: rgba(248, 246, 240, 0.58);
  font-size: 10px;
  line-height: 1;
}

.priority-cell {
  min-height: 0;
  padding: 9px 10px;
  border-color: rgba(255, 255, 255, 0.16);
  border-radius: 13px;
  background: rgba(255, 255, 255, 0.11);
}

.priority-cell div {
  font-size: 12px;
  line-height: 1.1;
}

.priority-cell p {
  font-size: 9px;
  line-height: 1.2;
}

.priority-decision {
  width: 68px;
  min-height: 30px;
  font-size: 10px;
  box-shadow: 0 10px 22px rgba(0, 0, 0, 0.22);
}

.consulting-process-flow {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 28px minmax(0, 1fr);
  grid-template-rows: 54px 18px 54px 24px 24px;
  gap: 5px 6px;
  align-content: center;
}

.consulting-process-flow .process-step {
  display: grid;
  align-content: center;
  min-height: 0;
  height: 54px;
  padding: 6px 8px;
  gap: 3px;
  border-color: rgba(47, 102, 234, 0.14);
  border-radius: 13px;
  background: linear-gradient(135deg, #f4f8ff, #eef5ff);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.58);
}

.consulting-process-flow .process-step b {
  font-size: 13px;
  line-height: 1;
}

.consulting-process-flow .process-step span {
  display: block;
  min-height: 0;
  font-size: 10px;
  line-height: 1.1;
  white-space: nowrap;
}

.consulting-process-flow .process-step em {
  display: inline-grid;
  justify-self: center;
  min-height: 16px;
  padding: 0 10px;
  place-items: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
  color: #526273;
  font-size: 9px;
  line-height: 1;
}

.consulting-process-flow > .process-step:nth-child(1) {
  grid-column: 1;
  grid-row: 1;
}

.consulting-process-flow > .process-step:nth-child(3) {
  grid-column: 3;
  grid-row: 1;
}

.consulting-process-flow > .process-step:nth-child(5) {
  grid-column: 3;
  grid-row: 3;
}

.consulting-process-flow > .process-step:nth-child(7) {
  grid-column: 1;
  grid-row: 3;
}

.consulting-process-flow > i {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  background: transparent;
  color: rgba(47, 102, 234, 0.72);
  font-size: 18px;
  font-style: normal;
  font-weight: 900;
  line-height: 1;
}

.consulting-process-flow > i::after {
  content: none;
}

.consulting-process-flow > i:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
}

.consulting-process-flow > i:nth-child(2)::before {
  content: "→";
}

.consulting-process-flow > i:nth-child(4) {
  grid-column: 3;
  grid-row: 2;
}

.consulting-process-flow > i:nth-child(4)::before {
  content: "↓";
}

.consulting-process-flow > i:nth-child(6) {
  grid-column: 2;
  grid-row: 3;
}

.consulting-process-flow > i:nth-child(6)::before {
  content: "←";
}

.process-breakpoints,
.process-metrics {
  grid-column: 1 / -1;
  display: grid;
  gap: 5px;
  padding: 0;
}

.process-breakpoints {
  grid-row: 4;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.process-metrics {
  grid-row: 5;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 0 18px;
}

.process-breakpoints span,
.process-metrics span {
  min-height: 22px;
  padding: 0 6px;
  font-size: 10px;
  white-space: nowrap;
}

.consulting-gap-bridge {
  grid-template-columns: minmax(0, 0.95fr) minmax(84px, 0.72fr) minmax(0, 0.95fr);
  grid-template-rows: minmax(0, 1fr) 30px;
  gap: 7px;
  align-items: stretch;
}

.gap-column,
.gap-register {
  display: grid;
  gap: 5px;
  min-width: 0;
  padding: 7px;
  align-content: stretch;
}

.gap-column div,
.gap-register div {
  min-height: 20px;
  font-size: 11px;
  line-height: 1;
}

.gap-column p,
.gap-register p {
  display: grid;
  min-height: 18px;
  padding: 0 7px;
  place-items: center;
  font-size: 10px;
  line-height: 1;
  white-space: nowrap;
}

.gap-output-card {
  min-height: 30px;
  font-size: 11px;
}

.consulting-launch-scorecard {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 104px;
  grid-template-rows: repeat(3, 24px) 30px;
  gap: 6px 8px;
  align-content: center;
}

.score-row {
  grid-template-columns: 34px minmax(0, 1fr) 42px;
  gap: 6px;
  min-height: 24px;
}

.score-row em,
.score-row p {
  min-height: 24px;
  font-size: 10px;
  line-height: 1;
}

.score-row div {
  height: 8px;
}

.launch-shortlist {
  grid-row: 1 / span 3;
  gap: 6px;
  padding: 7px;
  align-content: center;
}

.launch-shortlist div {
  min-height: 18px;
  font-size: 10px;
}

.launch-shortlist p {
  min-height: 23px;
  font-size: 10px;
  line-height: 1;
}

.launch-scope {
  grid-column: 1 / -1;
  gap: 6px;
}

.launch-scope p {
  min-height: 28px;
  padding: 0 8px;
  font-size: 10px;
  line-height: 1;
  white-space: nowrap;
}

.service-skill-panel {
  min-height: 560px;
}

.service-skill-panel .service-skill-flow article {
  grid-template-rows: 26px 72px 1fr;
  min-height: 340px;
  padding: 22px;
}

.service-skill-panel .service-skill-flow article strong {
  font-size: clamp(23px, 2vw, 28px);
}

.service-skill-panel .service-skill-flow article p {
  font-size: 14px;
  line-height: 1.48;
}

.service-app-stage {
  grid-template-columns: minmax(0, 1.34fr) minmax(300px, 0.66fr);
  gap: 30px;
  min-height: 640px;
  padding: 30px;
}

.service-app-visual {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 580px;
  padding: 0;
  overflow: visible;
  border: 0;
  background: transparent;
}

.service-workflow-board {
  min-height: 532px;
  padding: 32px;
  overflow: hidden;
  border: 0;
  border-radius: 26px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(135deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.48));
  background-size: 56px 56px, 56px 56px, auto;
  box-shadow: inset 0 0 0 1px rgba(20, 20, 20, 0.06);
}

.service-workflow-board::before {
  content: "";
  position: absolute;
  top: 28px;
  right: 32px;
  left: 32px;
  height: 54px;
  border-radius: 18px;
  background:
    linear-gradient(rgba(20, 20, 20, 0.14) 0 0) 24px 20px / 130px 10px no-repeat,
    linear-gradient(rgba(20, 20, 20, 0.08) 0 0) right 24px top 20px / 170px 10px no-repeat,
    rgba(255, 255, 255, 0.72);
}

.service-workflow-board strong {
  align-items: end;
  justify-items: start;
  min-height: 300px;
  padding: 18px;
  border: 0;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.66);
  font-size: clamp(18px, 1.9vw, 24px);
  line-height: 1.12;
  text-align: left;
  box-shadow: none;
}

.service-app-copy {
  min-height: 580px;
  padding: 30px;
}

.service-app-copy h3 {
  margin-top: 56px;
  font-size: clamp(32px, 3.2vw, 50px);
}

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

.service-cooperation-visual {
  display: grid;
  grid-template-rows: auto 1fr;
  min-height: 380px;
  margin: 0;
}

.service-cycle-graphic {
  position: relative;
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  align-content: center;
  min-height: 300px;
}

.service-cycle-graphic::before {
  content: "";
  position: absolute;
  top: 22px;
  bottom: 22px;
  left: 28px;
  width: 2px;
  background: linear-gradient(180deg, var(--blue), var(--green), var(--orange));
}

.service-cycle-graphic span {
  position: relative;
  display: grid;
  align-items: center;
  min-height: 76px;
  margin-left: 64px;
  padding: 18px 20px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink);
  font-family: var(--display);
  font-size: 24px;
  font-weight: 650;
  box-shadow: 0 14px 36px rgba(33, 29, 23, 0.07);
}

.service-cooperation-panel .service-timeline {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 28px;
}

.service-timeline article {
  min-height: 260px;
  padding: 30px;
}

.service-timeline h3 {
  margin-top: 22px;
  font-size: 28px;
}

.service-cooperation-panel .service-timeline p {
  margin: 44px 0 0;
}

.service-scope-panel {
  grid-template-columns: 1fr;
  gap: 0;
  padding: 38px;
}

.service-scope-visual {
  display: grid;
  grid-template-rows: auto 1fr;
  min-width: 0;
  min-height: 520px;
  margin: 0;
  padding: 28px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 26px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, #f7f3ed, #ffffff 55%, #eef5ff);
  background-size: 62px 62px, 62px 62px, auto;
}

.service-scope-radar {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
  align-content: center;
}

.service-scope-radar span {
  display: grid;
  place-items: center;
  min-height: 124px;
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.68);
  color: var(--ink);
  font-family: var(--display);
  font-size: 24px;
  font-weight: 650;
  box-shadow: 0 14px 38px rgba(33, 29, 23, 0.07);
}

.service-scope-content {
  display: grid;
  gap: 28px;
  align-content: start;
  min-width: 0;
}

.service-scope-content .service-scope-copy {
  display: grid;
  gap: 10px;
  align-content: start;
}

.service-scope-panel .service-scope-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.service-scope-grid div {
  min-height: 132px;
  padding: 22px;
}

.service-scope-grid strong {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 24px;
}

.service-scope-grid strong .scope-icon {
  flex: 0 0 auto;
  width: 24px;
  height: 24px;
  color: #28579e;
  stroke: currentColor;
  stroke-width: 1.8;
  stroke-linecap: round;
  stroke-linejoin: round;
  fill: none;
}

.service-scope-grid strong > span {
  display: inline;
  margin: 0;
  color: inherit;
  font: inherit;
  line-height: inherit;
}

.service-scope-grid div > span {
  margin-top: 12px;
  font-size: 15px;
  line-height: 1.45;
}

@media (max-width: 1180px) {
  .service-overview-layout,
  .service-cooperation-layout,
  .service-scope-panel {
    grid-template-columns: 1fr;
  }

  .service-overview-copy,
  .service-overview-visual,
  .service-cooperation-visual,
  .service-scope-visual {
    min-height: auto;
  }

  .service-cooperation-panel .service-timeline {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .service-page .display-title.page-title,
  .service-hero-copy .display-title {
    font-size: clamp(44px, 11vw, 62px);
    line-height: 0.96;
  }

  .service-content-title {
    font-size: clamp(34px, 8vw, 42px);
    line-height: 1.14;
  }

  .service-content-hero .section-lede {
    margin-top: 20px;
  }

  .service-content-tags {
    gap: 10px;
    margin-top: 24px;
  }

  .service-content-tags a {
    min-height: 38px;
    padding: 0 14px;
  }

  .service-overview-layout,
  .service-cooperation-layout {
    gap: 28px;
  }

  .service-overview-visual .service-three-map {
    grid-template-columns: 1fr;
  }

  .service-overview-visual .service-map-card {
    min-height: 220px;
    grid-template-rows: auto auto 1fr;
  }

  .service-app-stage {
    padding: 18px;
  }

  .service-app-visual {
    padding: 0;
  }

  .service-workflow-board {
    min-height: 360px;
    padding: 22px;
  }

  .service-workflow-board::before {
    top: 20px;
    right: 22px;
    left: 22px;
  }

  .service-workflow-board strong {
    min-height: 132px;
  }

  .service-app-copy {
    min-height: auto;
  }

  .service-scope-visual {
    min-height: 420px;
    padding: 18px;
  }
}

@media (max-width: 560px) {
  .service-page .display-title.page-title,
  .service-hero-copy .display-title {
    font-size: 44px;
  }

  .service-map-card p,
  .service-detail-copy p,
  .service-app-copy p,
  .service-scope-copy p,
  .service-timeline p {
    font-size: 16px;
  }

  .service-cycle-graphic span,
  .service-scope-radar span {
    min-height: 84px;
    font-size: 20px;
  }
}

.service-page .service-hero {
  padding-bottom: 124px;
}

.service-page .service-intro {
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

.service-page .service-final {
  padding-top: 124px;
  padding-bottom: 124px;
}

@media (max-width: 820px) {
  .service-page .service-hero {
    padding-bottom: 96px;
  }

  .service-page .service-final {
    padding-top: 96px;
    padding-bottom: 96px;
  }
}

/* About, Contact, and compact footer refinements */
.about-hero {
  display: grid;
  grid-template-columns: minmax(0, 0.95fr) minmax(420px, 1.05fr);
  gap: 72px;
  align-items: center;
  padding: 96px 0 84px;
}

.about-hero-copy {
  max-width: 720px;
}

.about-hero-copy .display-title {
  text-align: left;
}

.about-hero-copy .hero-lede {
  margin-left: 0;
  text-align: left;
}

.about-visual-frame {
  position: relative;
  min-height: 360px;
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 26px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(247, 247, 244, 0.46)),
    radial-gradient(circle at 20% 20%, rgba(255, 140, 0, 0.24), transparent 34%),
    radial-gradient(circle at 80% 75%, rgba(37, 99, 235, 0.18), transparent 34%);
  box-shadow: var(--shadow);
}

.about-hero-image {
  min-height: 520px;
}

.about-image-copy {
  display: grid;
  grid-template-columns: minmax(360px, 0.92fr) minmax(0, 1.08fr);
  gap: 70px;
  align-items: center;
}

.about-image-copy.reverse {
  grid-template-columns: minmax(0, 1.08fr) minmax(360px, 0.92fr);
}

.about-copy-block p {
  margin: 22px 0 0;
  color: var(--muted);
  font-size: 20px;
}

.about-orbit {
  position: absolute;
  inset: 34px;
  border-radius: 50%;
  border: 1px solid rgba(20, 20, 20, 0.1);
}

.about-orbit span {
  position: absolute;
  min-width: 116px;
  padding: 12px 14px;
  border-radius: 999px;
  background: var(--paper);
  box-shadow: 0 12px 34px rgba(20, 20, 20, 0.08);
  font-weight: 800;
  text-align: center;
}

.about-orbit span:nth-child(1) { top: 4%; left: 50%; transform: translateX(-50%); }
.about-orbit span:nth-child(2) { top: 42%; right: -8px; }
.about-orbit span:nth-child(3) { bottom: 4%; left: 50%; transform: translateX(-50%); }
.about-orbit span:nth-child(4) { top: 42%; left: -8px; }

.about-industry-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  margin-top: 56px;
}

.about-industry-card {
  display: grid;
  grid-template-rows: 310px auto;
  gap: 24px;
}

.about-industry-card h3 {
  margin: 0 0 10px;
  font-family: var(--display);
  font-size: 36px;
}

.about-industry-card p,
.about-point-list p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}

.about-industry-image {
  min-height: auto;
  display: grid;
  align-content: center;
  gap: 12px;
  padding: 42px;
}

.about-industry-image span {
  display: block;
  width: min(86%, 360px);
  padding: 16px 18px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.78);
  font-weight: 850;
  box-shadow: 0 14px 34px rgba(20, 20, 20, 0.08);
}

.about-industry-image span:nth-child(2) {
  margin-left: auto;
}

.about-industry-image.chain {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.72), rgba(247, 247, 244, 0.52)),
    radial-gradient(circle at 72% 20%, rgba(7, 193, 96, 0.22), transparent 36%),
    radial-gradient(circle at 20% 82%, rgba(230, 122, 151, 0.22), transparent 34%);
}

.about-point-list {
  display: grid;
  gap: 16px;
  margin-top: 28px;
}

.about-point-list p {
  padding: 18px 0;
  border-bottom: 1px solid var(--line);
}

.about-failure-stack {
  position: absolute;
  inset: 38px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.about-failure-stack span,
.about-failure-stack strong {
  display: grid;
  place-items: center;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.74);
  font-family: var(--display);
  font-size: 28px;
  text-align: center;
}

.about-failure-stack strong {
  grid-column: 1 / -1;
  background: var(--black);
  color: #f7f4ee;
}

.about-capability-map,
.about-ai-diagnosis,
.about-delivery-loop {
  position: absolute;
  inset: 38px;
}

.about-capability-map {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 18px;
  padding-top: 54px;
}

.about-capability-map::before,
.about-capability-map::after {
  position: absolute;
  z-index: 1;
  background: rgba(20, 20, 20, 0.08);
  content: "";
}

.about-capability-map::before {
  top: 54px;
  bottom: 0;
  left: 50%;
  width: 1px;
}

.about-capability-map::after {
  top: calc(54px + 50%);
  right: 0;
  left: 0;
  height: 1px;
}

.about-capability-map article {
  position: relative;
  z-index: 2;
  display: grid;
  align-content: space-between;
  min-height: 0;
  padding: 22px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 16px 42px rgba(30, 25, 20, 0.08);
}

.about-capability-map article small,
.about-capability-map article span,
.delivery-step small,
.delivery-step span,
.diagnosis-column small,
.diagnosis-pivot span {
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 850;
}

.about-capability-map article strong {
  font-family: var(--display);
  font-size: 30px;
  line-height: 1.04;
}

.about-capability-map article span {
  font-size: 14px;
}

.capability-center {
  position: absolute;
  top: calc(54px + 50%);
  left: 50%;
  z-index: 3;
  display: grid;
  place-items: center;
  width: 178px;
  min-height: 96px;
  padding: 16px;
  border-radius: 999px;
  background: var(--black);
  color: #f7f4ee;
  text-align: center;
  box-shadow: 0 20px 52px rgba(20, 20, 20, 0.18);
  transform: translate(-50%, -50%);
}

.capability-center small {
  color: rgba(247, 244, 238, 0.72);
  font-size: 12px;
  font-weight: 850;
}

.capability-center strong {
  font-size: 16px;
  line-height: 1.24;
}

.about-ai-diagnosis {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px minmax(0, 1fr);
  gap: 16px;
  align-items: stretch;
  padding-top: 54px;
}

.diagnosis-column {
  display: grid;
  grid-template-rows: auto repeat(4, minmax(0, 1fr));
  gap: 12px;
  min-height: 0;
}

.diagnosis-column small {
  display: flex;
  align-items: center;
  min-height: 32px;
}

.diagnosis-column span {
  display: grid;
  place-items: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  color: var(--ink);
  font-size: 17px;
  font-weight: 850;
  text-align: center;
}

.diagnosis-column.risk span {
  background: rgba(255, 247, 236, 0.84);
}

.diagnosis-column.target span {
  background: rgba(240, 249, 244, 0.86);
}

.diagnosis-pivot {
  display: grid;
  align-content: center;
  justify-items: center;
  gap: 14px;
  padding-top: 32px;
  text-align: center;
}

.diagnosis-pivot i {
  display: block;
  width: 2px;
  height: 110px;
  border-radius: 999px;
  background: linear-gradient(180deg, rgba(20, 20, 20, 0.16), rgba(20, 20, 20, 0.04));
}

.diagnosis-pivot strong {
  display: grid;
  place-items: center;
  min-height: 112px;
  padding: 16px;
  border-radius: 18px;
  background: var(--black);
  color: #f7f4ee;
  font-family: var(--display);
  font-size: 24px;
  line-height: 1.14;
}

.about-delivery-loop {
  min-height: 0;
  padding-top: 54px;
  --delivery-loop-center-y: calc(54px + 50% - 24px);
}

.delivery-loop-track {
  position: absolute;
  top: var(--delivery-loop-center-y);
  left: 50%;
  z-index: 1;
  width: min(76%, 390px);
  aspect-ratio: 1;
  border: 1px dashed rgba(49, 87, 124, 0.36);
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
}

.delivery-loop-center {
  position: absolute;
  top: var(--delivery-loop-center-y);
  left: 50%;
  z-index: 2;
  display: grid;
  align-content: center;
  place-items: center;
  gap: 8px;
  width: 140px;
  height: 140px;
  min-height: 0;
  padding: 16px;
  border-radius: 50%;
  background: var(--black);
  color: #f7f4ee;
  text-align: center;
  box-shadow: 0 20px 58px rgba(20, 20, 20, 0.18);
  transform: translate(-50%, -50%);
}

.delivery-loop-center small {
  color: rgba(247, 244, 238, 0.72);
  font-size: 12px;
  font-weight: 850;
}

.delivery-loop-center strong {
  display: grid;
  gap: 3px;
  font-size: 16px;
  line-height: 1.24;
}

.delivery-step {
  position: absolute;
  z-index: 3;
  display: grid;
  gap: 5px;
  width: 140px;
  padding: 13px 14px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 14px 40px rgba(30, 25, 20, 0.08);
}

.delivery-step strong {
  font-size: 18px;
  line-height: 1.18;
}

.delivery-step span {
  font-size: 12px;
  line-height: 1.35;
  white-space: nowrap;
}

.delivery-step.step-1 { top: 54px; left: 50%; transform: translateX(-50%); }
.delivery-step.step-2 { top: 38%; right: 0; }
.delivery-step.step-3 { right: 12%; bottom: 0; }
.delivery-step.step-4 { bottom: 0; left: 12%; }
.delivery-step.step-5 { top: 38%; left: 0; }

.about-method-flow {
  position: absolute;
  inset: 40px;
  display: grid;
  grid-template-columns: 1fr 24px 1fr;
  gap: 16px;
  align-content: center;
}

.about-method-flow span {
  display: grid;
  place-items: center;
  min-height: 78px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  font-weight: 900;
}

.about-method-flow i {
  align-self: center;
  height: 2px;
  background: rgba(20, 20, 20, 0.2);
}

.about-method-flow span:nth-of-type(5) {
  grid-column: 1 / -1;
  background: var(--green-soft);
}

.about-contact-mini {
  position: absolute;
  inset: 38px;
  display: grid;
  gap: 14px;
  align-content: center;
}

.about-contact-mini span {
  padding: 18px 20px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.78);
  font-weight: 850;
}

.about-legal-entry-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 28px;
  margin-top: 48px;
}

.about-legal-entry {
  display: block;
  color: var(--ink);
}

.about-legal-entry h3 {
  margin: 0 0 8px;
  font-family: var(--display);
  font-size: 38px;
}

.about-legal-entry p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}

.about-legal-image {
  display: flex;
  align-items: center;
  min-height: 280px;
  padding: 46px;
}

.about-legal-copy {
  position: relative;
  z-index: 1;
  max-width: 560px;
}

.contact-ai-layout {
  grid-template-columns: minmax(360px, 0.9fr) minmax(460px, 1.1fr);
  gap: 56px;
  align-items: stretch;
}

.contact-directory-compact,
.contact-chat-panel {
  min-height: 670px;
}

.contact-directory-compact {
  padding: 36px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.68);
}

.contact-directory-compact .contact-qr-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.contact-directory-compact .contact-qr-card {
  padding: 10px;
}

.contact-directory-compact .contact-qr-card strong {
  font-size: 13px;
}

.contact-directory-compact .contact-qr-card span {
  font-size: 12px;
}

.contact-chat-panel {
  align-content: stretch;
}

.contact-ai-chat {
  min-height: 584px;
}

.footer-compact {
  width: min(var(--wide), calc(100% - 48px));
  padding: 72px 0 36px;
}

.footer-main-compact {
  display: grid;
  grid-template-columns: minmax(280px, 360px) minmax(0, 1fr);
  gap: 48px;
  align-items: start;
  padding-bottom: 42px;
}

.footer-brand-compact {
  display: grid;
  gap: 20px;
}

.footer-brand-compact p {
  max-width: 390px;
  margin: 0;
  color: rgba(247, 244, 238, 0.62);
  font-size: 14px;
}

.footer-mini-chat {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 38px;
  gap: 8px;
  max-width: 360px;
  padding: 7px;
  border: 1px solid rgba(247, 244, 238, 0.18);
  border-radius: 17px;
  background: rgba(255, 255, 255, 0.08);
}

.footer-mini-chat input {
  min-width: 0;
  border: 0;
  background: transparent;
  color: #f7f4ee;
  padding: 0 10px;
  font-size: 14px;
}

.footer-mini-chat input::placeholder {
  color: rgba(247, 244, 238, 0.55);
}

.footer-mini-chat button {
  width: 38px;
  height: 38px;
  border: 0;
  border-radius: 12px;
  background: var(--blue);
  color: #fff;
  font-size: 20px;
  line-height: 1;
}

.footer-mini-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.footer-mini-actions button {
  padding: 8px 12px;
  border: 1px solid rgba(247, 244, 238, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(247, 244, 238, 0.72);
  font-size: 13px;
  font-family: inherit;
  font-weight: 650;
  cursor: pointer;
}

.footer-mini-actions button:hover,
.footer-mini-actions button.active {
  border-color: rgba(247, 244, 238, 0.26);
  background: rgba(255, 255, 255, 0.14);
  color: #f7f4ee;
}

.footer-topic-panel {
  display: grid;
  gap: 10px;
  max-width: 360px;
  padding: 14px 16px;
  border: 1px solid rgba(247, 244, 238, 0.12);
  border-radius: 16px;
  background: rgba(0, 0, 0, 0.2);
}

.footer-topic-panel[hidden] {
  display: none;
}

.footer-topic-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.footer-topic-title {
  color: rgba(247, 244, 238, 0.7);
  font-size: 14px;
}

.footer-topic-close {
  width: 28px;
  height: 28px;
  border: 0;
  border-radius: 50%;
  background: transparent;
  color: rgba(247, 244, 238, 0.5);
  font-size: 22px;
  line-height: 1;
  cursor: pointer;
}

.footer-topic-close:hover {
  color: #f7f4ee;
}

.footer-topic-questions {
  display: grid;
}

.footer-topic-questions a {
  padding: 9px 0;
  border-top: 1px solid rgba(247, 244, 238, 0.12);
  color: rgba(247, 244, 238, 0.78);
  font-size: 13px;
  font-weight: 650;
  line-height: 1.45;
}

.footer-topic-questions a:first-child {
  border-top: 0;
}

.footer-topic-questions a:hover {
  color: #f7f4ee;
}

.footer-grid-compact {
  grid-template-columns: minmax(90px, 0.9fr) minmax(180px, 1.55fr) minmax(150px, 1.35fr) minmax(110px, 0.9fr) minmax(156px, 1fr);
  gap: 24px;
  padding-bottom: 0;
}

.footer-follow {
  display: grid;
  gap: 14px;
  justify-items: start;
  margin-top: 40px;
}

.footer-follow h3 {
  margin: 0;
  color: rgba(247, 244, 238, 0.92);
  font-size: 14px;
}

.footer-qr-row {
  display: flex;
  gap: 16px;
  width: max-content;
  transform: translateX(-120px);
}

.footer-qr-row article {
  display: grid;
  gap: 5px;
  justify-items: center;
  width: 80px;
  color: rgba(247, 244, 238, 0.72);
  font-size: 13px;
  text-align: center;
}

.footer-qr-row article span {
  margin: 0;
  white-space: nowrap;
}

.footer-qr-row img {
  width: 80px;
  height: 80px;
  padding: 5px;
  border-radius: 8px;
  background: #fff;
}

.footer-compact .footer-bottom {
  border-top: 1px solid rgba(247, 244, 238, 0.1);
  padding-top: 24px;
}

@media (max-width: 1080px) {
  .about-hero,
  .about-image-copy,
  .about-image-copy.reverse,
  .contact-ai-layout,
  .footer-main-compact {
    grid-template-columns: 1fr;
  }

  .about-hero-copy .display-title,
  .about-hero-copy .hero-lede {
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }

  .about-hero-copy {
    max-width: none;
  }

  .about-hero-copy .hero-actions {
    justify-content: center;
  }

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

@media (max-width: 760px) {
  .about-hero {
    padding-top: 64px;
  }

  .about-hero-image,
  .about-visual-frame {
    min-height: 340px;
  }

  .about-industry-grid,
  .about-legal-entry-grid,
  .contact-directory-compact .contact-qr-grid,
  .footer-grid-compact {
    grid-template-columns: 1fr;
  }

  .about-industry-card,
  .about-legal-entry {
    grid-template-rows: auto auto;
  }

  .about-method-flow {
    grid-template-columns: 1fr;
  }

  .about-method-flow i {
    width: 2px;
    height: 18px;
    justify-self: center;
  }

  .contact-directory-compact,
  .contact-chat-panel {
    min-height: auto;
  }

  .contact-ai-chat {
    min-height: 560px;
  }

  .footer-compact {
    width: min(100% - 36px, var(--wide));
  }

  .footer-qr-row {
    display: flex;
    transform: none;
  }
}

.ai-chat-widget {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto auto;
  min-height: 430px;
  border: 1px solid rgba(247, 244, 238, 0.14);
  border-radius: 24px;
  overflow: hidden;
  background: #171717;
  color: #f7f4ee;
  box-shadow: 0 28px 90px rgba(0, 0, 0, 0.32);
}

.chat-window-head {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  padding: 22px 22px 16px;
  border-bottom: 1px solid rgba(247, 244, 238, 0.1);
}

.chat-window-head h2 {
  margin: 4px 0 0;
  font-family: var(--display);
  font-size: 24px;
  line-height: 1.15;
}

.chat-kicker {
  color: rgba(247, 244, 238, 0.48);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
}

.chat-status {
  align-self: start;
  padding: 5px 9px;
  border: 1px solid rgba(7, 193, 96, 0.45);
  border-radius: 999px;
  color: #8bf0bd;
  font-size: 12px;
  white-space: nowrap;
}

.chat-close {
  width: 34px;
  height: 34px;
  border: 1px solid rgba(247, 244, 238, 0.14);
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  color: #f7f4ee;
  font-size: 22px;
  line-height: 1;
}

.chat-messages {
  display: flex;
  flex-direction: column;
  gap: 12px;
  min-height: 190px;
  max-height: 310px;
  padding: 18px;
  overflow: auto;
}

.chat-message {
  display: flex;
  max-width: 88%;
}

.chat-message.bot {
  align-self: flex-start;
}

.chat-message.user {
  align-self: flex-end;
}

.chat-bubble {
  padding: 12px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(247, 244, 238, 0.9);
  font-size: 14px;
  line-height: 1.55;
}

.chat-message.user .chat-bubble {
  background: #daf7e8;
  color: #0f2d1d;
}

.chat-message[data-chat-pending="true"] .chat-bubble {
  color: rgba(247, 244, 238, 0.62);
}

.chat-bubble p {
  margin: 0;
  white-space: pre-wrap;
}

.chat-content p + p {
  margin-top: 10px;
}

.chat-speaker {
  display: block;
  margin-bottom: 4px;
  color: #8bf0bd;
  font-size: 12px;
  font-weight: 800;
}

.chat-quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 0 18px 16px;
}

.chat-quick-actions button {
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid rgba(247, 244, 238, 0.13);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.05);
  color: rgba(247, 244, 238, 0.76);
  font-size: 13px;
}

.chat-quick-actions button:hover {
  border-color: rgba(139, 240, 189, 0.5);
  color: #f7f4ee;
}

.chat-input-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  padding: 16px 18px 18px;
  border-top: 1px solid rgba(247, 244, 238, 0.1);
}

.chat-input-row input {
  min-width: 0;
  min-height: 46px;
  padding: 0 14px;
  border: 1px solid rgba(247, 244, 238, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: #f7f4ee;
}

.chat-input-row input::placeholder {
  color: rgba(247, 244, 238, 0.45);
}

.chat-input-row button {
  min-height: 46px;
  padding: 0 18px;
  border: 0;
  border-radius: 999px;
  background: var(--green);
  color: #062817;
  font-weight: 850;
}

.ai-chat-overlay {
  position: fixed;
  inset: 0;
  z-index: 90;
  display: none;
}

.ai-chat-overlay.show {
  display: block;
}

.ai-chat-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(12, 12, 12, 0.48);
  backdrop-filter: blur(6px);
}

.ai-chat-drawer {
  position: absolute;
  right: 28px;
  bottom: 28px;
  width: min(440px, calc(100% - 40px));
  max-height: calc(100vh - 56px);
}

.footer-with-chat {
  width: min(var(--wide), calc(100% - 48px));
  padding: 86px 0 42px;
}

.footer-main {
  display: grid;
  grid-template-columns: minmax(360px, 470px) minmax(0, 1fr);
  gap: 86px;
  align-items: start;
  padding-bottom: 58px;
}

.footer-main.footer-main-compact {
  padding-bottom: 31px;
}

.footer-brand-panel {
  display: grid;
  gap: 22px;
}

.footer-logo {
  display: inline-grid;
  gap: 6px;
  justify-items: start;
}

.footer-brand-panel p {
  max-width: 450px;
  margin: 0;
  color: rgba(247, 244, 238, 0.62);
  font-size: 15px;
}

.footer-chat {
  min-height: 408px;
}

.footer-links-panel {
  min-width: 0;
}

.footer-with-chat .footer-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(118px, 1fr));
  gap: 34px;
  padding: 4px 0 34px;
}

.footer-with-chat .footer-col h3 {
  margin-bottom: 16px;
  color: rgba(247, 244, 238, 0.92);
}

.footer-with-chat .footer-col a,
.footer-with-chat .footer-col span {
  margin: 10px 0;
}

.footer-contact-line {
  color: rgba(247, 244, 238, 0.6);
  font-size: 14px;
}

.footer-social {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}

.footer-social span {
  margin: 0;
  padding: 7px 9px;
  border: 1px solid rgba(247, 244, 238, 0.12);
  border-radius: 999px;
  color: rgba(247, 244, 238, 0.66);
  font-size: 12px;
}

.footer-with-chat .footer-bottom {
  border-top: 1px solid rgba(247, 244, 238, 0.1);
  padding-top: 26px;
}

.contact-ai-section {
  padding-top: 24px;
}

.contact-ai-layout {
  display: grid;
  grid-template-columns: minmax(320px, 0.86fr) minmax(0, 1.14fr);
  gap: 72px;
  align-items: start;
}

.contact-directory {
  display: grid;
  gap: 26px;
}

.contact-directory h2,
.contact-chat-panel h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(34px, 4vw, 54px);
  line-height: 1.08;
}

.contact-directory p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}

.contact-info-list {
  display: grid;
  gap: 12px;
}

.contact-info-list a,
.contact-info-list span {
  display: grid;
  gap: 4px;
  padding: 16px 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
}

.contact-info-list small {
  color: var(--muted-2);
  font-size: 13px;
  font-weight: 800;
}

.contact-info-list strong {
  font-size: 18px;
}

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

.contact-qr-card {
  display: grid;
  gap: 10px;
  padding: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
}

.contact-qr-card img {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 10px;
  background: #fff;
}

.contact-qr-card strong {
  font-size: 15px;
}

.contact-qr-card span {
  color: var(--muted);
  font-size: 13px;
}

.contact-chat-panel {
  display: grid;
  gap: 22px;
}

.contact-ai-chat {
  min-height: 620px;
  background: #111;
}

.contact-ai-chat .chat-messages {
  max-height: 430px;
}

.about-contact-grid,
.privacy-summary-grid,
.failure-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  margin-top: 42px;
}

.about-contact-card,
.privacy-summary-card,
.failure-card {
  padding: 24px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.68);
}

.about-contact-card h3,
.privacy-summary-card h3,
.failure-card h3 {
  margin: 0 0 10px;
  font-family: var(--display);
  font-size: 26px;
  line-height: 1.15;
}

.about-contact-card p,
.privacy-summary-card p,
.failure-card p {
  margin: 0;
  color: var(--muted);
}

.about-legal-note {
  margin-top: 42px;
  padding: 28px;
  border: 1px solid var(--line);
  border-radius: 22px;
  background: var(--paper);
}

.about-legal-note p {
  margin: 0;
  color: var(--muted);
  font-size: 18px;
}

.legal .legal-date {
  margin-top: -24px;
  margin-bottom: 38px;
  color: var(--muted-2);
  font-weight: 700;
}

.legal ul {
  margin: 12px 0 0;
  padding-left: 22px;
}

@media (max-width: 1080px) {
  .footer-main,
  .contact-ai-layout {
    grid-template-columns: 1fr;
    gap: 48px;
  }

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

  .footer-brand-panel p {
    max-width: 680px;
  }

  .about-contact-grid,
  .privacy-summary-grid,
  .failure-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .footer-with-chat {
    width: min(100% - 36px, var(--wide));
    padding-top: 58px;
  }

  .footer-main {
    gap: 38px;
  }

  .footer-with-chat .footer-grid,
  .about-contact-grid,
  .privacy-summary-grid,
  .failure-grid,
  .contact-qr-grid {
    grid-template-columns: 1fr;
  }

  .ai-chat-widget,
  .footer-chat,
  .contact-ai-chat {
    min-height: 520px;
  }

  .chat-messages,
  .contact-ai-chat .chat-messages {
    max-height: 340px;
  }

  .chat-window-head,
  .chat-input-row {
    padding-left: 16px;
    padding-right: 16px;
  }

  .chat-input-row {
    grid-template-columns: 1fr;
  }

  .ai-chat-drawer {
    right: 18px;
    bottom: 18px;
    width: calc(100% - 36px);
  }

  .footer-with-chat .footer-bottom {
    display: grid;
    gap: 12px;
  }
}

/* Final about, contact and footer alignment refinements */
.about-company-page .hero {
  padding-bottom: 36px;
}

.about-company-hero .hero-narrow {
  text-align: center;
}

.about-company-hero .module-eyebrow {
  display: inline-flex;
  margin-bottom: 16px;
}

.about-company-hero .hero-actions {
  justify-content: center;
}

.about-company-statement {
  padding-top: 26px;
}

.about-editorial-panel {
  display: grid;
  grid-template-columns: minmax(320px, 0.9fr) minmax(0, 1.1fr);
  gap: 72px;
  align-items: center;
}

.about-company-portrait {
  min-height: 460px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.86), rgba(255, 255, 255, 0.55)),
    linear-gradient(135deg, var(--blue-soft), var(--paper) 48%, var(--orange-soft));
}

.about-portrait-grid {
  position: absolute;
  inset: 36px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.about-portrait-grid span {
  display: grid;
  place-items: center;
  min-height: 130px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--ink);
  font-weight: 850;
  text-align: center;
}

.about-editorial-copy p,
.about-method-section .about-copy-block p,
.about-contact-preview .about-copy-block p {
  color: var(--muted);
  font-size: 18px;
  line-height: 1.82;
}

.about-belief-section {
  background: linear-gradient(180deg, rgba(244, 240, 234, 0.62), rgba(251, 250, 247, 0));
}

.about-contact-list {
  display: grid;
  gap: 12px;
  margin: 28px 0 8px;
}

.about-contact-list a {
  display: grid;
  gap: 4px;
  padding: 14px 0;
  border-bottom: 1px solid var(--line);
  color: var(--ink);
}

.about-contact-list small {
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 850;
}

.about-contact-list strong {
  font-size: 18px;
}

.about-legal-entry-section .section-heading {
  max-width: 820px;
  margin: 0 auto;
  text-align: center;
}

.about-legal-entry-section .about-legal-entry-grid {
  margin-top: 42px;
}

.contact-ai-layout {
  grid-template-columns: minmax(360px, 0.95fr) minmax(480px, 1.05fr);
  gap: 54px;
  align-items: stretch;
}

.contact-directory-compact,
.contact-chat-panel {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 22px;
  min-height: auto;
}

.contact-directory-compact {
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

.contact-side-card {
  display: grid;
  align-content: start;
  gap: 26px;
  min-height: 640px;
  padding: 34px;
  border: 1px solid var(--line);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
}

.contact-chat-panel .contact-ai-chat {
  min-height: 640px;
  height: 100%;
}

.contact-directory-compact .contact-qr-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.contact-directory-compact .contact-qr-card {
  padding: 10px;
}

.contact-directory-compact .contact-qr-card strong {
  font-size: 13px;
}

.contact-directory-compact .contact-qr-card span {
  font-size: 12px;
}

.footer-brand-compact {
  gap: 16px;
  align-content: start;
}

.footer-logo-single {
  display: inline-flex;
  align-items: flex-end;
  gap: 9px;
  width: max-content;
  max-width: 100%;
  color: #f7f4ee;
  white-space: nowrap;
}

.footer-logo-mark {
  display: block;
  width: 34px;
  height: 34px;
  flex: 0 0 auto;
}

.footer-logo-single .footer-brand {
  font-size: 24px;
  font-weight: 780;
  line-height: 0.95;
  margin-bottom: 5px;
}

.footer-logo-single span:last-child {
  color: rgba(247, 244, 238, 0.92);
  font-size: 14px;
  font-weight: 760;
  line-height: 1;
  margin-bottom: 5px;
}

.footer-brand-compact p {
  display: none;
}

.footer-mini-chat {
  margin-top: 2px;
}

.footer-mini-chat button {
  background: var(--blue);
  color: #fff;
}

.chat-input-row button {
  background: var(--blue);
  color: #fff;
}

@media (max-width: 1080px) {
  .about-editorial-panel,
  .contact-ai-layout {
    grid-template-columns: 1fr;
  }

  .contact-side-card,
  .contact-chat-panel .contact-ai-chat {
    min-height: 560px;
  }
}

@media (max-width: 720px) {
  .about-editorial-panel {
    gap: 36px;
  }

  .about-company-portrait {
    min-height: 340px;
  }

  .about-portrait-grid {
    inset: 18px;
    grid-template-columns: 1fr;
  }

  .about-portrait-grid span {
    min-height: 62px;
  }

  .contact-side-card,
  .contact-chat-panel .contact-ai-chat {
    min-height: 520px;
  }

  .contact-directory-compact .contact-qr-grid {
    grid-template-columns: 1fr;
  }

  .footer-logo-single {
    white-space: normal;
  }
}

@media (min-width: 901px) and (max-width: 1080px) {
  .contact-ai-layout {
    grid-template-columns: minmax(320px, 0.95fr) minmax(420px, 1.05fr);
    gap: 32px;
  }
}

@media (max-width: 900px) {
  .contact-ai-layout {
    grid-template-columns: 1fr;
  }
}

/* About page v2: Claude-style company narrative with reserved visual slots */
.about-company-hero-v2 {
  padding: 92px 0 124px;
}

.about-company-hero-copy {
  max-width: 1120px;
}

.about-company-hero-copy .display-title {
  max-width: 1120px;
  font-size: clamp(56px, 7.2vw, 104px);
  line-height: 0.96;
}

.about-company-hero-copy .title-line {
  display: block;
}

.about-company-hero-v2 .module-eyebrow {
  display: inline-flex;
  margin-bottom: 16px;
}

.about-company-hero-v2 .hero-actions,
.about-company-hero-v2 .about-anchor-row {
  justify-content: center;
}

.about-company-hero-copy .hero-lede-line {
  white-space: nowrap;
}

.about-company-module-section figcaption {
  position: relative;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  min-height: 34px;
  margin: 0;
  padding: 0 13px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--muted);
  font-size: 12px;
  font-weight: 800;
}

.about-company-module-section {
  padding: 124px 0;
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

.about-company-statement {
  padding-top: 124px;
}

.about-company-module-section .about-editorial-panel,
.about-company-module-section .about-image-copy,
.about-company-module-section .about-image-copy.reverse {
  width: min(var(--wide), calc(100% - 48px));
  height: 660px;
  min-height: 660px;
  max-width: none;
  margin: 0 auto;
  padding: 34px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 34px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 22px 72px rgba(30, 25, 20, 0.08);
}

.about-company-module-section .about-editorial-panel,
.about-company-module-section .about-image-copy {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: minmax(0, 1fr);
  gap: 46px;
  align-items: stretch;
}

.about-company-module-section .about-image-copy.reverse {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.about-company-module-section .about-copy-block,
.about-company-module-section .about-editorial-copy {
  display: grid;
  align-content: center;
  height: 100%;
  min-height: 0;
}

.about-company-module-section .about-copy-block p,
.about-company-module-section .about-editorial-copy p {
  max-width: 620px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.72;
}

.about-company-module-section .about-visual-frame {
  height: 100%;
  min-height: 0;
  border-radius: 28px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, #f4f0ea 0%, #ffffff 54%, #edf4ff 100%);
  background-size: 34px 34px, 34px 34px, auto;
}

.about-company-module-section .about-company-portrait {
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, var(--blue-soft), #fff 48%, var(--green-soft));
}

.about-company-module-section .about-failure-image {
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, #f4f0ea, #fff 48%, var(--orange-soft));
}

.about-company-module-section .about-method-image {
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.03) 1px, transparent 1px),
    linear-gradient(135deg, var(--green-soft), #fff 48%, var(--blue-soft));
}

.about-company-module-section .about-portrait-grid,
.about-company-module-section .about-failure-stack,
.about-company-module-section .about-method-flow {
  inset: 92px 38px 38px;
}

.about-company-module-section .about-point-list p {
  padding: 16px 0;
  font-size: 17px;
  line-height: 1.62;
}

.about-legal-entry-section {
  padding-top: 124px;
  padding-bottom: 124px;
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

.about-final-cta {
  padding-top: 124px;
  padding-bottom: 124px;
  border-top: 1px solid rgba(20, 20, 20, 0.055);
}

.about-final-cta .section-title,
.about-final-cta .section-lede {
  margin-right: auto;
  margin-left: auto;
  text-align: center;
}

.about-final-cta .section-title {
  white-space: nowrap;
}

.about-final-cta .title-line {
  display: block;
}

.about-final-cta .section-actions {
  justify-content: center;
}

@media (max-width: 900px) {
  .about-company-module-section .about-editorial-panel,
  .about-company-module-section .about-image-copy,
  .about-company-module-section .about-image-copy.reverse {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    height: auto;
    min-height: auto;
    gap: 28px;
  }

  .about-company-module-section .about-copy-block,
  .about-company-module-section .about-editorial-copy {
    height: auto;
    min-height: auto;
  }

  .about-company-module-section .about-visual-frame {
    height: auto;
    min-height: 360px;
  }

  .about-company-module-section .about-portrait-grid,
  .about-company-module-section .about-failure-stack,
  .about-company-module-section .about-method-flow,
  .about-company-module-section .about-capability-map,
  .about-company-module-section .about-ai-diagnosis,
  .about-company-module-section .about-delivery-loop {
    inset: 74px 24px 24px;
  }

  .about-capability-map {
    gap: 10px;
    padding-top: 0;
  }

  .about-capability-map article {
    padding: 14px;
    border-radius: 16px;
  }

  .about-capability-map article strong {
    font-size: 22px;
  }

  .capability-center {
    top: 50%;
    width: 132px;
    min-height: 76px;
    padding: 12px;
  }

  .capability-center strong {
    font-size: 13px;
  }

  .about-ai-diagnosis {
    grid-template-columns: minmax(0, 1fr) 76px minmax(0, 1fr);
    gap: 8px;
    padding-top: 0;
  }

  .diagnosis-column {
    gap: 8px;
  }

  .diagnosis-column span {
    border-radius: 12px;
    font-size: 13px;
  }

  .diagnosis-pivot {
    gap: 8px;
    padding-top: 32px;
  }

  .diagnosis-pivot i {
    height: 70px;
  }

  .diagnosis-pivot strong {
    min-height: 82px;
    padding: 10px;
    border-radius: 14px;
    font-size: 16px;
  }

  .about-delivery-loop {
    display: grid;
    gap: 8px;
    padding-top: 0;
  }

  .delivery-loop-center,
  .delivery-loop-track {
    display: none;
  }

  .delivery-step {
    position: static;
    width: auto;
    min-height: 0;
    padding: 11px 12px;
    transform: none !important;
  }

  .about-company-module-section .about-portrait-grid span,
  .about-company-module-section .about-failure-stack span,
  .about-company-module-section .about-failure-stack strong {
    min-height: 86px;
    font-size: 20px;
  }
}

@media (max-width: 720px) {
  .about-company-hero-v2 {
    width: min(100% - 36px, var(--wide));
    padding: 70px 0 96px;
  }

  .about-company-hero-copy .display-title {
    font-size: clamp(42px, 11vw, 62px);
  }

  .about-company-hero-copy .hero-lede-line {
    white-space: normal;
  }

  .about-final-cta .section-title {
    white-space: normal;
  }

  .about-company-module-section .about-portrait-grid,
  .about-company-module-section .about-failure-stack,
  .about-company-module-section .about-method-flow,
  .about-company-module-section .about-capability-map,
  .about-company-module-section .about-ai-diagnosis,
  .about-company-module-section .about-delivery-loop {
    inset: 74px 18px 18px;
  }

  .about-company-module-section {
    padding: 96px 0;
  }

  .about-legal-entry-section,
  .about-final-cta {
    padding-top: 96px;
    padding-bottom: 96px;
  }

  .about-company-module-section .about-editorial-panel,
  .about-company-module-section .about-image-copy,
  .about-company-module-section .about-image-copy.reverse {
    width: min(100% - 36px, var(--wide));
    padding: 18px;
    border-radius: 26px;
  }

  .about-company-module-section .about-visual-frame {
    min-height: 380px;
    border-radius: 22px;
  }
}

/* Keep secondary page hero titles aligned with the homepage hero scale. */
.about-company-hero-copy .display-title.page-title,
.service-page .display-title.page-title,
.service-hero-copy .display-title.page-title,
.cases-page .display-title.page-title {
  max-width: 1120px;
  margin-right: auto;
  margin-left: auto;
  font-size: clamp(50px, 5.8vw, 86px);
  font-weight: 650;
  line-height: 1.08;
  letter-spacing: 0;
}

.about-company-hero-copy .page-title .title-line,
.service-hero-copy .page-title .title-line,
.case-hero .page-title .title-line {
  display: block;
  white-space: nowrap;
}

.cases-page .case-hero .hero-lede {
  font-size: clamp(18px, 1.45vw, 22px);
  line-height: 1.48;
}

@media (max-width: 720px) {
  .about-company-hero-copy .display-title.page-title,
  .service-page .display-title.page-title,
  .service-hero-copy .display-title.page-title,
  .cases-page .display-title.page-title {
    font-size: clamp(34px, 7.2vw, 42px);
    line-height: 1.12;
  }

  .cases-page .case-hero .hero-lede {
    font-size: 18px;
  }

  .case-hero .page-title .title-line {
    white-space: normal;
  }
}

/* Service hero consulting graphic: keep the case-page module scale with a left / center / right structure. */
.service-page .service-hero-stage {
  grid-template-columns: minmax(250px, 0.92fr) minmax(0, 1.26fr) minmax(230px, 0.78fr);
  gap: 22px;
  height: 660px;
  min-height: 660px;
  border: 0;
}

.service-page .service-hero-stage::before {
  content: none;
}

.service-page .service-stage-top span:nth-child(1) {
  border-color: rgba(201, 121, 16, 0.18);
  background: rgba(255, 241, 216, 0.9);
  color: #8a5a16;
}

.service-page .service-stage-top span:nth-child(2) {
  border-color: rgba(47, 102, 234, 0.16);
  background: rgba(232, 242, 255, 0.9);
  color: #315d9a;
}

.service-page .service-stage-top span:nth-child(3) {
  border-color: rgba(103, 142, 97, 0.18);
  background: rgba(232, 246, 229, 0.9);
  color: #3d6437;
}

.service-page .service-command-card,
.service-page .service-orbit-map,
.service-page .service-result-stack {
  align-self: end;
  height: 540px;
  min-height: 540px;
}

.service-page .service-command-card {
  display: grid;
  grid-template-rows: auto auto;
  align-content: center;
  gap: 46px;
  padding: 30px 28px;
}

.service-page .service-command-card strong {
  max-width: 340px;
  font-size: clamp(28px, 2.35vw, 38px);
}

.service-diagnosis-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.service-diagnosis-list span {
  display: grid;
  place-items: center;
  min-height: 34px;
  border: 1px solid rgba(248, 246, 240, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(248, 246, 240, 0.82);
  font-size: 12px;
  font-weight: 850;
  white-space: nowrap;
}

.service-page .service-orbit-map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: 124px 126px 124px;
  gap: 22px 24px;
  align-content: center;
  padding: 30px 24px;
  overflow: hidden;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(20, 20, 20, 0.08) calc(50% - 1px), rgba(20, 20, 20, 0.08) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(20, 20, 20, 0.08) calc(50% - 1px), rgba(20, 20, 20, 0.08) calc(50% + 1px), transparent calc(50% + 1px)),
    rgba(255, 255, 255, 0.66);
}

.service-method-source,
.service-method-core,
.service-result-stack article {
  position: relative;
  z-index: 1;
  border: 1px solid rgba(20, 20, 20, 0.08);
  box-shadow: 0 14px 38px rgba(33, 29, 23, 0.08);
}

.service-method-source {
  display: grid;
  gap: 8px;
  align-content: center;
  min-height: 0;
  padding: 18px 20px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.82);
}

.service-method-benchmark-one {
  grid-column: 1;
  grid-row: 1;
  background: linear-gradient(135deg, #fff1d8, rgba(255, 255, 255, 0.88));
}

.service-method-benchmark-two {
  grid-column: 2;
  grid-row: 1;
  background: linear-gradient(135deg, #fff7e8, rgba(255, 255, 255, 0.9));
}

.service-method-business-one {
  grid-column: 1;
  grid-row: 3;
  background: linear-gradient(135deg, #e8f2ff, rgba(255, 255, 255, 0.9));
}

.service-method-business-two {
  grid-column: 2;
  grid-row: 3;
  background: linear-gradient(135deg, #e8f2ff, rgba(255, 255, 255, 0.9));
}

.service-method-benchmark-two,
.service-method-business-two {
  justify-items: end;
  text-align: right;
}

.service-method-source small,
.service-method-core small {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: fit-content;
  min-height: 24px;
  padding: 0 10px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.service-method-benchmark small {
  border-color: rgba(201, 121, 16, 0.15);
  background: rgba(255, 247, 232, 0.88);
  color: #9b671e;
}

.service-method-business small {
  border-color: rgba(47, 102, 234, 0.15);
  background: rgba(235, 245, 255, 0.9);
  color: #315d9a;
}

.service-method-core small {
  justify-self: center;
  border-color: rgba(87, 81, 73, 0.12);
  background: rgba(255, 255, 255, 0.76);
}

.service-method-source strong,
.service-method-core strong {
  color: var(--ink);
  font-size: 20px;
  font-weight: 950;
  line-height: 1.08;
}

.service-method-source span,
.service-method-core span {
  color: var(--muted);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.32;
}

.service-method-core {
  grid-column: 1 / -1;
  grid-row: 2;
  justify-self: center;
  align-self: center;
  display: grid;
  gap: 6px;
  width: min(252px, 70%);
  min-height: 126px;
  padding: 18px 24px;
  border-radius: 28px;
  background:
    radial-gradient(circle at 85% 18%, rgba(47, 102, 234, 0.14), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.96), #fff8ed);
  text-align: center;
}

.service-method-core strong {
  font-family: var(--display);
  font-size: clamp(24px, 1.8vw, 29px);
  font-weight: 700;
}

.service-method-flow {
  display: none;
  position: absolute;
  inset: 28px;
  z-index: 0;
  pointer-events: none;
}

.service-method-flow i {
  position: absolute;
  display: block;
  min-height: 0;
  border: 0;
  border-radius: 999px;
  background: rgba(20, 20, 20, 0.12) !important;
  box-shadow: none;
}

.service-method-flow i:nth-child(1) {
  top: 195px;
  left: 20%;
  width: 60%;
  height: 1px;
}

.service-method-flow i:nth-child(2) {
  top: 194px;
  left: 31%;
  width: 1px;
  height: 76px;
}

.service-method-flow i:nth-child(3) {
  top: 194px;
  right: 31%;
  width: 1px;
  height: 76px;
}

.service-method-flow i:nth-child(4) {
  top: 345px;
  left: 20%;
  width: 60%;
  height: 1px;
}

.service-page .service-result-stack {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.service-result-stack article {
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: auto 1fr;
  gap: 10px;
  align-items: stretch;
  min-height: 0;
  overflow: hidden;
  padding: 14px 14px 13px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
}

.service-result-graphic {
  display: grid;
  align-items: center;
  height: 82px;
  min-width: 0;
  overflow: hidden;
  padding: 10px 12px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 18px;
  background: linear-gradient(135deg, var(--result-soft), rgba(255, 255, 255, 0.92));
}

.service-result-graphic span {
  min-height: auto;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
  font-family: var(--body);
  line-height: 1.1;
}

.service-result-copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 3px;
  min-width: 0;
}

.service-result-stack small {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  min-height: 22px;
  padding: 0 9px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.8);
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
}

.service-result-stack strong {
  display: block;
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(21px, 1.55vw, 25px);
  font-weight: 700;
  line-height: 1.02;
  white-space: nowrap;
}

.service-result-skill {
  --result-soft: #fff0dc;
  --result-accent: #d38a31;
}

.service-result-app {
  --result-soft: #eee7ff;
  --result-accent: #7258d8;
}

.service-result-review {
  --result-soft: #ffe8f0;
  --result-accent: #d96f9a;
}

.service-result-skill small {
  border-color: rgba(211, 138, 49, 0.18);
  background: rgba(255, 245, 229, 0.9);
  color: #9b671e;
}

.service-result-app small {
  border-color: rgba(114, 88, 216, 0.16);
  background: rgba(242, 237, 255, 0.9);
  color: #6047c4;
}

.service-result-review small {
  border-color: rgba(217, 111, 154, 0.16);
  background: rgba(255, 238, 244, 0.92);
  color: #bb527c;
}

.service-result-skill .service-result-graphic {
  grid-template-columns: 122px 28px 66px;
  justify-content: center;
  gap: 7px;
}

.skill-source-list {
  display: grid;
  gap: 6px;
  align-content: center;
  min-width: 0;
}

.skill-source-list span,
.app-interface span,
.review-signal-grid span {
  display: grid;
  place-items: center;
  min-height: 17px;
  padding: 0 6px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.84);
  color: var(--result-accent);
  font-size: 10px;
  font-weight: 900;
  white-space: nowrap;
}

.service-result-skill .service-result-graphic > i {
  justify-self: center;
  align-self: center;
  width: 24px;
  height: 2px;
  background: var(--result-accent);
  opacity: 0.42;
}

.skill-callable {
  display: grid;
  place-items: center;
  align-self: center;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 0 0 9px rgba(211, 138, 49, 0.22);
  text-align: center;
}

.skill-callable b,
.agent-token b,
.review-skill-call b {
  color: var(--ink);
  font-size: 13px;
  font-weight: 950;
  line-height: 1;
}

.skill-callable span,
.review-skill-call span,
.agent-token span {
  color: var(--ink);
  font-size: 9px;
  font-weight: 760;
}

.service-result-app .service-result-graphic {
  grid-template-columns: 58px 150px;
  justify-content: center;
  gap: 10px;
}

.agent-token {
  display: grid;
  place-items: center;
  align-self: center;
  width: 54px;
  height: 58px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
}

.agent-token::before {
  display: block;
  width: 24px;
  height: 24px;
  margin-bottom: -7px;
  border-radius: 50%;
  background: rgba(114, 88, 216, 0.36);
  content: "";
}

.agent-token b {
  color: var(--result-accent);
  font-size: 11px;
}

.app-interface {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-self: center;
  gap: 6px;
  min-height: 58px;
  padding: 8px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.58);
}

.service-result-review .service-result-graphic {
  grid-template-columns: 118px 34px 58px;
  justify-content: center;
  gap: 7px;
}

.review-signal-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-content: center;
  gap: 6px;
}

.review-check {
  display: grid;
  place-items: center;
  align-self: center;
  width: 34px;
  height: 34px;
  border: 6px solid rgba(217, 111, 154, 0.22);
  border-radius: 50%;
}

.review-check i {
  width: 14px;
  height: 9px;
  border-bottom: 4px solid var(--result-accent);
  border-left: 4px solid var(--result-accent);
  transform: rotate(-45deg);
}

.review-skill-call {
  display: grid;
  place-items: center;
  align-self: center;
  width: 56px;
  height: 58px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.74);
  text-align: center;
}

@media (max-width: 1180px) {
  .service-page .service-hero-stage {
    grid-template-columns: 1fr;
    height: auto;
    min-height: 0;
  }

  .service-page .service-command-card,
  .service-page .service-orbit-map,
  .service-page .service-result-stack {
    height: auto;
    min-height: auto;
  }

  .service-page .service-command-card {
    min-height: 300px;
  }

  .service-page .service-result-stack {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

@media (max-width: 820px) {
  .service-page .service-orbit-map,
  .service-page .service-result-stack,
  .service-diagnosis-list {
    grid-template-columns: 1fr;
  }

  .service-method-core {
    grid-column: auto;
    grid-row: auto;
    width: 100%;
  }

  .service-method-benchmark,
  .service-method-business {
    grid-column: auto;
    grid-row: auto;
  }

  .service-method-flow {
    display: none;
  }
}

/* Contact page: make the AI advisor the primary action while keeping official contact entries compact. */
.contact-ai-priority-layout {
  display: grid;
  width: min(1120px, calc(100% - 48px));
  grid-template-columns: 1fr;
  gap: 46px;
}

.contact-support-panel {
  max-width: 1040px;
  margin: 0 auto;
}

.contact-support-heading {
  max-width: 720px;
  margin: 0 auto;
  text-align: center;
}

.contact-support-heading h2,
.contact-chat-primary > h2 {
  font-size: clamp(32px, 3.6vw, 50px);
}

.contact-support-heading p {
  margin-top: 14px;
  color: var(--muted);
  font-size: 17px;
}

.contact-support-panel .contact-side-card {
  display: grid;
  grid-template-columns: minmax(230px, 0.72fr) minmax(0, 1.28fr);
  gap: 28px;
  align-items: center;
  min-height: auto;
  margin-top: 24px;
  padding: 24px;
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.72);
}

.contact-support-panel .contact-info-list {
  gap: 0;
}

.contact-support-panel .contact-info-list a,
.contact-support-panel .contact-info-list span {
  padding: 12px 0;
}

.contact-support-panel .contact-info-list a:first-child,
.contact-support-panel .contact-info-list span:first-child {
  padding-top: 0;
}

.contact-support-panel .contact-info-list a:last-child,
.contact-support-panel .contact-info-list span:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.contact-support-panel .contact-info-list strong {
  font-size: 16px;
  line-height: 1.35;
}

.contact-support-panel .contact-qr-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}

.contact-support-panel .contact-qr-card {
  justify-items: center;
  gap: 8px;
  padding: 12px;
  text-align: center;
}

.contact-support-panel .contact-qr-card img {
  width: min(100%, 118px);
}

.contact-support-panel .contact-qr-card strong {
  font-size: 13px;
}

.contact-support-panel .contact-qr-card span {
  font-size: 12px;
}

.contact-chat-primary {
  width: min(900px, calc(100% - 96px));
  margin: 0 auto;
  gap: 22px;
}

.contact-chat-primary > h2 {
  text-align: center;
}

.contact-chat-panel.contact-chat-primary .contact-ai-chat {
  width: 100%;
  min-height: 640px;
  height: auto;
  border-radius: 28px;
}

.contact-chat-panel.contact-chat-primary .contact-ai-chat .chat-messages {
  max-height: 430px;
}

@media (max-width: 900px) {
  .contact-ai-priority-layout {
    width: min(100% - 48px, 1120px);
    gap: 38px;
  }

  .contact-support-panel .contact-side-card {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 720px) {
  .contact-ai-priority-layout {
    width: min(100% - 36px, 1120px);
    gap: 32px;
  }

  .contact-support-heading {
    text-align: left;
  }

  .contact-support-heading h2,
  .contact-chat-primary > h2 {
    font-size: 32px;
  }

  .contact-support-heading p {
    font-size: 16px;
  }

  .contact-support-panel .contact-side-card {
    padding: 18px;
    border-radius: 22px;
  }

  .contact-support-panel .contact-qr-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 8px;
  }

  .contact-support-panel .contact-qr-card {
    padding: 8px;
  }

  .contact-support-panel .contact-qr-card img {
    width: min(100%, 78px);
  }

  .contact-support-panel .contact-qr-card strong {
    font-size: 12px;
  }

  .contact-support-panel .contact-qr-card span {
    display: none;
  }

  .contact-chat-panel.contact-chat-primary .contact-ai-chat {
    min-height: 540px;
    border-radius: 24px;
  }

  .contact-chat-primary {
    width: min(480px, calc(100% - 36px));
  }
}

/* Contact page final order: AI chat first, large QR codes second, contact strip last. */
.contact-ai-priority-layout {
  gap: 42px;
}

.contact-support-panel {
  width: min(980px, 100%);
}

.contact-support-panel .contact-side-card {
  grid-template-columns: 1fr;
  gap: 24px;
  margin-top: 0;
  padding: 28px;
}

.contact-support-panel .contact-qr-grid {
  gap: 18px;
}

.contact-support-panel .contact-qr-card {
  padding: 16px;
  border-radius: 20px;
}

.contact-support-panel .contact-qr-card img {
  width: min(100%, 180px);
}

.contact-support-panel .contact-qr-card strong {
  font-size: 15px;
}

.contact-support-panel .contact-qr-card span {
  font-size: 13px;
}

.contact-info-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0;
  padding: 18px 24px;
  border: 1px solid rgba(20, 20, 20, 0.12);
  border-radius: 999px;
  background: #111;
  color: #f7f4ee;
}

.contact-support-panel .contact-info-strip a,
.contact-support-panel .contact-info-strip span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 22px;
  border-right: 1px solid rgba(247, 244, 238, 0.22);
  border-bottom: 0;
  color: #f7f4ee;
  white-space: nowrap;
}

.contact-support-panel .contact-info-strip a:last-child,
.contact-support-panel .contact-info-strip span:last-child {
  border-right: 0;
}

.contact-support-panel .contact-info-strip small {
  color: var(--blue);
  font-size: 13px;
  font-weight: 850;
}

.contact-support-panel .contact-info-strip strong {
  color: #f7f4ee;
  font-size: 16px;
  font-weight: 760;
}

.contact-chat-primary {
  gap: 0;
}

@media (max-width: 720px) {
  .contact-ai-priority-layout {
    gap: 30px;
  }

  .contact-support-panel .contact-side-card {
    padding: 16px;
  }

  .contact-support-panel .contact-qr-grid {
    gap: 10px;
  }

  .contact-support-panel .contact-qr-card {
    padding: 10px 8px;
  }

  .contact-support-panel .contact-qr-card img {
    width: min(100%, 140px);
  }

  .contact-support-panel .contact-qr-card strong {
    font-size: 12px;
  }

  .contact-support-panel .contact-qr-card span {
    display: none;
  }

  .contact-info-strip {
    display: grid;
    justify-content: stretch;
    gap: 10px;
    padding: 16px 18px;
    border-radius: 22px;
  }

  .contact-support-panel .contact-info-strip a,
  .contact-support-panel .contact-info-strip span {
    justify-content: space-between;
    gap: 14px;
    padding: 0;
    border-right: 0;
    white-space: normal;
  }

  .contact-support-panel .contact-info-strip strong {
    text-align: right;
    font-size: 14px;
  }
}

/* Contact page harmony pass: keep the assistant dominant and make contact entries feel auxiliary. */
.contact-ai-section {
  padding-top: 8px;
  padding-bottom: 88px;
}

.contact-ai-priority-layout {
  width: min(980px, calc(100% - 48px));
  gap: 30px;
}

.contact-chat-primary {
  width: min(920px, 100%);
}

.contact-chat-panel.contact-chat-primary .contact-ai-chat {
  min-height: 720px;
  border-radius: 32px;
  box-shadow: 0 34px 90px rgba(20, 20, 20, 0.18);
}

.contact-chat-panel.contact-chat-primary .contact-ai-chat .chat-messages {
  max-height: 510px;
}

.contact-support-panel {
  width: min(920px, 100%);
}

.contact-support-panel .contact-side-card {
  gap: 18px;
  padding: 18px;
  border-color: rgba(20, 20, 20, 0.07);
  border-radius: 28px;
  background: rgba(255, 255, 255, 0.58);
  box-shadow: 0 18px 60px rgba(30, 25, 20, 0.06);
}

.contact-support-panel .contact-qr-grid {
  gap: 14px;
}

.contact-support-panel .contact-qr-card {
  min-height: 214px;
  align-content: center;
  padding: 14px 12px;
  border-color: rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: none;
}

.contact-support-panel .contact-qr-card img {
  width: min(100%, 156px);
  border-radius: 8px;
}

.contact-support-panel .contact-qr-card strong {
  color: var(--ink);
  font-size: 14px;
  line-height: 1.15;
}

.contact-support-panel .contact-qr-card span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
}

.contact-info-strip {
  justify-content: space-between;
  padding: 14px 18px;
  border-color: rgba(20, 20, 20, 0.08);
  background: rgba(17, 17, 17, 0.94);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.06);
}

.contact-support-panel .contact-info-strip a,
.contact-support-panel .contact-info-strip span {
  flex: 1 1 auto;
  justify-content: center;
  padding: 0 14px;
}

.contact-support-panel .contact-info-strip small {
  font-size: 12px;
}

.contact-support-panel .contact-info-strip strong {
  font-size: 14px;
}

@media (max-width: 720px) {
  .contact-ai-section {
    padding-top: 0;
    padding-bottom: 64px;
  }

  .contact-ai-priority-layout {
    width: min(100% - 36px, 980px);
    gap: 24px;
  }

  .contact-chat-primary {
    width: min(520px, 100%);
  }

  .contact-chat-panel.contact-chat-primary .contact-ai-chat {
    min-height: 600px;
    border-radius: 26px;
  }

  .contact-chat-panel.contact-chat-primary .contact-ai-chat .chat-messages {
    max-height: 390px;
  }

  .contact-support-panel .contact-side-card {
    gap: 14px;
    padding: 12px;
    border-radius: 24px;
  }

  .contact-support-panel .contact-qr-grid {
    gap: 10px;
  }

  .contact-support-panel .contact-qr-card {
    min-height: 170px;
    padding: 10px 8px;
  }

  .contact-support-panel .contact-qr-card img {
    width: min(100%, 128px);
  }

  .contact-support-panel .contact-qr-card strong {
    font-size: 12px;
  }

  .contact-support-panel .contact-qr-card span {
    display: block;
    font-size: 10px;
    line-height: 1.2;
  }

  .contact-info-strip {
    padding: 14px 16px;
  }
}

/* Contact support module: resource-card treatment with icon-only contact labels. */
.contact-support-panel {
  padding-top: 18px;
}

.contact-support-panel .contact-side-card {
  position: relative;
  padding: 26px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.82), rgba(255, 255, 255, 0.54)),
    var(--paper-soft);
}

.contact-support-panel .contact-side-card::before {
  content: "";
  position: absolute;
  top: -20px;
  left: 50%;
  width: min(320px, 68%);
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(20, 20, 20, 0.18), transparent);
  transform: translateX(-50%);
}

.contact-support-panel .contact-qr-grid {
  align-items: stretch;
}

.contact-support-panel .contact-qr-card {
  min-height: 226px;
  border-color: rgba(20, 20, 20, 0.09);
  background: rgba(255, 255, 255, 0.88);
}

.contact-info-strip {
  display: flex;
  align-items: center;
  min-height: 72px;
  border: 1px solid rgba(247, 244, 238, 0.1);
  border-radius: 999px;
}

.contact-support-panel .contact-info-strip a,
.contact-support-panel .contact-info-strip span {
  gap: 10px;
  min-width: 0;
}

.contact-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  flex: 0 0 auto;
  color: var(--blue);
}

.contact-info-icon svg {
  width: 100%;
  height: 100%;
  fill: none;
  stroke: currentColor;
  stroke-width: 2.35;
  stroke-linecap: round;
  stroke-linejoin: round;
}

.contact-support-panel .contact-info-strip strong {
  overflow-wrap: anywhere;
}

@media (max-width: 720px) {
  .contact-support-panel {
    padding-top: 14px;
  }

  .contact-support-panel .contact-side-card {
    padding: 14px;
  }

  .contact-support-panel .contact-side-card::before {
    top: -16px;
    width: 70%;
  }

  .contact-support-panel .contact-qr-card {
    min-height: 184px;
  }

  .contact-info-strip {
    min-height: auto;
  }

  .contact-support-panel .contact-info-strip a,
  .contact-support-panel .contact-info-strip span {
    display: grid;
    grid-template-columns: 24px minmax(0, 1fr);
    justify-content: initial;
  }

  .contact-info-icon {
    width: 20px;
    height: 20px;
  }
}

/* Keep contact-strip icons independent from legacy span rules. */
.contact-support-panel .contact-info-strip > a,
.contact-support-panel .contact-info-strip > span {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.contact-support-panel .contact-info-strip .contact-info-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  padding: 0;
  border: 0;
  flex: 0 0 auto;
  color: var(--blue);
}

.contact-support-panel .contact-info-strip .contact-info-icon svg {
  width: 100%;
  height: 100%;
}

@media (max-width: 720px) {
  .contact-info-strip {
    display: grid;
    gap: 10px;
  }

  .contact-support-panel .contact-info-strip > a,
  .contact-support-panel .contact-info-strip > span {
    display: grid;
    grid-template-columns: 22px minmax(0, 1fr);
    align-items: center;
    gap: 12px;
  }

  .contact-support-panel .contact-info-strip .contact-info-icon {
    width: 20px;
    height: 20px;
  }

  .contact-support-panel .contact-info-strip strong {
    text-align: left;
  }
}

/* Contact follow module: title, contact subtitle, then QR cards. */
.contact-support-panel {
  width: min(980px, 100%);
  padding-top: 34px;
}

.contact-support-panel .contact-side-card {
  grid-template-columns: 1fr;
  gap: 42px;
  min-height: auto;
  padding: 68px 52px 48px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 34px;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.88), rgba(255, 255, 255, 0.62)),
    var(--paper-soft);
  box-shadow: 0 28px 90px rgba(30, 25, 20, 0.08);
}

.contact-support-panel .contact-side-card::before {
  content: none;
}

.contact-support-header {
  display: grid;
  justify-items: center;
  gap: 20px;
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}

.contact-support-header h2 {
  margin: 0;
  font-family: var(--display);
  font-size: clamp(42px, 5vw, 72px);
  line-height: 1.05;
  letter-spacing: 0;
  color: var(--ink);
  text-wrap: balance;
}

.contact-support-header .contact-info-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 24px;
  min-height: auto;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

.contact-support-header .contact-info-strip > a,
.contact-support-header .contact-info-strip > span {
  display: inline-flex;
  flex: 0 1 auto;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-width: 0;
  padding: 0;
  color: var(--muted);
  text-decoration: none;
}

.contact-support-header .contact-info-strip strong {
  color: var(--muted);
  font-size: 15px;
  font-weight: 720;
  line-height: 1.35;
  overflow-wrap: anywhere;
}

.contact-support-header .contact-info-strip .contact-info-icon {
  width: 18px;
  height: 18px;
  color: var(--blue);
}

.contact-support-panel .contact-qr-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 22px;
  align-items: stretch;
}

.contact-support-panel .contact-qr-card {
  min-height: 252px;
  align-content: center;
  gap: 10px;
  padding: 22px 18px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 22px;
  background: rgba(255, 255, 255, 0.9);
  box-shadow: none;
}

.contact-support-panel .contact-qr-card img {
  width: min(100%, 166px);
  border-radius: 10px;
}

.contact-support-panel .contact-qr-card strong {
  color: var(--ink);
  font-size: 15px;
  line-height: 1.2;
}

.contact-support-panel .contact-qr-card span {
  color: var(--muted);
  font-size: 12px;
  line-height: 1.28;
}

@media (max-width: 720px) {
  .contact-support-panel {
    padding-top: 24px;
  }

  .contact-support-panel .contact-side-card {
    gap: 28px;
    padding: 42px 18px 24px;
    border-radius: 28px;
  }

  .contact-support-header {
    gap: 16px;
  }

  .contact-support-header h2 {
    font-size: 36px;
  }

  .contact-support-header .contact-info-strip {
    display: grid;
    justify-items: center;
    gap: 10px;
  }

  .contact-support-header .contact-info-strip > a,
  .contact-support-header .contact-info-strip > span {
    display: inline-flex;
    justify-content: center;
    text-align: center;
  }

  .contact-support-header .contact-info-strip strong {
    font-size: 13px;
    text-align: center;
  }

  .contact-support-panel .contact-qr-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 10px;
  }

  .contact-support-panel .contact-qr-card {
    min-height: 168px;
    padding: 10px 8px;
    border-radius: 18px;
  }

  .contact-support-panel .contact-qr-card img {
    width: min(100%, 110px);
  }

  .contact-support-panel .contact-qr-card strong {
    font-size: 12px;
  }

  .contact-support-panel .contact-qr-card span {
    font-size: 10px;
  }
}

/* Contact page final CTA follows the same bottom-module structure as services. */
.contact-page .contact-ai-section {
  padding-bottom: 148px;
}

.contact-page .contact-ai-priority-layout {
  gap: 0;
}

.contact-page .contact-final-cta {
  padding-top: 128px;
  padding-bottom: 122px;
  border-top: 1px solid var(--line);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0), rgba(244, 240, 234, 0.82));
}

.contact-page .contact-final-cta .section-title {
  max-width: 920px;
  font-size: clamp(46px, 5.2vw, 76px);
  line-height: 1.06;
}

.contact-page .contact-final-cta .container {
  width: min(var(--wide), calc(100% - 48px));
}

.contact-final-info {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 12px 28px;
  max-width: 980px;
  margin: 28px auto 0;
  color: var(--muted);
  font-size: clamp(16px, 1.2vw, 18px);
  line-height: 1.5;
}

.contact-final-info > a,
.contact-final-info > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-width: 0;
  color: inherit;
  text-decoration: none;
}

.contact-final-info strong {
  color: var(--muted);
  font-size: inherit;
  font-weight: 680;
}

.contact-final-info .contact-info-icon {
  width: 19px;
  height: 19px;
  color: var(--blue);
}

.contact-final-qr-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  justify-content: center;
  gap: 28px;
  width: min(980px, 100%);
  margin: 54px auto 0;
}

.contact-final-qr-card {
  display: grid;
  grid-template-rows: 258px 18px 16px;
  justify-items: center;
  align-content: center;
  gap: 9px;
  min-height: 246px;
  padding: 24px 18px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
}

.contact-final-qr-card img {
  display: block;
  width: 258px;
  height: 258px;
  object-fit: contain;
  border-radius: 10px;
  background: #fff;
}

.contact-final-qr-card strong {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
  font-size: 15px;
  font-weight: 760;
  line-height: 1.2;
  text-align: center;
}

.contact-final-qr-card span {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--muted);
  font-size: 12px;
  line-height: 1.25;
  text-align: center;
}

@media (max-width: 720px) {
  .contact-page .contact-ai-section {
    padding-bottom: 96px;
  }

  .contact-page .contact-final-cta {
    padding-top: 92px;
    padding-bottom: 92px;
  }

  .contact-page .contact-final-cta .section-title {
    font-size: clamp(34px, 9vw, 42px);
  }

  .contact-final-info {
    display: grid;
    justify-items: center;
    gap: 10px;
    margin-top: 22px;
    font-size: 13px;
    text-align: center;
  }

  .contact-final-info > a,
  .contact-final-info > span {
    justify-content: center;
  }

  .contact-final-info .contact-info-icon {
    width: 18px;
    height: 18px;
  }

  .contact-final-qr-grid {
    grid-template-columns: 1fr;
    gap: 18px;
    margin-top: 36px;
  }

  .contact-final-qr-card {
    grid-template-rows: auto 15px 13px;
    min-height: 168px;
    padding: 16px;
    border-radius: 18px;
  }

  .contact-final-qr-card img {
    width: min(100%, 258px);
    height: auto;
    aspect-ratio: 1;
  }

  .contact-final-qr-card strong {
    font-size: 12px;
  }

  .contact-final-qr-card span {
    font-size: 10px;
  }
}

/* Keep bottom CTA headings consistent with the home/products CTA scale. */
.final-product-cta .section-title,
.cases-page .final-product-cta .section-title,
.service-page .final-product-cta .section-title,
.contact-page .contact-final-cta .section-title {
  max-width: min(1180px, 100%);
  font-size: clamp(36px, 3.9vw, 58px);
  line-height: 1.14;
  white-space: nowrap;
}

@media (max-width: 720px) {
  .final-product-cta .section-title,
  .cases-page .final-product-cta .section-title,
  .service-page .final-product-cta .section-title,
  .contact-page .contact-final-cta .section-title {
    font-size: clamp(32px, 8.8vw, 40px);
    line-height: 1.14;
    white-space: normal;
  }
}

/* Particle case: AI skin report tab final layout. */
.particle-growth-lab .case-tab-copy.lizi-report-insight {
  align-content: stretch;
}

.lizi-report-insight {
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
  height: 100%;
  max-height: 690px;
  min-height: 0;
  padding: 30px;
  overflow: hidden;
  background:
    radial-gradient(circle at 88% 5%, rgba(255, 222, 226, 0.42), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.95), rgba(255, 250, 245, 0.84));
  color: #171717;
}

.lizi-report-insight::before {
  content: none;
}

.lizi-report-insight > * {
  position: relative;
  z-index: 1;
}

.lizi-report-insight .report-insight-head span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(173, 116, 101, 0.2);
  border-radius: 999px;
  background: rgba(255, 247, 240, 0.9);
  color: #8e5a40;
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.lizi-report-insight .report-insight-head h3 {
  max-width: 360px;
  margin: 13px 0 0;
  font-size: clamp(28px, 2.2vw, 34px);
  line-height: 1.08;
}

.lizi-report-insight .report-insight-head p {
  max-width: 358px;
  margin: 10px 0 0;
  color: rgba(37, 31, 28, 0.64);
  font-size: 13px;
  font-weight: 720;
  line-height: 1.42;
}

.report-growth-system {
  display: grid;
  grid-template-rows: auto auto auto;
  gap: 12px;
  min-height: 0;
}

.report-growth-action {
  padding: 15px 16px;
  border-left: 4px solid rgba(224, 134, 57, 0.82);
  border-radius: 0 18px 18px 0;
  background: linear-gradient(90deg, rgba(255, 241, 229, 0.92), rgba(255, 255, 255, 0.52));
}

.report-growth-action small,
.report-growth-steps b {
  color: #b66f55;
  font-size: 11px;
  font-weight: 940;
}

.report-growth-action strong {
  display: block;
  margin-top: 7px;
  color: #171717;
  font-size: 20px;
  font-weight: 940;
  line-height: 1.08;
}

.report-growth-action span {
  display: block;
  margin-top: 7px;
  color: rgba(37, 31, 28, 0.58);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.32;
}

.report-growth-steps {
  display: grid;
  gap: 8px;
}

.report-growth-steps article {
  display: grid;
  grid-template-columns: 70px 1fr;
  column-gap: 12px;
  align-items: center;
  min-height: 60px;
  padding: 10px 0;
  border-top: 1px solid rgba(188, 127, 112, 0.13);
}

.report-growth-steps article:last-child {
  border-bottom: 1px solid rgba(188, 127, 112, 0.13);
}

.report-growth-steps strong {
  color: #171717;
  font-size: 18px;
  font-weight: 930;
  line-height: 1.08;
}

.report-growth-steps span {
  grid-column: 2;
  margin-top: 4px;
  color: rgba(37, 31, 28, 0.58);
  font-size: 12px;
  font-weight: 760;
  line-height: 1.3;
}

.report-growth-loop {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 18px minmax(0, 1fr) 18px minmax(0, 1fr);
  align-items: center;
  gap: 6px;
}

.report-growth-loop span {
  display: grid;
  place-items: center;
  min-height: 38px;
  border-radius: 999px;
  background: rgba(255, 242, 236, 0.82);
  color: #241d1a;
  font-size: 12px;
  font-weight: 900;
  text-align: center;
}

.report-growth-loop i {
  display: block;
  height: 1px;
  background: rgba(190, 124, 109, 0.34);
}

.report-growth-results {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding-top: 12px;
  border-top: 1px solid rgba(188, 127, 112, 0.16);
}

.report-growth-results article {
  min-height: 58px;
  padding: 10px;
  border-radius: 14px;
  background: rgba(255, 245, 240, 0.78);
}

.report-growth-results strong {
  display: block;
  color: #171717;
  font-size: 16px;
  font-weight: 940;
}

.report-growth-results strong::before {
  display: inline-block;
  width: 6px;
  height: 6px;
  margin-right: 7px;
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.9);
  content: "";
}

.report-growth-results span {
  display: block;
  margin-top: 5px;
  color: rgba(37, 31, 28, 0.56);
  font-size: 11px;
  font-weight: 760;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-image {
  height: 100%;
  min-height: 0;
  padding: 0;
  background: #fff7f4;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-image img {
  object-fit: cover;
  object-position: center center;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-image::before,
.particle-growth-lab .case-image-slot.lizi-skin-report-image::after {
  content: none;
}

@media (max-width: 560px) {
  .lizi-report-insight {
    height: auto;
    max-height: none;
    padding: 24px;
  }

  .report-growth-steps article {
    grid-template-columns: 64px 1fr;
  }

  .report-growth-loop,
  .report-growth-results {
    grid-template-columns: 1fr;
  }

  .report-growth-loop i {
    display: none;
  }

  .media-lizi-skin .case-image-slot.lizi-skin-report-image {
    min-height: 560px;
  }
}

/* Final tuning for the AI skin report tab: restore the preferred explain-board layout. */
.lizi-report-insight {
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 14px;
}

.lizi-report-insight .report-insight-head h3 {
  max-width: 380px;
  font-size: clamp(27px, 2.1vw, 32px);
}

.lizi-report-insight .report-insight-head p {
  max-width: 366px;
}

.report-explain-board {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: auto auto auto;
  gap: 9px 10px;
  min-height: 294px;
  align-content: center;
}

.report-explain-board::before,
.report-explain-board::after {
  position: absolute;
  z-index: 0;
  background: rgba(197, 143, 128, 0.13);
  content: "";
}

.report-explain-board::before {
  top: 50%;
  right: 14px;
  left: 14px;
  height: 1px;
}

.report-explain-board::after {
  top: 18px;
  bottom: 18px;
  left: 50%;
  width: 1px;
}

.report-question-card,
.report-center-explain {
  position: relative;
  z-index: 1;
  border: 1px solid rgba(188, 127, 112, 0.13);
  background: rgba(255, 255, 255, 0.74);
  box-shadow: 0 12px 32px rgba(113, 74, 60, 0.06);
}

.report-question-card {
  min-height: 78px;
  padding: 12px 13px;
  border-radius: 16px;
}

.report-question-card small,
.report-center-explain small {
  color: #b66f55;
  font-size: 11px;
  font-weight: 940;
}

.report-question-card strong {
  display: block;
  margin-top: 7px;
  color: #171717;
  font-size: 17px;
  font-weight: 930;
  line-height: 1.12;
}

.report-question-card span {
  display: block;
  margin-top: 6px;
  color: rgba(37, 31, 28, 0.54);
  font-size: 11px;
  font-weight: 760;
}

.report-center-explain {
  grid-column: 1 / -1;
  justify-self: center;
  width: min(260px, 74%);
  min-height: 104px;
  padding: 15px 20px;
  border-radius: 22px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.9), rgba(255, 247, 244, 0.82));
}

.report-center-explain strong {
  display: block;
  margin-top: 6px;
  font-family: var(--display);
  color: #171717;
  font-size: 30px;
  line-height: 1;
}

.report-center-explain span {
  display: block;
  margin-top: 7px;
  color: rgba(37, 31, 28, 0.58);
  font-size: 12px;
  font-weight: 780;
  line-height: 1.28;
}

.report-center-explain i {
  display: block;
  height: 8px;
  margin-top: 7px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(226, 119, 151, 0.82), rgba(250, 217, 219, 0.82));
}

.report-center-explain i:nth-of-type(2) {
  width: 78%;
}

.report-center-explain i:nth-of-type(3) {
  width: 92%;
}

.report-action-lanes {
  display: grid;
  gap: 7px;
  padding-top: 10px;
  border-top: 1px solid rgba(188, 127, 112, 0.14);
}

.report-action-lanes article {
  display: grid;
  grid-template-columns: 36px 86px 1fr;
  align-items: center;
  gap: 10px;
  min-height: 42px;
  padding: 7px 0;
}

.report-action-lanes b {
  display: grid;
  place-items: center;
  width: 31px;
  height: 31px;
  border-radius: 50%;
  background: rgba(229, 132, 146, 0.12);
  color: #b66f55;
  font-size: 11px;
  font-weight: 950;
}

.report-action-lanes strong {
  color: #171717;
  font-size: 15px;
  font-weight: 930;
}

.report-action-lanes span {
  color: rgba(37, 31, 28, 0.58);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.24;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-image img {
  transform: scale(1.055);
  transform-origin: center center;
}

.report-explain-board {
  align-content: start;
  gap: 11px 10px;
  min-height: 280px;
}

.report-question-card {
  min-height: 68px;
  padding: 10px 12px;
}

.report-question-card strong {
  margin-top: 5px;
  font-size: 16px;
}

.report-question-card span {
  margin-top: 4px;
  font-size: 10px;
}

.report-center-explain {
  grid-column: 1 / -1;
  justify-self: stretch;
  width: 100%;
  min-height: 70px;
  padding: 10px 14px;
  border-radius: 16px;
  box-shadow: 0 8px 22px rgba(113, 74, 60, 0.04);
  }

.report-center-explain strong {
  margin-top: 3px;
  font-size: 22px;
}

.report-center-explain span {
  margin-top: 4px;
  font-size: 10px;
}

.report-center-explain i {
  height: 4px;
  margin-top: 4px;
}

.report-action-lanes {
  gap: 6px;
  padding-top: 8px;
}

.report-action-lanes article {
  min-height: 39px;
  padding: 5px 0;
}

@media (max-width: 560px) {
  .report-explain-board {
    grid-template-columns: 1fr;
    min-height: auto;
  }

  .report-explain-board::before,
  .report-explain-board::after {
    content: none;
  }

  .report-center-explain {
    grid-column: auto;
    width: 100%;
    order: -1;
  }

  .report-action-lanes article {
    grid-template-columns: 34px 1fr;
  }

  .report-action-lanes span {
    grid-column: 2;
  }
}

.lizi-report-insight .report-explain-board {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: 82px 102px 82px;
  gap: 10px;
  min-height: 286px;
  align-content: start;
}

.lizi-report-insight .report-question-card {
  min-height: 0;
  padding: 12px 13px;
}

.lizi-report-insight .report-question-card:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

.lizi-report-insight .report-question-card:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

.lizi-report-insight .report-question-card:nth-of-type(4) {
  grid-column: 1;
  grid-row: 3;
}

.lizi-report-insight .report-question-card:nth-of-type(5) {
  grid-column: 2;
  grid-row: 3;
}

.lizi-report-insight .report-question-card strong {
  margin-top: 7px;
  font-size: 17px;
}

.lizi-report-insight .report-question-card span {
  margin-top: 6px;
  font-size: 11px;
}

.lizi-report-insight .report-center-explain {
  position: absolute;
  z-index: 3;
  top: 50%;
  left: 50%;
  grid-column: auto;
  justify-self: auto;
  width: 190px;
  min-height: 88px;
  padding: 11px 15px;
  border-radius: 18px;
  transform: translate(-50%, -50%);
  box-shadow: 0 14px 34px rgba(113, 74, 60, 0.075);
}

.lizi-report-insight .report-center-explain strong {
  margin-top: 4px;
  font-size: 24px;
}

.lizi-report-insight .report-center-explain span {
  margin-top: 5px;
  font-size: 10px;
  line-height: 1.25;
}

.lizi-report-insight .report-center-explain i {
  height: 4px;
  margin-top: 4px;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-image img {
  object-fit: cover;
  object-position: left center;
  transform: scale(1.02);
  transform-origin: left center;
}

@media (max-width: 560px) {
  .lizi-report-insight .report-explain-board {
    grid-template-columns: 1fr;
    grid-template-rows: none;
    min-height: auto;
  }

  .lizi-report-insight .report-question-card:nth-of-type(n) {
    grid-column: auto;
    grid-row: auto;
  }

  .lizi-report-insight .report-center-explain {
    position: relative;
    top: auto;
    left: auto;
    order: -1;
    width: 100%;
    transform: none;
  }
}

.lizi-report-insight .report-insight-head h3 {
  max-width: 390px;
  font-size: clamp(30px, 2.2vw, 34px);
  line-height: 1.08;
}

.lizi-report-insight .report-insight-head p {
  max-width: 386px;
  font-size: 13px;
  line-height: 1.48;
}

.lizi-report-insight .report-explain-board {
  grid-template-rows: 84px 112px 84px;
  gap: 10px 12px;
  min-height: 300px;
}

.lizi-report-insight .report-explain-board::before {
  right: 28px;
  left: 28px;
  background: linear-gradient(90deg, transparent, rgba(197, 143, 128, 0.22), transparent);
}

.lizi-report-insight .report-explain-board::after {
  top: 28px;
  bottom: 28px;
  background: linear-gradient(180deg, transparent, rgba(197, 143, 128, 0.18), transparent);
}

.lizi-report-insight .report-question-card {
  display: grid;
  align-content: center;
  border-color: rgba(188, 127, 112, 0.14);
  background: rgba(255, 255, 255, 0.72);
}

.lizi-report-insight .report-question-card small {
  font-size: 11px;
}

.lizi-report-insight .report-question-card strong {
  font-size: 17px;
}

.lizi-report-insight .report-question-card span {
  font-size: 11px;
  line-height: 1.22;
}

.lizi-report-insight .report-center-explain {
  width: 214px;
  min-height: 96px;
  padding: 12px 16px;
  background:
    radial-gradient(circle at 84% 12%, rgba(255, 210, 219, 0.54), transparent 38%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.95), rgba(255, 246, 242, 0.9));
}

.lizi-report-insight .report-center-explain strong {
  font-size: 23px;
  white-space: nowrap;
}

.lizi-report-insight .report-action-lanes {
  gap: 7px;
  padding-top: 10px;
}

.lizi-report-insight .report-action-lanes article {
  grid-template-columns: 34px 86px 1fr;
  min-height: 42px;
  padding: 6px 0;
}

.lizi-report-insight .report-action-lanes b {
  width: 30px;
  height: 30px;
}

.lizi-report-insight .report-action-lanes strong {
  font-size: 15px;
}

.lizi-report-insight .report-action-lanes span {
  font-size: 11px;
  line-height: 1.28;
}

.lizi-report-insight .report-action-lanes {
  gap: 7px;
  padding-top: 0;
  border-top: 0;
}

.lizi-report-insight .report-action-lanes article {
  grid-template-columns: 34px 82px 1fr;
  min-height: 50px;
  padding: 8px 12px;
  border: 1px solid rgba(188, 127, 112, 0.14);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 10px 24px rgba(113, 74, 60, 0.045);
}

.lizi-report-insight .report-action-lanes b {
  background: rgba(229, 132, 146, 0.14);
}

.lizi-report-insight {
  gap: 12px;
}

.lizi-report-insight .report-insight-head h3 {
  max-width: 405px;
  font-size: clamp(29px, 2.08vw, 33px);
}

.lizi-report-insight .report-explain-board {
  grid-template-rows: 78px 94px 78px;
  min-height: 262px;
  margin-bottom: 8px;
}

.lizi-report-insight .report-question-card {
  padding: 9px 12px;
}

.lizi-report-insight .report-question-card strong {
  margin-top: 5px;
  font-size: 16px;
}

.lizi-report-insight .report-question-card span {
  margin-top: 4px;
  font-size: 10px;
}

.lizi-report-insight .report-center-explain {
  width: 198px;
  min-height: 88px;
  padding: 10px 14px;
}

.lizi-report-insight .report-center-explain strong {
  font-size: 21px;
}

.lizi-report-insight .report-center-explain span {
  font-size: 9.5px;
}

.lizi-report-insight .report-action-lanes {
  gap: 7px;
  margin-top: 2px;
}

.lizi-report-insight .report-action-lanes article {
  min-height: 46px;
  padding: 7px 12px;
}

.lizi-report-insight .report-action-lanes {
  gap: 8px;
  margin-top: 4px;
}

.lizi-report-insight .report-action-lanes article {
  grid-template-columns: 34px 82px minmax(0, 1fr);
  min-height: 44px;
  padding: 6px 12px;
}

.lizi-report-insight .report-action-lanes span {
  white-space: nowrap;
}

.lizi-report-insight {
  gap: 14px;
}

.lizi-report-insight .report-explain-board {
  grid-template-rows: 76px 116px 76px;
  gap: 10px 12px;
  min-height: 288px;
  margin-bottom: 0;
}

.lizi-report-insight .report-center-explain {
  top: 49%;
  min-height: 86px;
}

.lizi-report-insight .report-question-card:nth-of-type(4),
.lizi-report-insight .report-question-card:nth-of-type(5) {
  transform: translateY(6px);
}

.lizi-report-insight .report-action-lanes {
  gap: 8px;
  margin-top: 0;
}

.lizi-report-insight .report-action-lanes article {
  min-height: 44px;
  padding: 6px 12px;
}

.lizi-report-insight .report-insight-head h3 {
  font-size: clamp(30px, 2.35vw, 35px);
  line-height: 1.08;
}

.lizi-report-insight .report-explain-board {
  grid-template-rows: 76px 104px 76px;
  gap: 12px;
  min-height: 280px;
}

.lizi-report-insight .report-center-explain {
  display: grid;
  align-content: center;
  top: 50%;
  min-height: 0;
  height: 120px;
  padding: 10px 14px;
}

.lizi-report-insight .report-center-explain strong {
  margin-top: 7px;
}

.lizi-report-insight .report-center-explain span {
  margin-top: 7px;
}

.lizi-report-insight .report-center-explain i {
  margin-top: 5px;
}

.lizi-report-insight .report-question-card:nth-of-type(4),
.lizi-report-insight .report-question-card:nth-of-type(5) {
  transform: none;
}

.media-lizi-skin .case-image-slot.lizi-skin-report-image img {
  object-fit: cover;
  object-position: center center;
  transform: none;
  transform-origin: center center;
}

/* Skin ID asset tab: right-side lifecycle value diagram. */
.particle-growth-lab .case-tab-stage > .media-lizi-id {
  align-self: stretch;
  grid-template-rows: auto minmax(0, 1fr);
  height: 100%;
  max-height: 690px;
  min-height: 0;
  overflow: hidden;
}

.media-lizi-id .case-image-slot.lizi-id-asset-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 13% 16%, rgba(255, 255, 255, 0.92), transparent 24%),
    radial-gradient(circle at 86% 18%, rgba(255, 218, 225, 0.62), transparent 30%),
    radial-gradient(circle at 76% 88%, rgba(225, 241, 255, 0.68), transparent 32%),
    linear-gradient(135deg, #fff8f2 0%, #ffeaf0 52%, #eef7ff 100%);
}

.media-lizi-id .case-image-slot.lizi-id-asset-image::before,
.particle-growth-lab .case-image-slot.lizi-id-asset-image::after {
  content: none;
}

.lizi-id-asset-image strong,
.lizi-id-asset-image span {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.skin-id-asset-map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 10px;
  height: 100%;
  color: #3c2924;
}

.skin-id-map-head {
  display: grid;
  gap: 6px;
  max-width: 660px;
}

.skin-id-map-head span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(209, 143, 112, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: #b86b4c;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.skin-id-map-head strong {
  font-family: var(--display);
  font-size: clamp(27px, 2.45vw, 38px);
  font-weight: 900;
  line-height: 1.02;
  letter-spacing: 0;
}

.skin-id-map-head p {
  max-width: 640px;
  margin: 0;
  color: rgba(60, 41, 36, 0.68);
  font-size: 13px;
  font-weight: 760;
  line-height: 1.42;
}

.skin-id-map-core {
  position: relative;
  display: grid;
  grid-template-columns: minmax(136px, 0.72fr) minmax(320px, 1.72fr) minmax(142px, 0.72fr);
  gap: 12px;
  min-height: 0;
  align-items: stretch;
}

.skin-id-map-core::before {
  content: none;
}

.skin-id-account-card,
.skin-id-hub-card,
.skin-id-value-card {
  position: relative;
  z-index: 1;
  border: 1px solid rgba(183, 124, 104, 0.16);
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.72);
  box-shadow: 0 16px 34px rgba(115, 74, 55, 0.08);
  min-height: 0;
}

.skin-id-account-card,
.skin-id-value-card {
  display: grid;
  align-content: center;
  gap: 7px;
  padding: 13px;
}

.skin-id-account-card > span,
.skin-id-value-card > span {
  color: #bd7952;
  font-size: 12px;
  font-weight: 900;
}

.skin-id-account-card strong {
  font-family: var(--display);
  font-size: 25px;
  font-weight: 900;
  line-height: 0.95;
}

.skin-id-account-card ul {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.skin-id-account-card li {
  padding: 5px 7px;
  border: 1px solid rgba(221, 144, 159, 0.28);
  border-radius: 999px;
  background: rgba(255, 244, 241, 0.82);
  color: rgba(55, 39, 34, 0.72);
  font-size: 10.5px;
  font-weight: 820;
}

.skin-id-cycle-board {
  position: relative;
  z-index: 1;
  min-height: 0;
  overflow: hidden;
  border: 1px solid rgba(183, 124, 104, 0.14);
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 225, 230, 0.82), transparent 31%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.64), rgba(255, 245, 249, 0.52));
  box-shadow: 0 18px 38px rgba(115, 74, 55, 0.07);
}

.skin-id-cycle-board::before,
.skin-id-cycle-board::after {
  position: absolute;
  top: 50%;
  left: 50%;
  width: min(292px, calc(100% - 34px), calc(100vh - 410px));
  aspect-ratio: 1;
  border-radius: 50%;
  pointer-events: none;
  transform: translate(-50%, -50%);
  content: "";
}

.skin-id-cycle-board::before {
  border: 1px dashed rgba(224, 122, 150, 0.24);
}

.skin-id-cycle-board::after {
  width: min(252px, calc(100% - 72px), calc(100vh - 450px));
  border: 14px solid transparent;
  border-top-color: rgba(230, 123, 151, 0.24);
  border-right-color: rgba(230, 123, 151, 0.18);
  border-bottom-color: rgba(227, 162, 100, 0.18);
  border-left-color: rgba(230, 123, 151, 0.12);
  transform: translate(-50%, -50%) rotate(18deg);
}

.skin-id-hub-card {
  display: grid;
  place-items: center;
  align-content: center;
  gap: 7px;
  padding: 15px 12px;
  text-align: center;
  background:
    radial-gradient(circle at 50% 42%, rgba(255, 214, 223, 0.78), transparent 56%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.9), rgba(255, 247, 239, 0.78));
}

.skin-id-cycle-board .skin-id-hub-card {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 152px;
  height: 152px;
  padding: 12px;
  border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow:
    inset 0 1px 0 rgba(255, 255, 255, 0.8),
    0 16px 38px rgba(180, 92, 120, 0.14);
}

.skin-id-cycle-board .skin-id-hub-card small {
  display: none;
}

.skin-id-hub-card::before {
  width: 74px;
  height: 74px;
  border: 1px solid rgba(222, 135, 154, 0.38);
  border-radius: 50%;
  background:
    radial-gradient(circle, rgba(255, 255, 255, 0.9) 0 34%, rgba(232, 122, 150, 0.18) 35% 62%, transparent 63%),
    conic-gradient(from 210deg, rgba(226, 131, 151, 0.24), rgba(231, 170, 101, 0.28), rgba(152, 188, 220, 0.22), rgba(226, 131, 151, 0.24));
  content: "";
}

.skin-id-cycle-board .skin-id-hub-card::before {
  width: 48px;
  height: 48px;
}

.skin-id-hub-card small {
  color: #b86b4c;
  font-size: 9px;
  font-weight: 900;
  text-transform: uppercase;
}

.skin-id-hub-card strong {
  font-family: var(--display);
  font-size: 28px;
  font-weight: 900;
  line-height: 0.95;
}

.skin-id-hub-card span {
  color: rgba(60, 41, 36, 0.68);
  font-size: 10px;
  font-weight: 850;
}

.skin-id-value-card ol {
  display: grid;
  gap: 5px;
  margin: 0;
  padding: 0;
  list-style: none;
}

.skin-id-value-card li {
  display: grid;
  grid-template-columns: 1fr;
  gap: 3px;
  align-items: center;
  padding: 6px 8px;
  border-radius: 13px;
  background: rgba(255, 247, 244, 0.78);
}

.skin-id-value-card b {
  color: #171717;
  font-size: 13.5px;
  font-weight: 940;
}

.skin-id-value-card small {
  color: rgba(60, 41, 36, 0.58);
  font-size: 10px;
  font-weight: 780;
  white-space: nowrap;
}

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

.skin-id-code-row article {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 2px 9px;
  align-items: center;
  min-height: 60px;
  padding: 9px 11px;
  border: 1px solid rgba(183, 124, 104, 0.13);
  border-radius: 17px;
  background: rgba(255, 255, 255, 0.66);
  box-shadow: 0 10px 26px rgba(115, 74, 55, 0.055);
}

.skin-id-code-row small {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(232, 132, 151, 0.13);
  color: #c87453;
  font-size: 12px;
  font-weight: 940;
}

.skin-id-code-row strong {
  color: #181818;
  font-size: 15px;
  font-weight: 940;
  line-height: 1.1;
}

.skin-id-code-row span {
  color: rgba(60, 41, 36, 0.6);
  font-size: 11px;
  font-weight: 760;
}

.skin-id-lifecycle {
  position: absolute;
  inset: 0;
  z-index: 2;
  display: block;
}

.skin-id-lifecycle article {
  position: absolute;
  display: grid;
  gap: 3px;
  align-content: center;
  width: 94px;
  min-height: 44px;
  padding: 7px 8px;
  border: 1px solid rgba(183, 124, 104, 0.12);
  border-radius: 999px;
  background: rgba(255, 253, 249, 0.78);
  box-shadow: 0 10px 24px rgba(115, 74, 55, 0.06);
  text-align: center;
  transform: translate(-50%, -50%);
}

.skin-id-lifecycle article:nth-child(1) {
  top: 14%;
  left: 50%;
}

.skin-id-lifecycle article:nth-child(2) {
  top: 34%;
  left: 84%;
}

.skin-id-lifecycle article:nth-child(3) {
  top: 82%;
  left: 72%;
}

.skin-id-lifecycle article:nth-child(4) {
  top: 82%;
  left: 28%;
}

.skin-id-lifecycle article:nth-child(5) {
  top: 34%;
  left: 16%;
}

.skin-id-lifecycle article:not(:last-child)::after {
  content: none;
}

.skin-id-lifecycle b {
  color: #c87453;
  font-size: 10px;
  font-weight: 940;
}

.skin-id-lifecycle span {
  color: #171717;
  font-size: 12px;
  font-weight: 920;
  white-space: nowrap;
}

@media (max-width: 760px) {
  .media-lizi-id .case-image-slot.lizi-id-asset-image {
    min-height: 820px;
  }

  .skin-id-asset-map {
    grid-template-rows: auto auto auto;
  }

  .skin-id-map-core,
  .skin-id-code-row,
  .skin-id-lifecycle {
    grid-template-columns: 1fr;
  }

  .skin-id-cycle-board {
    min-height: 360px;
  }

  .skin-id-map-core::before,
  .skin-id-lifecycle article::after {
    content: none;
  }
}

/* Renewal and franchise tab: AI-managed repurchase and scale system. */
.particle-growth-lab .case-tab-copy.lizi-renewal-insight {
  align-content: center;
}

.lizi-renewal-insight {
  position: relative;
  grid-template-rows: auto auto auto auto;
  gap: 12px;
  height: 100%;
  min-height: 0;
  overflow: hidden;
  padding: 26px 32px;
}

.lizi-renewal-insight::before {
  position: absolute;
  inset: -30% -18% auto auto;
  width: 270px;
  height: 270px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255, 210, 202, 0.18), transparent 68%);
  content: "";
}

.lizi-renewal-insight > * {
  position: relative;
  z-index: 1;
}

.renewal-insight-head > span {
  display: inline-flex;
  width: fit-content;
  padding: 6px 10px;
  border: 1px solid rgba(255, 232, 211, 0.16);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.08);
  color: rgba(255, 229, 203, 0.78);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
}

.renewal-insight-head h3 {
  max-width: 520px;
  margin: 12px 0 0;
  font-size: clamp(30px, 2.35vw, 35px);
  line-height: 1.08;
}

.renewal-insight-head p {
  margin: 11px 0 0;
  color: rgba(248, 246, 240, 0.72);
  font-size: 14px;
  line-height: 1.48;
}

.renewal-command-card {
  display: grid;
  gap: 10px;
  min-height: 204px;
  padding: 15px;
  overflow: hidden;
  border: 1px solid rgba(255, 226, 203, 0.13);
  border-radius: 22px;
  background:
    radial-gradient(circle at 82% 18%, rgba(255, 215, 198, 0.13), transparent 34%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.055)),
    #171717;
}

.renewal-command-core {
  display: grid;
  gap: 7px;
  padding: 13px 14px;
  border: 1px solid rgba(255, 226, 203, 0.12);
  border-radius: 17px;
  background: linear-gradient(135deg, rgba(224, 134, 57, 0.12), rgba(255, 255, 255, 0.055));
}

.renewal-command-core small,
.renewal-lane-pair small,
.renewal-result-strip span {
  color: rgba(255, 214, 174, 0.74);
  font-size: 11px;
  font-weight: 900;
}

.renewal-command-core strong {
  color: #fffaf3;
  font-size: 18px;
  font-weight: 930;
  line-height: 1.08;
}

.renewal-command-core span {
  color: rgba(248, 246, 240, 0.62);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.32;
}

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

.renewal-command-grid article {
  min-height: 58px;
  padding: 10px 7px;
  border: 1px solid rgba(255, 226, 203, 0.1);
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.1);
}

.renewal-command-grid b {
  display: block;
  color: #fffaf3;
  font-size: 15px;
  font-weight: 930;
}

.renewal-command-grid span {
  display: block;
  margin-top: 6px;
  color: rgba(248, 246, 240, 0.58);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.2;
}

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

.renewal-lane-pair article {
  min-height: 112px;
  padding: 14px;
  border: 1px solid rgba(255, 226, 203, 0.1);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.09);
}

.renewal-lane-pair strong {
  display: block;
  margin-top: 9px;
  color: #fffaf3;
  font-size: 17px;
  font-weight: 930;
  line-height: 1.15;
}

.renewal-lane-pair span {
  display: block;
  margin-top: 9px;
  color: rgba(248, 246, 240, 0.58);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.32;
}

.renewal-result-strip {
  display: grid;
  grid-template-columns: 1fr repeat(3, minmax(0, 68px));
  gap: 7px;
  align-items: center;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 255, 255, 0.11);
}

.renewal-result-strip strong {
  display: grid;
  place-items: center;
  min-height: 38px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.09);
  color: rgba(255, 250, 243, 0.92);
  font-size: 14px;
  font-weight: 920;
}

.particle-growth-lab .case-tab-stage > .media-lizi-renewal {
  align-self: stretch;
  grid-template-rows: auto minmax(0, 1fr);
  height: 100%;
  max-height: 690px;
  min-height: 0;
  overflow: hidden;
}

.media-lizi-renewal .case-image-slot.lizi-renewal-system-image {
  display: block;
  height: 100%;
  min-height: 0;
  padding: 18px;
  background:
    radial-gradient(circle at 16% 18%, rgba(255, 255, 255, 0.92), transparent 25%),
    radial-gradient(circle at 84% 20%, rgba(255, 219, 226, 0.62), transparent 30%),
    radial-gradient(circle at 75% 88%, rgba(225, 241, 255, 0.66), transparent 32%),
    linear-gradient(135deg, #fff8f1 0%, #ffe9f0 52%, #eef7ff 100%);
}

.media-lizi-renewal .case-image-slot.lizi-renewal-system-image::before,
.particle-growth-lab .case-image-slot.lizi-renewal-system-image::after {
  content: none;
}

.lizi-renewal-system-image strong,
.lizi-renewal-system-image span {
  position: static;
  z-index: auto;
  max-width: none;
  margin: 0;
  color: inherit;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
}

.lizi-renewal-system-image i {
  display: block;
  opacity: 1;
  background: none;
}

.renewal-system-map {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: auto minmax(0, 1fr) auto;
  gap: 10px;
  height: 100%;
  color: #3c2924;
}

.renewal-system-head {
  display: grid;
  gap: 6px;
  max-width: 640px;
}

.renewal-system-head span {
  width: fit-content;
  padding: 5px 10px;
  border: 1px solid rgba(209, 143, 112, 0.18);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.62);
  color: #b86b4c;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

.renewal-system-head strong {
  font-family: var(--display);
  font-size: clamp(27px, 2.45vw, 38px);
  font-weight: 900;
  line-height: 1.02;
}

.renewal-system-head p {
  max-width: 620px;
  margin: 0;
  color: rgba(60, 41, 36, 0.68);
  font-size: 14px;
  font-weight: 760;
  line-height: 1.42;
}

.renewal-system-core {
  display: grid;
  grid-template-columns: minmax(0, 0.92fr) minmax(220px, 1.08fr) minmax(0, 0.92fr);
  gap: 12px;
  min-height: 0;
}

.renewal-system-side,
.renewal-ai-center,
.renewal-metrics-row article {
  border: 1px solid rgba(183, 124, 104, 0.14);
  background: rgba(255, 255, 255, 0.7);
  box-shadow: 0 16px 34px rgba(115, 74, 55, 0.07);
}

.renewal-system-side {
  display: grid;
  align-content: center;
  gap: 8px;
  min-height: 0;
  padding: 13px;
  border-radius: 20px;
}

.renewal-system-side > span {
  color: #bd7952;
  font-size: 12px;
  font-weight: 900;
}

.renewal-system-side article {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 3px 8px;
  align-items: center;
  padding: 8px 9px;
  border-radius: 14px;
  background: rgba(255, 247, 244, 0.78);
}

.renewal-system-side b {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 25px;
  height: 25px;
  border-radius: 50%;
  background: rgba(232, 132, 151, 0.13);
  color: #c87453;
  font-size: 10px;
  font-weight: 940;
}

.renewal-system-side strong {
  color: #171717;
  font-size: 13px;
  font-weight: 940;
  line-height: 1.12;
}

.renewal-system-side small {
  color: rgba(60, 41, 36, 0.58);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.2;
}

.renewal-ai-center {
  position: relative;
  min-height: 0;
  overflow: hidden;
  border-radius: 22px;
  background:
    radial-gradient(circle at 50% 50%, rgba(255, 225, 230, 0.86), transparent 31%),
    linear-gradient(135deg, rgba(255, 255, 255, 0.7), rgba(255, 245, 249, 0.56));
}

.renewal-ai-orbit {
  position: absolute;
  inset: 18px;
  border: 1px dashed rgba(224, 122, 150, 0.24);
  border-radius: 50%;
}

.renewal-ai-orbit::before {
  position: absolute;
  inset: 24px;
  border: 12px solid transparent;
  border-top-color: rgba(230, 123, 151, 0.22);
  border-right-color: rgba(230, 123, 151, 0.17);
  border-bottom-color: rgba(227, 162, 100, 0.17);
  border-left-color: rgba(230, 123, 151, 0.12);
  border-radius: 50%;
  transform: rotate(18deg);
  content: "";
}

.renewal-ai-core {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  gap: 6px;
  width: 148px;
  height: 148px;
  padding: 14px;
  border: 1px solid rgba(222, 135, 154, 0.32);
  border-radius: 50%;
  background:
    radial-gradient(circle at 50% 34%, rgba(255, 255, 255, 0.9), transparent 38%),
    linear-gradient(145deg, rgba(255, 255, 255, 0.92), rgba(255, 247, 239, 0.82));
  text-align: center;
  transform: translate(-50%, -50%);
  box-shadow: 0 16px 38px rgba(180, 92, 120, 0.14);
}

.renewal-ai-core small {
  color: #b86b4c;
  font-size: 10px;
  font-weight: 900;
}

.renewal-ai-core strong {
  font-family: var(--display);
  color: #271716;
  font-size: 27px;
  font-weight: 900;
  line-height: 0.95;
}

.renewal-ai-core span {
  color: rgba(60, 41, 36, 0.64);
  font-size: 10px;
  font-weight: 780;
  line-height: 1.24;
}

.renewal-ai-orbit i {
  position: absolute;
  z-index: 2;
  display: grid;
  place-items: center;
  width: 54px;
  height: 30px;
  border: 1px solid rgba(183, 124, 104, 0.12);
  border-radius: 999px;
  background: rgba(255, 253, 249, 0.82);
  color: #171717;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  box-shadow: 0 10px 24px rgba(115, 74, 55, 0.06);
  transform: translate(-50%, -50%);
}

.renewal-ai-orbit i:nth-of-type(1) {
  top: 11%;
  left: 50%;
}

.renewal-ai-orbit i:nth-of-type(2) {
  top: 50%;
  left: 91%;
}

.renewal-ai-orbit i:nth-of-type(3) {
  top: 89%;
  left: 50%;
}

.renewal-ai-orbit i:nth-of-type(4) {
  top: 50%;
  left: 9%;
}

.renewal-metrics-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}

.renewal-metrics-row article {
  display: grid;
  gap: 5px;
  align-content: center;
  min-height: 58px;
  padding: 9px 10px;
  border-radius: 15px;
  background: rgba(255, 253, 249, 0.68);
}

.renewal-metrics-row b {
  color: #171717;
  font-size: 13px;
  font-weight: 940;
  line-height: 1.12;
}

.renewal-metrics-row span {
  color: rgba(60, 41, 36, 0.58);
  font-size: 10px;
  font-weight: 760;
  line-height: 1.2;
}

@media (max-width: 760px) {
  .media-lizi-renewal .case-image-slot.lizi-renewal-system-image {
    min-height: 880px;
  }

  .renewal-system-map {
    grid-template-rows: auto auto auto;
  }

  .renewal-system-core,
  .renewal-metrics-row,
  .renewal-command-grid,
  .renewal-lane-pair {
    grid-template-columns: 1fr;
  }

  .renewal-ai-center {
    min-height: 320px;
  }
}

/* Final renewal tab form: proof ladder + managed operating board, distinct from Skin ID lifecycle. */
.renewal-proof-ladder {
  position: relative;
  display: grid;
  gap: 8px;
  min-height: 296px;
}

.renewal-proof-ladder::before {
  position: absolute;
  top: 28px;
  bottom: 28px;
  left: 28px;
  width: 2px;
  background: linear-gradient(180deg, rgba(224, 134, 57, 0.86), rgba(255, 226, 203, 0.16));
  content: "";
}

.renewal-proof-ladder article {
  position: relative;
  display: grid;
  align-content: center;
  min-height: 84px;
  padding: 12px 14px 12px 46px;
  border: 1px solid rgba(255, 226, 203, 0.12);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.055)),
    #171717;
}

.renewal-proof-ladder article:nth-child(1) {
  margin-right: 54px;
}

.renewal-proof-ladder article:nth-child(2) {
  margin-left: 30px;
  margin-right: 26px;
}

.renewal-proof-ladder article:nth-child(3) {
  margin-left: 60px;
}

.renewal-proof-ladder article::before {
  position: absolute;
  top: 50%;
  left: 14px;
  width: 20px;
  height: 20px;
  border: 1px solid rgba(255, 223, 198, 0.42);
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.18);
  transform: translateY(-50%);
  content: "";
}

.renewal-proof-ladder small {
  color: rgba(255, 214, 174, 0.78);
  font-size: 11px;
  font-weight: 920;
}

.renewal-proof-ladder strong {
  display: block;
  margin-top: 6px;
  color: #fffaf3;
  font-size: 16px;
  font-weight: 930;
  line-height: 1.18;
}

.renewal-proof-ladder span {
  display: block;
  margin-top: 6px;
  color: rgba(248, 246, 240, 0.58);
  font-size: 11px;
  font-weight: 760;
  line-height: 1.28;
}

.renewal-scale-equation {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px minmax(0, 1fr);
  gap: 8px;
  align-items: center;
}

.renewal-scale-equation article {
  min-height: 78px;
  padding: 13px 12px;
  border: 1px solid rgba(255, 226, 203, 0.1);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.09);
}

.renewal-scale-equation span {
  color: rgba(255, 214, 174, 0.74);
  font-size: 11px;
  font-weight: 900;
}

.renewal-scale-equation strong {
  display: block;
  margin-top: 7px;
  color: #fffaf3;
  font-size: 15px;
  font-weight: 920;
  line-height: 1.18;
}

.renewal-scale-equation b {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(255, 210, 170, 0.24);
  border-radius: 50%;
  background: rgba(224, 134, 57, 0.12);
}

.renewal-scale-equation b::before {
  color: rgba(255, 221, 190, 0.86);
  font-size: 18px;
  font-weight: 900;
  content: "→";
}

.renewal-ops-board {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 10px;
  min-height: 0;
}

.renewal-command-deck {
  display: grid;
  gap: 8px;
  padding: 11px;
  border: 1px solid rgba(183, 124, 104, 0.2);
  border-radius: 18px;
  background:
    linear-gradient(135deg, rgba(255, 249, 245, 0.96), rgba(255, 241, 238, 0.86));
  box-shadow: 0 16px 34px rgba(115, 74, 55, 0.09);
}

.renewal-command-deck > span,
.renewal-flow-lane > span {
  color: #bd7952;
  font-size: 13px;
  font-weight: 900;
}

.renewal-command-deck > div {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
}

.renewal-command-deck article {
  min-height: 58px;
  padding: 10px 9px;
  border-radius: 13px;
  background: rgba(255, 245, 239, 0.94);
  box-shadow: inset 0 0 0 1px rgba(190, 130, 104, 0.06);
}

.renewal-command-deck b,
.renewal-flow-lane strong {
  color: #171717;
  font-size: 15px;
  font-weight: 940;
  line-height: 1.14;
}

.renewal-command-deck small,
.renewal-flow-lane small {
  display: block;
  margin-top: 5px;
  color: rgba(60, 41, 36, 0.66);
  font-size: 11px;
  font-weight: 780;
  line-height: 1.22;
}

.renewal-flow-lanes {
  display: grid;
  grid-template-rows: repeat(2, minmax(0, 1fr));
  gap: 10px;
  min-height: 0;
}

.renewal-flow-lane {
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 9px;
  align-items: center;
  min-height: 0;
  padding: 10px;
  border: 1px solid rgba(183, 124, 104, 0.2);
  border-radius: 18px;
  background: rgba(255, 250, 247, 0.9);
  box-shadow: 0 16px 34px rgba(115, 74, 55, 0.08);
}

.renewal-flow-lane > div {
  position: relative;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.renewal-flow-lane > div::before {
  position: absolute;
  top: 50%;
  right: 8px;
  left: 8px;
  height: 2px;
  background: linear-gradient(90deg, rgba(224, 134, 57, 0.34), rgba(230, 123, 151, 0.25));
  content: "";
}

.renewal-flow-lane article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 2px 7px;
  align-items: center;
  min-height: 72px;
  padding: 9px;
  border: 1px solid rgba(183, 124, 104, 0.18);
  border-radius: 14px;
  background: rgba(255, 250, 245, 0.96);
  box-shadow: 0 8px 18px rgba(115, 74, 55, 0.045);
}

.renewal-flow-lane b {
  grid-row: 1 / span 2;
  display: grid;
  place-items: center;
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: rgba(232, 132, 151, 0.13);
  color: #c87453;
  font-size: 11px;
  font-weight: 940;
}

.renewal-metrics-row {
  border-top: 1px solid rgba(183, 124, 104, 0.1);
  padding-top: 2px;
}

.renewal-metrics-row article {
  border-color: rgba(183, 124, 104, 0.18);
  background: rgba(255, 250, 245, 0.92);
  box-shadow: 0 10px 22px rgba(115, 74, 55, 0.06);
}

.renewal-metrics-row b {
  font-size: 15px;
}

.renewal-metrics-row span {
  color: rgba(60, 41, 36, 0.66);
  font-size: 11px;
  font-weight: 780;
}

@media (max-width: 760px) {
  .renewal-scale-equation,
  .renewal-flow-lane,
  .renewal-command-deck > div,
  .renewal-flow-lane > div {
    grid-template-columns: 1fr;
  }

  .renewal-flow-lane > div::before {
    content: none;
  }
}

/* Final consulting diagnostic map overrides. */
.service-detail-consulting .service-consulting-stage {
  height: 620px;
  min-height: 620px;
}

.service-detail-consulting .consulting-node-goal .consulting-node-head strong {
  font-size: clamp(20px, 1.85vw, 26px);
}

.service-detail-consulting .consulting-node-goal .consulting-node-visual {
  padding: 4px 0 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.service-detail-consulting .consulting-node-goal .consulting-priority-map {
  gap: 8px;
  padding: 18px 8px 8px;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.service-detail-consulting .consulting-node-goal .priority-cell {
  padding: 9px 10px;
  border-radius: 13px;
}

.service-detail-consulting .consulting-node-goal .priority-cell div {
  font-size: 12px;
}

.service-detail-consulting .consulting-node-goal .priority-cell p {
  font-size: 9px;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow {
  grid-template-columns: minmax(0, 1fr) 14px minmax(0, 1fr) 14px minmax(0, 1fr) 14px minmax(0, 1fr);
  grid-template-rows: 50px 24px 24px;
  gap: 7px 5px;
  align-content: center;
  height: 100%;
}

.service-detail-consulting .consulting-node-flow .process-step {
  height: 50px;
  min-height: 0;
  padding: 6px 5px;
  gap: 3px;
}

.service-detail-consulting .consulting-node-flow .process-step b {
  font-size: 11px;
}

.service-detail-consulting .consulting-node-flow .process-step span {
  font-size: 9px;
}

.service-detail-consulting .consulting-node-flow .process-step em {
  display: none;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2),
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4),
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6) {
  display: grid;
  width: 100%;
  height: 100%;
  place-items: center;
  background: transparent;
  color: rgba(47, 102, 234, 0.72);
  font-size: 15px;
  font-style: normal;
  font-weight: 950;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2)::after,
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4)::after,
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6)::after {
  content: none;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2)::before {
  content: "→";
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4)::before {
  content: "→";
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6)::before {
  content: "→";
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(1) {
  grid-column: 1;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2) {
  grid-column: 2;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(3) {
  grid-column: 3;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4) {
  grid-column: 4;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(5) {
  grid-column: 5;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6) {
  grid-column: 6;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(7) {
  grid-column: 7;
  grid-row: 1;
}

.service-detail-consulting .consulting-node-flow .process-breakpoints,
.service-detail-consulting .consulting-node-flow .process-metrics {
  gap: 5px;
  padding: 0;
}

.service-detail-consulting .consulting-node-flow .process-breakpoints span,
.service-detail-consulting .consulting-node-flow .process-metrics span {
  min-height: 24px;
  padding: 0 4px;
  font-size: 9px;
}

.service-detail-consulting .consulting-node-flow .process-breakpoints {
  grid-row: 2;
  grid-template-columns: repeat(4, minmax(0, 1fr));
}

.service-detail-consulting .consulting-node-flow .process-metrics {
  grid-row: 3;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  padding: 0 16px;
}

.service-detail-consulting .consulting-node-gap .consulting-gap-bridge {
  grid-template-columns: minmax(0, 1fr) minmax(78px, 0.7fr) minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) 26px;
  gap: 6px;
}

.service-detail-consulting .consulting-node-gap .gap-column,
.service-detail-consulting .consulting-node-gap .gap-register {
  gap: 4px;
  padding: 6px;
}

.service-detail-consulting .consulting-node-gap .gap-column div,
.service-detail-consulting .consulting-node-gap .gap-register div {
  min-height: 18px;
  font-size: 10px;
}

.service-detail-consulting .consulting-node-gap .gap-column p,
.service-detail-consulting .consulting-node-gap .gap-register p {
  min-height: 16px;
  padding: 0 6px;
  font-size: 9px;
}

.service-detail-consulting .consulting-node-gap .gap-output-card {
  min-height: 26px;
  font-size: 10px;
}

.service-detail-consulting .consulting-node-launch .consulting-launch-scorecard {
  grid-template-columns: minmax(0, 1fr) 104px;
  grid-template-rows: repeat(3, 24px) 30px;
  gap: 6px 8px;
}

.service-detail-consulting .consulting-node-launch .launch-scope p {
  min-width: 0;
  font-size: 10px;
}

.service-detail-consulting .consulting-node-goal .diagnosis-goal-visual::before {
  content: none;
}

.service-detail-consulting .consulting-node-flow .diagnosis-flow-visual::before {
  content: none;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2),
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4),
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6) {
  position: static;
  right: auto;
  bottom: auto;
  border: 0;
  border-radius: 0;
  box-shadow: none;
}

@media (max-width: 560px) {
  .service-detail-consulting .service-consulting-stage {
    height: auto;
    min-height: auto;
    grid-template-columns: 1fr;
    grid-template-rows: auto;
  }

  .service-detail-consulting .service-consulting-stage figcaption {
    grid-column: 1;
  }

  .service-detail-consulting .consulting-node {
    min-height: 238px;
  }

  .service-detail-consulting .consulting-node-goal .consulting-node-visual {
    height: 164px;
  }

  .service-detail-consulting .consulting-node-flow .consulting-process-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: 48px 48px 24px 24px;
    gap: 6px;
  }

  .service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2),
  .service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4),
  .service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6) {
    display: none;
  }

  .service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(1) {
    grid-column: 1;
    grid-row: 1;
  }

  .service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(3) {
    grid-column: 2;
    grid-row: 1;
  }

  .service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(5) {
    grid-column: 2;
    grid-row: 2;
  }

  .service-detail-consulting .consulting-node-flow .consulting-process-flow > .process-step:nth-child(7) {
    grid-column: 1;
    grid-row: 2;
  }

  .service-detail-consulting .consulting-node-flow .process-breakpoints {
    grid-row: 3;
  }

  .service-detail-consulting .consulting-node-flow .process-metrics {
    grid-row: 4;
    padding: 0;
  }
}

/* Consulting map revision: remove inner visual frames and redraw the flow section. */
.service-detail-consulting .consulting-node-flow .consulting-node-visual,
.service-detail-consulting .consulting-node-gap .consulting-node-visual,
.service-detail-consulting .consulting-node-launch .consulting-node-visual {
  padding: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow {
  grid-template-columns: minmax(0, 1fr) 18px minmax(0, 1fr) 18px minmax(0, 1fr) 18px minmax(0, 1fr);
  grid-template-rows: 62px 30px 32px;
  gap: 8px 4px;
  align-content: center;
}

.service-detail-consulting .consulting-node-flow .process-step {
  height: 62px;
  padding: 8px 6px;
  gap: 5px;
  border-color: rgba(47, 102, 234, 0.22);
  border-radius: 14px;
  background: linear-gradient(180deg, #f6f9ff 0%, #eef5ff 100%);
}

.service-detail-consulting .consulting-node-flow .process-step b {
  font-size: 14px;
  line-height: 1;
}

.service-detail-consulting .consulting-node-flow .process-step span {
  color: var(--ink);
  font-size: 11px;
  line-height: 1;
  font-weight: 900;
}

.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(2),
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(4),
.service-detail-consulting .consulting-node-flow .consulting-process-flow > i:nth-child(6) {
  font-size: 17px;
}

.service-detail-consulting .consulting-node-flow .process-breakpoints {
  grid-row: 2;
  gap: 6px;
}

.service-detail-consulting .consulting-node-flow .process-metrics {
  grid-row: 3;
  gap: 7px;
  padding: 0 12px;
}

.service-detail-consulting .consulting-node-flow .process-breakpoints span,
.service-detail-consulting .consulting-node-flow .process-metrics span {
  min-height: 28px;
  font-size: 11px;
  line-height: 1;
  font-weight: 920;
}

.service-detail-consulting .consulting-node-gap .consulting-gap-bridge {
  grid-template-rows: minmax(0, 1fr) 30px;
  gap: 8px;
}

.service-detail-consulting .consulting-node-gap .gap-column,
.service-detail-consulting .consulting-node-gap .gap-register {
  gap: 5px;
  padding: 8px;
}

.service-detail-consulting .consulting-node-gap .gap-column div,
.service-detail-consulting .consulting-node-gap .gap-register div {
  min-height: 20px;
  font-size: 12px;
}

.service-detail-consulting .consulting-node-gap .gap-column p,
.service-detail-consulting .consulting-node-gap .gap-register p {
  min-height: 18px;
  font-size: 10.5px;
}

.service-detail-consulting .consulting-node-gap .gap-output-card {
  min-height: 30px;
  font-size: 12px;
}

.service-detail-consulting .consulting-node-launch .consulting-launch-scorecard {
  grid-template-columns: minmax(0, 1fr) 110px;
  grid-template-rows: repeat(3, 28px) 34px;
  gap: 7px 9px;
}

.service-detail-consulting .consulting-node-launch .score-row {
  grid-template-columns: 38px minmax(0, 1fr) 46px;
  gap: 7px;
}

.service-detail-consulting .consulting-node-launch .score-row em,
.service-detail-consulting .consulting-node-launch .score-row p,
.service-detail-consulting .consulting-node-launch .launch-shortlist div,
.service-detail-consulting .consulting-node-launch .launch-shortlist p,
.service-detail-consulting .consulting-node-launch .launch-scope p {
  font-size: 11px;
  line-height: 1;
}

.service-detail-consulting .consulting-node-launch .launch-shortlist {
  gap: 7px;
  padding: 8px;
}

.service-detail-consulting .consulting-node-launch .launch-shortlist p {
  min-height: 25px;
}

.service-detail-consulting .consulting-node-launch .launch-scope {
  gap: 7px;
}

.service-detail-consulting .consulting-node-launch .launch-scope p {
  min-height: 31px;
}

@media (max-width: 560px) {
  .service-detail-consulting .consulting-node-flow .consulting-process-flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: 58px 58px 28px 28px;
    gap: 7px;
  }

  .service-detail-consulting .consulting-node-flow .process-step {
    height: 58px;
  }
}

/* Consulting map rebuild: clearer consulting-style flow and gap diagnostics. */
.service-detail-consulting .consulting-node small {
  min-height: 26px;
  padding: 0 12px;
  font-size: 12px;
}

.service-detail-consulting .consulting-node-goal .priority-axis-y,
.service-detail-consulting .consulting-node-goal .priority-axis-x,
.service-detail-consulting .consulting-node-goal .priority-cell p {
  font-size: 10.5px;
}

.service-detail-consulting .consulting-node-goal .priority-cell div {
  font-size: 13px;
}

.consulting-process-blueprint {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr) 12px minmax(0, 1fr) 12px minmax(0, 1fr) 12px minmax(0, 1fr);
  grid-template-rows: 54px 31px 31px;
  gap: 7px 4px;
  height: 100%;
  min-height: 0;
  align-content: center;
}

.blueprint-lane-label {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.82);
  color: #526273;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.blueprint-stage {
  display: grid;
  align-content: center;
  min-width: 0;
  padding: 7px 4px;
  border: 1px solid rgba(47, 102, 234, 0.24);
  border-radius: 13px;
  background: linear-gradient(180deg, #f7faff, #eef5ff);
  text-align: center;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.58);
}

.blueprint-stage b {
  color: #315d9a;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
}

.blueprint-stage span {
  margin-top: 7px;
  color: var(--ink);
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.consulting-process-blueprint > i {
  display: grid;
  place-items: center;
  color: rgba(47, 102, 234, 0.74);
  font-size: 15px;
  font-style: normal;
  font-weight: 950;
}

.consulting-process-blueprint > i::before {
  content: "→";
}

.blueprint-risk,
.blueprint-metric {
  display: grid;
  place-items: center;
  min-width: 0;
  min-height: 31px;
  padding: 0 5px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 920;
  line-height: 1;
  white-space: nowrap;
}

.blueprint-risk {
  border: 1px solid rgba(201, 121, 16, 0.16);
  background: #fff7e9;
  color: #8a5a16;
}

.blueprint-metric {
  border: 1px solid rgba(103, 142, 97, 0.16);
  background: #f0f9ee;
  color: #3d6437;
}

.consulting-process-blueprint .blueprint-lane-label:nth-of-type(1) {
  grid-column: 1;
  grid-row: 1;
}

.consulting-process-blueprint .blueprint-lane-label:nth-of-type(2) {
  grid-column: 1;
  grid-row: 2;
}

.consulting-process-blueprint .blueprint-lane-label:nth-of-type(3) {
  grid-column: 1;
  grid-row: 3;
}

.blueprint-stage:nth-of-type(2) {
  grid-column: 2;
  grid-row: 1;
}

.consulting-process-blueprint > i:nth-of-type(1) {
  grid-column: 3;
  grid-row: 1;
}

.blueprint-stage:nth-of-type(3) {
  grid-column: 4;
  grid-row: 1;
}

.consulting-process-blueprint > i:nth-of-type(2) {
  grid-column: 5;
  grid-row: 1;
}

.blueprint-stage:nth-of-type(4) {
  grid-column: 6;
  grid-row: 1;
}

.consulting-process-blueprint > i:nth-of-type(3) {
  grid-column: 7;
  grid-row: 1;
}

.blueprint-stage:nth-of-type(5) {
  grid-column: 8;
  grid-row: 1;
}

.blueprint-risk:nth-of-type(6) {
  grid-column: 2;
  grid-row: 2;
}

.blueprint-risk:nth-of-type(7) {
  grid-column: 4;
  grid-row: 2;
}

.blueprint-risk:nth-of-type(8) {
  grid-column: 6;
  grid-row: 2;
}

.blueprint-risk:nth-of-type(9) {
  grid-column: 8;
  grid-row: 2;
}

.blueprint-metric:nth-of-type(10) {
  grid-column: 2 / span 2;
  grid-row: 3;
}

.blueprint-metric:nth-of-type(11) {
  grid-column: 4 / span 2;
  grid-row: 3;
}

.blueprint-metric:nth-of-type(12) {
  grid-column: 6 / span 3;
  grid-row: 3;
}

.consulting-process-blueprint > :nth-child(1) {
  grid-column: 1;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(2) {
  grid-column: 2;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(3) {
  grid-column: 3;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(4) {
  grid-column: 4;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(5) {
  grid-column: 5;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(6) {
  grid-column: 6;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(7) {
  grid-column: 7;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(8) {
  grid-column: 8;
  grid-row: 1;
}

.consulting-process-blueprint > :nth-child(9) {
  grid-column: 1;
  grid-row: 2;
}

.consulting-process-blueprint > :nth-child(10) {
  grid-column: 2;
  grid-row: 2;
}

.consulting-process-blueprint > :nth-child(11) {
  grid-column: 4;
  grid-row: 2;
}

.consulting-process-blueprint > :nth-child(12) {
  grid-column: 6;
  grid-row: 2;
}

.consulting-process-blueprint > :nth-child(13) {
  grid-column: 8;
  grid-row: 2;
}

.consulting-process-blueprint > :nth-child(14) {
  grid-column: 1;
  grid-row: 3;
}

.consulting-process-blueprint > :nth-child(15) {
  grid-column: 2 / span 2;
  grid-row: 3;
}

.consulting-process-blueprint > :nth-child(16) {
  grid-column: 4 / span 2;
  grid-row: 3;
}

.consulting-process-blueprint > :nth-child(17) {
  grid-column: 6 / span 3;
  grid-row: 3;
}

.consulting-gap-model {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 92px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) 32px;
  gap: 8px;
  height: 100%;
  min-height: 0;
}

.gap-model-side,
.gap-model-core {
  display: grid;
  min-width: 0;
  gap: 5px;
  align-content: center;
  padding: 8px;
  border-radius: 15px;
}

.gap-model-side b,
.gap-model-core b {
  display: grid;
  min-height: 23px;
  place-items: center;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}

.gap-model-side span,
.gap-model-core span {
  display: grid;
  min-height: 22px;
  place-items: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  font-size: 11.5px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.gap-model-benchmark {
  border: 1px solid rgba(201, 121, 16, 0.18);
  background: linear-gradient(135deg, #fff6e6, rgba(255, 255, 255, 0.88));
}

.gap-model-benchmark b {
  color: #8a5a16;
  background: #fff8ed;
}

.gap-model-core {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.72);
}

.gap-model-core b {
  background: #ffffff;
  color: var(--ink);
}

.gap-model-core span {
  color: #9a6418;
}

.gap-model-business {
  border: 1px solid rgba(47, 102, 234, 0.17);
  background: linear-gradient(135deg, #eef6ff, rgba(255, 255, 255, 0.9));
}

.gap-model-business b {
  color: #315d9a;
  background: #eef6ff;
}

.gap-model-output {
  grid-column: 1 / -1;
  display: grid;
  min-height: 32px;
  place-items: center;
  border: 1px solid rgba(103, 142, 97, 0.16);
  border-radius: 999px;
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}

.service-detail-consulting .consulting-node-launch .score-row em,
.service-detail-consulting .consulting-node-launch .score-row p,
.service-detail-consulting .consulting-node-launch .launch-shortlist div,
.service-detail-consulting .consulting-node-launch .launch-shortlist p,
.service-detail-consulting .consulting-node-launch .launch-scope p {
  font-size: 12px;
  font-weight: 900;
}

@media (max-width: 560px) {
  .consulting-process-blueprint {
    grid-template-columns: 50px repeat(2, minmax(0, 1fr));
    grid-template-rows: repeat(2, 54px) 30px 30px;
  }

  .consulting-process-blueprint > i {
    display: none;
  }

  .consulting-gap-model {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: minmax(0, 1fr) minmax(0, 1fr) 32px;
  }

  .gap-model-core {
    grid-column: 1 / -1;
  }
}

/* Consulting card final rebuild: centered labels, larger microcopy, and redesigned graphics. */
.service-detail-consulting .consulting-node-head {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.service-detail-consulting .consulting-node small {
  display: inline-grid;
  place-items: center;
  min-height: 30px;
  padding: 0 14px;
  text-align: center;
  font-size: 13px;
  font-weight: 920;
  line-height: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head,
.service-detail-consulting .consulting-node-launch .consulting-node-head {
  justify-content: flex-end;
  text-align: right;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head strong,
.service-detail-consulting .consulting-node-launch .consulting-node-head strong {
  order: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head small,
.service-detail-consulting .consulting-node-launch .consulting-node-head small {
  order: 2;
}

.service-detail-consulting .consulting-node-goal .priority-axis-y,
.service-detail-consulting .consulting-node-goal .priority-axis-x {
  font-size: 11.5px;
}

.service-detail-consulting .consulting-node-goal .priority-cell div {
  font-size: 14px;
}

.service-detail-consulting .consulting-node-goal .priority-cell p {
  font-size: 11px;
  line-height: 1.18;
}

.service-detail-consulting .consulting-node-goal .priority-decision {
  font-size: 11.5px;
}

.consulting-flow-audit,
.consulting-gap-decision {
  height: 100%;
  min-height: 0;
}

.consulting-flow-audit {
  display: grid;
  grid-template-columns: 58px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) 38px;
  gap: 8px;
}

.flow-audit-spine {
  grid-row: 1 / -1;
  display: grid;
  gap: 7px;
}

.flow-audit-spine span {
  display: grid;
  place-items: center;
  min-width: 0;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #526273;
  font-size: 12px;
  font-weight: 920;
  line-height: 1;
  text-align: center;
}

.flow-audit-map {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  min-height: 0;
}

.flow-audit-map::before {
  position: absolute;
  top: 28px;
  right: 8%;
  left: 8%;
  height: 2px;
  background: linear-gradient(90deg, rgba(47, 102, 234, 0.12), rgba(47, 102, 234, 0.42), rgba(47, 102, 234, 0.12));
  content: "";
}

.flow-audit-map article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: 48px 34px;
  gap: 6px;
  align-content: center;
  min-width: 0;
}

.flow-audit-map article::after {
  position: absolute;
  top: 20px;
  right: -11px;
  display: grid;
  width: 18px;
  height: 18px;
  place-items: center;
  border: 1px solid rgba(47, 102, 234, 0.18);
  border-radius: 999px;
  background: #ffffff;
  color: #2f66ea;
  font-size: 12px;
  font-weight: 950;
  content: "→";
}

.flow-audit-map article:last-child::after {
  content: none;
}

.flow-audit-map b,
.flow-audit-map span {
  display: grid;
  place-items: center;
  min-width: 0;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
}

.flow-audit-map b {
  border: 1px solid rgba(47, 102, 234, 0.22);
  border-radius: 14px;
  background: linear-gradient(180deg, #f7faff, #eef5ff);
  color: #315d9a;
  font-size: 14px;
  font-weight: 950;
}

.flow-audit-map span {
  border: 1px solid rgba(201, 121, 16, 0.16);
  border-radius: 999px;
  background: #fff7e9;
  color: #8a5a16;
  font-size: 12px;
  font-weight: 920;
}

.flow-audit-output {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 8px;
}

.flow-audit-output span,
.flow-audit-output b {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  line-height: 1;
  white-space: nowrap;
}

.flow-audit-output span {
  border: 1px solid rgba(103, 142, 97, 0.16);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
  font-weight: 920;
}

.flow-audit-output b {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 12px;
  font-weight: 930;
}

.consulting-gap-decision {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 78px minmax(0, 1fr);
  grid-template-rows: 58px 42px 38px;
  gap: 8px;
}

.consulting-gap-decision::before {
  position: absolute;
  top: 29px;
  right: 21%;
  left: 21%;
  height: 2px;
  background: linear-gradient(90deg, rgba(201, 121, 16, 0.2), rgba(20, 20, 20, 0.1), rgba(47, 102, 234, 0.2));
  content: "";
}

.gap-decision-input,
.gap-decision-core,
.gap-decision-output {
  position: relative;
  z-index: 1;
  min-width: 0;
}

.gap-decision-input {
  display: grid;
  align-content: center;
  gap: 7px;
  padding: 8px;
  border-radius: 15px;
}

.gap-decision-input.benchmark {
  border: 1px solid rgba(201, 121, 16, 0.18);
  background: linear-gradient(135deg, #fff6e6, rgba(255, 255, 255, 0.9));
}

.gap-decision-input.business {
  border: 1px solid rgba(47, 102, 234, 0.17);
  background: linear-gradient(135deg, #eef6ff, rgba(255, 255, 255, 0.9));
}

.gap-decision-input b,
.gap-decision-input span,
.gap-decision-core span,
.gap-decision-core b,
.gap-decision-output span,
.gap-decision-output b,
.gap-decision-output em {
  display: grid;
  place-items: center;
  min-width: 0;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
}

.gap-decision-input b {
  font-size: 13px;
  font-weight: 950;
}

.gap-decision-input span {
  min-height: 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
}

.gap-decision-core {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 86px minmax(0, 1fr);
  gap: 8px;
}

.gap-decision-core span,
.gap-decision-core b {
  border-radius: 999px;
}

.gap-decision-core span {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: #ffffff;
  color: var(--ink);
  font-size: 12px;
  font-weight: 930;
}

.gap-decision-core b {
  border: 1px solid rgba(201, 121, 16, 0.16);
  background: #fff8ed;
  color: #8a5a16;
  font-size: 12px;
  font-weight: 930;
}

.gap-decision-output {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 62px minmax(0, 0.8fr) minmax(0, 1fr);
  gap: 8px;
}

.gap-decision-output span,
.gap-decision-output b,
.gap-decision-output em {
  border-radius: 999px;
}

.gap-decision-output span {
  border: 1px solid rgba(103, 142, 97, 0.16);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
  font-weight: 930;
}

.gap-decision-output b {
  border: 1px solid rgba(103, 142, 97, 0.18);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 13px;
  font-weight: 950;
}

.gap-decision-output em {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 12px;
  font-style: normal;
  font-weight: 920;
}

.service-detail-consulting .consulting-node-launch .score-row em,
.service-detail-consulting .consulting-node-launch .score-row p,
.service-detail-consulting .consulting-node-launch .launch-shortlist div,
.service-detail-consulting .consulting-node-launch .launch-shortlist p,
.service-detail-consulting .consulting-node-launch .launch-scope p {
  font-size: 12.5px;
}

@media (max-width: 560px) {
  .consulting-flow-audit {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 38px;
  }

  .flow-audit-spine {
    grid-row: auto;
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .flow-audit-map {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .flow-audit-map article::after {
    content: none;
  }

  .consulting-gap-decision {
    grid-template-columns: 1fr;
    grid-template-rows: repeat(2, 58px) 42px 38px;
  }

  .gap-decision-core,
  .gap-decision-output {
    grid-column: 1;
  }
}

/* Flow and team diagnostic canvas redesign. */
.service-detail-consulting .consulting-node-flow .consulting-node-visual {
  overflow: hidden;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head {
  justify-content: flex-end;
  text-align: right;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head strong {
  order: 1;
}

.service-detail-consulting .consulting-node-flow .consulting-node-head small {
  order: 2;
}

.service-detail-consulting .consulting-node small {
  display: inline-grid;
  place-items: center;
  text-align: center;
}

.consulting-flow-audit {
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  grid-template-rows: minmax(0, 1fr) 34px;
  gap: 9px;
  height: 100%;
  min-height: 0;
}

.flow-audit-spine {
  grid-row: 1 / -1;
  display: grid;
  grid-template-rows: 34px repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.flow-audit-spine b,
.flow-audit-spine span {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  text-align: center;
  line-height: 1;
}

.flow-audit-spine b {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.9);
  color: var(--ink);
  font-size: 12px;
  font-weight: 950;
}

.flow-audit-spine span {
  border: 1px solid rgba(47, 102, 234, 0.1);
  background: rgba(255, 255, 255, 0.72);
  color: #526273;
  font-size: 12.5px;
  font-weight: 920;
}

.flow-audit-map {
  position: relative;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 7px;
  min-height: 0;
}

.flow-audit-map::before {
  position: absolute;
  top: 17px;
  right: 10%;
  left: 10%;
  height: 2px;
  background: linear-gradient(90deg, rgba(47, 102, 234, 0.1), rgba(47, 102, 234, 0.36), rgba(47, 102, 234, 0.1));
  content: "";
}

.flow-audit-map article {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-rows: 22px 32px 28px 22px;
  gap: 5px;
  min-width: 0;
  padding: 6px;
  border: 1px solid rgba(47, 102, 234, 0.14);
  border-radius: 15px;
  background: linear-gradient(180deg, rgba(248, 251, 255, 0.96), rgba(241, 247, 255, 0.9));
}

.flow-audit-map article::after {
  position: absolute;
  top: 15px;
  right: -11px;
  z-index: 2;
  display: grid;
  width: 18px;
  height: 18px;
  place-items: center;
  border: 1px solid rgba(47, 102, 234, 0.18);
  border-radius: 999px;
  background: #ffffff;
  color: #2f66ea;
  font-size: 12px;
  font-weight: 950;
  content: "→";
}

.flow-audit-map article:last-child::after {
  content: none;
}

.flow-audit-map small,
.flow-audit-map b,
.flow-audit-map span,
.flow-audit-map em {
  display: grid;
  place-items: center;
  min-width: 0;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
}

.flow-audit-map small {
  min-height: 22px;
  padding: 0;
  border: 1px solid rgba(47, 102, 234, 0.12);
  border-radius: 999px;
  background: #ffffff;
  color: #315d9a;
  font-size: 11px;
  font-weight: 950;
}

.flow-audit-map b {
  color: #315d9a;
  font-size: 13px;
  font-weight: 950;
}

.flow-audit-map span {
  border: 1px solid rgba(201, 121, 16, 0.16);
  border-radius: 999px;
  background: #fff7e9;
  color: #8a5a16;
  font-size: 11.5px;
  font-weight: 920;
}

.flow-audit-map em {
  border: 1px solid rgba(103, 142, 97, 0.14);
  border-radius: 999px;
  background: #f0f9ee;
  color: #3d6437;
  font-size: 11px;
  font-style: normal;
  font-weight: 920;
}

.flow-audit-output {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 8px;
}

.flow-audit-output span,
.flow-audit-output b {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  text-align: center;
  line-height: 1;
  white-space: nowrap;
}

.flow-audit-output span {
  border: 1px solid rgba(103, 142, 97, 0.15);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
  font-weight: 930;
}

.flow-audit-output b {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 12px;
  font-weight: 930;
}

@media (max-width: 560px) {
  .consulting-flow-audit {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto 34px;
  }

  .flow-audit-spine {
    grid-row: auto;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    grid-template-rows: 30px;
  }

  .flow-audit-map {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .flow-audit-map article::after,
  .flow-audit-map::before {
    content: none;
  }
}

/* Compact consulting flow board: prevent crowding in the fixed card width. */
.consulting-flow-board {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: 54px 62px 34px;
  gap: 8px;
  height: 100%;
  min-height: 0;
}

.consulting-flow-board article,
.flow-board-output {
  min-width: 0;
  border-radius: 15px;
}

.consulting-flow-board article {
  display: grid;
  align-content: center;
  gap: 7px;
  padding: 8px 10px;
}

.consulting-flow-board b,
.consulting-flow-board span {
  min-width: 0;
  line-height: 1;
  white-space: nowrap;
}

.consulting-flow-board article > b {
  font-size: 13px;
  font-weight: 950;
}

.flow-board-chain {
  grid-column: 1 / -1;
  border: 1px solid rgba(47, 102, 234, 0.18);
  background: linear-gradient(90deg, #eef5ff, rgba(255, 255, 255, 0.9));
}

.flow-board-chain b {
  color: #315d9a;
}

.flow-board-chain span {
  display: grid;
  place-items: center;
  min-height: 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  font-size: 13px;
  font-weight: 930;
  text-align: center;
}

.flow-board-break {
  border: 1px solid rgba(201, 121, 16, 0.18);
  background: linear-gradient(135deg, #fff7e9, rgba(255, 255, 255, 0.9));
}

.flow-board-owner {
  border: 1px solid rgba(103, 142, 97, 0.16);
  background: linear-gradient(135deg, #f0f9ee, rgba(255, 255, 255, 0.9));
}

.flow-board-break b {
  color: #8a5a16;
}

.flow-board-owner b {
  color: #3d6437;
}

.flow-board-break,
.flow-board-owner {
  grid-template-columns: 1fr;
}

.flow-board-break span,
.flow-board-owner span {
  display: inline-grid;
  place-items: center;
  min-height: 22px;
  padding: 0 9px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink);
  font-size: 12px;
  font-weight: 900;
}

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

.flow-board-break b {
  grid-column: 1 / -1;
}

.flow-board-owner {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.flow-board-owner b {
  grid-column: 1 / -1;
}

.flow-board-output {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 8px;
}

.flow-board-output span,
.flow-board-output b {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  line-height: 1;
  white-space: nowrap;
}

.flow-board-output span {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: #ffffff;
  color: #526273;
  font-size: 12px;
  font-weight: 930;
}

.flow-board-output b {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 12px;
  font-weight: 930;
}

@media (max-width: 560px) {
  .consulting-flow-board {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto 34px;
  }

  .flow-board-chain,
  .flow-board-output {
    grid-column: 1;
  }
}

/* Compact gap decision board. */
.consulting-gap-decision {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: 54px 38px 34px;
  gap: 8px;
  height: 100%;
  min-height: 0;
}

.consulting-gap-decision::before {
  content: none;
}

.gap-decision-input.benchmark {
  grid-column: 1;
  grid-row: 1;
}

.gap-decision-input.business {
  grid-column: 2;
  grid-row: 1;
}

.gap-decision-input {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
  align-content: center;
  min-width: 0;
  padding: 7px 9px;
  border-radius: 15px;
}

.gap-decision-input b {
  font-size: 13px;
  font-weight: 950;
  line-height: 1;
}

.gap-decision-input span {
  min-height: 22px;
  font-size: 12px;
}

.gap-decision-core {
  grid-column: 1 / -1;
  grid-row: 2;
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 8px;
}

.gap-decision-core span,
.gap-decision-core b,
.gap-decision-output span,
.gap-decision-output b,
.gap-decision-output em {
  min-height: 100%;
  line-height: 1;
  white-space: nowrap;
}

.gap-decision-core span,
.gap-decision-core b {
  font-size: 12px;
}

.gap-decision-output {
  grid-column: 1 / -1;
  grid-row: 3;
  display: grid;
  grid-template-columns: 58px minmax(0, 0.78fr) minmax(0, 1fr);
  gap: 8px;
}

.gap-decision-output span,
.gap-decision-output em {
  font-size: 11.5px;
}

.gap-decision-output b {
  font-size: 12.5px;
}

/* Benchmark gap consulting diagram. */
.consulting-gap-consult {
  display: grid;
  grid-template-rows: 66px 38px 31px;
  gap: 8px;
  height: 100%;
  min-height: 0;
}

.gap-consult-inputs {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.gap-consult-inputs::after {
  position: absolute;
  right: calc(50% - 13px);
  bottom: -18px;
  display: grid;
  width: 26px;
  height: 26px;
  place-items: center;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: #ffffff;
  color: #8a5a16;
  font-size: 13px;
  font-weight: 950;
  content: "↓";
  z-index: 2;
}

.gap-consult-inputs article,
.gap-consult-judge,
.gap-consult-output span {
  min-width: 0;
  border-radius: 15px;
}

.gap-consult-inputs article {
  display: grid;
  align-content: center;
  gap: 5px;
  padding: 6px 9px;
}

.gap-consult-benchmark {
  border: 1px solid rgba(201, 121, 16, 0.18);
  background: linear-gradient(135deg, #fff6e6, rgba(255, 255, 255, 0.92));
}

.gap-consult-business {
  border: 1px solid rgba(47, 102, 234, 0.17);
  background: linear-gradient(135deg, #eef6ff, rgba(255, 255, 255, 0.92));
}

.gap-consult-inputs span,
.gap-consult-inputs b,
.gap-consult-judge span,
.gap-consult-judge b,
.gap-consult-output span {
  display: grid;
  place-items: center;
  min-width: 0;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.gap-consult-inputs span {
  font-size: 12px;
  font-weight: 930;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-inputs span {
  min-height: 18px;
  border: 0;
  background: transparent;
  color: inherit;
}

.gap-consult-inputs b {
  min-height: 22px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink);
  font-size: 12px;
  font-weight: 930;
}

.gap-consult-judge {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 8px;
  padding: 0;
}

.gap-consult-judge span,
.gap-consult-judge b {
  border-radius: 999px;
}

.gap-consult-judge span {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: #ffffff;
  color: var(--ink);
  font-size: 12px;
  font-weight: 930;
}

.gap-consult-judge b {
  border: 1px solid rgba(201, 121, 16, 0.16);
  background: #fff8ed;
  color: #8a5a16;
  font-size: 12px;
  font-weight: 930;
}

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

.gap-consult-output span {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 12px;
  font-weight: 930;
}

.service-detail-consulting .consulting-gap-consult b,
.service-detail-consulting .consulting-gap-consult span,
.service-detail-consulting .consulting-gap-consult em {
  width: auto;
  height: auto;
  min-width: 0;
  max-width: none;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-inputs::after {
  content: none;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-inputs b {
  min-height: 22px;
  border: 0;
  border-radius: 999px;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-judge {
  grid-template-columns: 86px minmax(0, 1fr);
}

.service-detail-consulting .consulting-gap-consult .gap-consult-judge span,
.service-detail-consulting .consulting-gap-consult .gap-consult-judge b {
  min-height: 38px;
  border-radius: 999px;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-judge b {
  font-size: 12px;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-output span {
  min-height: 31px;
}

/* Flow board alignment fix: preserve current concept while removing overlap. */
.consulting-flow-board {
  grid-template-rows: 35px 93px 27px;
  gap: 8px;
}

.consulting-flow-board article {
  gap: 5px;
  padding: 7px 9px;
  align-content: stretch;
}

.flow-board-chain {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr);
  align-items: center;
}

.flow-board-chain b {
  display: grid;
  place-items: center;
  height: 100%;
  border-right: 1px solid rgba(47, 102, 234, 0.12);
  font-size: 12px;
  text-align: center;
}

.flow-board-chain span {
  min-height: 22px;
  font-size: 12px;
}

.flow-board-break,
.flow-board-owner {
  align-content: stretch;
}

.flow-board-break {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  grid-template-rows: 23px 29px;
  gap: 7px 5px;
}

.flow-board-owner {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: 20px 22px 22px;
  gap: 5px 8px;
  padding: 8px 14px 10px;
}

.flow-board-break b,
.flow-board-owner b {
  display: grid;
  place-items: center;
  min-height: 0;
  font-size: 12.5px;
  line-height: 1;
  text-align: center;
}

.flow-board-break span,
.flow-board-owner span {
  min-height: 0;
  padding: 0 6px;
  font-size: 11.5px;
}

.flow-board-owner span {
  font-size: 11px;
  min-height: 22px;
}

.flow-board-output {
  grid-template-columns: 76px minmax(0, 1fr);
  gap: 7px;
  align-self: end;
}

.flow-board-output span,
.flow-board-output b {
  min-height: 27px;
  font-size: 11.5px;
}

/* Distinct colored labels and radial gap diagram. */
.service-detail-consulting .consulting-node-goal .consulting-node-head small {
  border-color: rgba(255, 255, 255, 0.18);
  background: rgba(255, 255, 255, 0.12);
  color: rgba(248, 246, 240, 0.86);
}

.service-detail-consulting .consulting-node-flow .consulting-node-head small {
  border-color: rgba(47, 102, 234, 0.16);
  background: #eef5ff;
  color: #315d9a;
}

.service-detail-consulting .consulting-node-gap .consulting-node-head small {
  border-color: rgba(201, 121, 16, 0.18);
  background: #fff7e9;
  color: #8a5a16;
}

.service-detail-consulting .consulting-node-launch .consulting-node-head small {
  border-color: rgba(103, 142, 97, 0.16);
  background: #f0f9ee;
  color: #3d6437;
}

.consulting-gap-consult {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 92px minmax(0, 1fr);
  grid-template-rows: 64px 34px 34px;
  gap: 8px;
}

.gap-consult-inputs {
  display: contents;
}

.gap-consult-inputs::after {
  content: none;
}

.gap-consult-benchmark,
.gap-consult-business {
  grid-row: 1;
  display: grid;
  align-content: center;
  gap: 6px;
  min-width: 0;
  padding: 8px 9px;
  border-radius: 16px;
}

.gap-consult-benchmark {
  grid-column: 1;
}

.gap-consult-business {
  grid-column: 3;
}

.gap-consult-judge {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  display: grid;
  grid-template-columns: 1fr;
  grid-template-rows: 23px 45px;
  gap: 6px;
  padding: 0;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-judge {
  grid-template-columns: 1fr;
}

.gap-consult-judge span,
.gap-consult-judge b {
  display: grid;
  place-items: center;
  min-width: 0;
  text-align: center;
  line-height: 1;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-judge span {
  min-height: 23px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: #ffffff;
  color: var(--ink);
  font-size: 11px;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-judge b {
  min-height: 45px;
  padding: 0 9px;
  border: 1px solid rgba(201, 121, 16, 0.2);
  border-radius: 18px;
  background: #fff8ed;
  color: #8a5a16;
  font-size: 11px;
  line-height: 1;
  white-space: nowrap;
}

.gap-consult-output {
  grid-column: 1 / -1;
  grid-row: 3;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.service-detail-consulting .consulting-gap-consult .gap-consult-output span {
  min-height: 34px;
  border-radius: 999px;
  font-size: 12px;
}

/* Benchmark gap scorecard: distinct consulting comparison table. */
.consulting-gap-scorecard {
  display: grid;
  grid-template-columns: 72px minmax(0, 1fr) minmax(0, 1fr);
  grid-template-rows: 26px repeat(3, 23px) 30px;
  gap: 5px;
  height: 100%;
  min-height: 0;
}

.gap-score-head,
.gap-score-row,
.gap-score-output {
  display: contents;
}

.gap-score-head span,
.gap-score-row b,
.gap-score-row span,
.gap-score-row em,
.gap-score-output span,
.gap-score-output b {
  display: grid;
  place-items: center;
  min-width: 0;
  min-height: 0;
  border-radius: 999px;
  line-height: 1;
  text-align: center;
  white-space: nowrap;
}

.gap-score-head span {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.86);
  color: #526273;
  font-size: 10.5px;
  font-weight: 920;
}

.gap-score-row b {
  border: 1px solid rgba(201, 121, 16, 0.14);
  background: #fff7e9;
  color: #8a5a16;
  font-size: 12px;
  font-weight: 950;
}

.gap-score-row span {
  border: 1px solid rgba(103, 142, 97, 0.14);
  background: #f0f9ee;
  color: #3d6437;
  font-size: 12px;
  font-weight: 920;
}

.gap-score-row em {
  border: 1px solid rgba(47, 102, 234, 0.14);
  background: #eef5ff;
  color: #315d9a;
  font-size: 12px;
  font-style: normal;
  font-weight: 920;
}

.gap-score-output span {
  grid-column: 1;
  grid-row: 5;
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: #ffffff;
  color: var(--ink);
  font-size: 11px;
  font-weight: 930;
}

.gap-score-output b {
  grid-column: 2 / span 2;
  grid-row: 5;
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-size: 11px;
  font-weight: 930;
}

/* Stabilize the scorecard against earlier generic gap-visual rules. */
.consulting-gap-scorecard {
  grid-template-columns: 1fr;
  grid-template-rows: 30px repeat(3, 28px) 36px;
  gap: 5px;
}

.gap-score-head,
.gap-score-row,
.gap-score-output {
  display: grid;
  min-width: 0;
  gap: 6px;
}

.gap-score-head,
.gap-score-row {
  grid-template-columns: 70px minmax(0, 0.9fr) minmax(0, 0.9fr);
}

.gap-score-output {
  grid-template-columns: 70px minmax(0, 1fr);
}

.service-detail-consulting .consulting-gap-scorecard span,
.service-detail-consulting .consulting-gap-scorecard b,
.service-detail-consulting .consulting-gap-scorecard em {
  width: auto;
  height: auto;
  min-width: 0;
  min-height: 0;
  max-width: none;
  padding: 0 5px;
  border-radius: 999px;
  line-height: 1;
  white-space: nowrap;
}

.gap-score-output span {
  grid-column: auto;
  grid-row: auto;
}

.gap-score-output b {
  grid-column: auto;
  grid-row: auto;
}

/* AI implementation scorecard spacing. */
.service-detail-consulting .consulting-node-launch .consulting-launch-scorecard {
  grid-template-columns: minmax(0, 1fr) 108px;
  grid-template-rows: repeat(3, 26px) 35px;
  gap: 11px 15px;
}

.service-detail-consulting .consulting-node-launch .score-row {
  grid-template-columns: 40px minmax(0, 1fr) 50px;
  gap: 10px;
}

.service-detail-consulting .consulting-node-launch .launch-shortlist {
  gap: 11px;
  padding: 9px 10px;
}

.service-detail-consulting .consulting-node-launch .launch-shortlist p {
  min-height: 23px;
}

.service-detail-consulting .consulting-node-launch .launch-scope {
  gap: 14px;
}

.service-detail-consulting .consulting-node-launch .launch-scope p {
  min-height: 35px;
}

/* Agent + Skill service block aligned with the consulting block while keeping four cards. */
.service-detail-skill {
  grid-template-columns: minmax(320px, 0.72fr) minmax(0, 1.28fr);
}

.service-skill-copy {
  align-content: center;
}

.service-detail-skill .service-detail-index {
  display: inline-flex;
  align-items: center;
  width: max-content;
  min-height: 34px;
  margin-bottom: 26px;
  padding: 0 14px;
  border: 1px solid rgba(47, 102, 234, 0.16);
  border-radius: 999px;
  background: rgba(232, 242, 255, 0.9);
  color: #315d9a;
  font-size: 13px;
  font-weight: 900;
}

.service-detail-skill .service-skill-title {
  max-width: 520px;
  font-size: clamp(30px, 2.25vw, 38px);
  line-height: 1.08;
}

.service-detail-skill .service-skill-title .title-line {
  display: block;
  white-space: nowrap;
}

.skill-left-map {
  max-width: 580px;
  margin-top: 24px;
}

.skill-left-map > p {
  max-width: 580px;
  margin: 0;
}

.skill-left-flow {
  display: grid;
  gap: 12px;
  margin-top: 28px;
}

.skill-left-flow article {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  min-height: 82px;
  padding: 14px 16px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 16px 38px rgba(33, 29, 23, 0.05);
}

.skill-left-flow i {
  display: grid;
  place-items: center;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(47, 102, 234, 0.18);
  border-radius: 999px;
  background: #eef5ff;
  color: #315d9a;
  font-style: normal;
  font-size: 12px;
  font-weight: 900;
}

.skill-left-flow strong {
  display: block;
  color: var(--ink);
  font-size: 16px;
  line-height: 1.25;
}

.skill-left-flow span {
  display: block;
  margin-top: 6px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 700;
  line-height: 1.42;
}

.service-detail-skill .service-skill-panel {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  gap: 16px;
  height: 620px;
  min-height: 620px;
  padding: 28px;
}

.service-detail-skill .service-skill-panel figcaption {
  justify-self: start;
  min-height: 34px;
  margin: 0;
  padding: 0 14px;
  border-color: rgba(47, 102, 234, 0.16);
  background: rgba(232, 242, 255, 0.9);
  color: #315d9a;
  font-size: 13px;
  font-weight: 900;
}

.service-detail-skill .service-skill-flow {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  height: 100%;
  min-height: 0;
  margin: 0;
}

.service-detail-skill .service-skill-flow article {
  display: grid;
  grid-template-rows: 22px auto auto minmax(0, 1fr);
  gap: 10px;
  min-height: 0;
  height: 100%;
  padding: 20px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.76);
  box-shadow: none;
}

.service-detail-skill .service-skill-flow article:nth-child(2) {
  background: linear-gradient(135deg, rgba(218, 247, 232, 0.72), rgba(255, 255, 255, 0.86));
}

.service-detail-skill .service-skill-flow article:nth-child(3) {
  background: linear-gradient(135deg, rgba(223, 232, 255, 0.78), rgba(255, 255, 255, 0.86));
}

.service-detail-skill .service-skill-flow article span:first-child {
  color: var(--muted-2);
  font-size: 12px;
  font-weight: 900;
  line-height: 1;
  text-transform: uppercase;
}

.service-detail-skill .service-skill-flow article strong {
  align-self: start;
  margin: 0;
  font-family: var(--display);
  font-size: clamp(23px, 1.8vw, 28px);
  line-height: 1.05;
}

.service-detail-skill .service-skill-flow article p {
  align-self: start;
  min-height: 86px;
  margin: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 650;
  line-height: 1.46;
}

.skill-flow-visual {
  align-self: end;
  min-height: 190px;
  padding: 12px;
  overflow: hidden;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.62);
}

.skill-flow-visual span,
.skill-flow-visual b,
.skill-flow-visual em,
.skill-flow-visual strong,
.skill-flow-visual small,
.skill-flow-visual div {
  min-width: 0;
}

.service-detail-skill .skill-flow-visual b,
.service-detail-skill .skill-flow-visual strong,
.service-detail-skill .skill-flow-visual em,
.service-detail-skill .skill-flow-visual span,
.service-detail-skill .skill-flow-visual p {
  font-family: var(--body);
  margin: 0;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.service-detail-skill .service-skill-flow article .skill-flow-visual strong,
.service-detail-skill .service-skill-flow article .skill-flow-visual p {
  font-family: var(--body);
  margin: 0;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.skill-benchmark-visual {
  display: grid;
  grid-template-rows: 1fr 30px 1fr;
  gap: 8px;
  background: linear-gradient(135deg, #fff8ed, rgba(255, 255, 255, 0.72));
}

.benchmark-source-list,
.benchmark-output-list {
  display: grid;
  gap: 7px;
}

.benchmark-source-list span,
.benchmark-output-list span {
  display: grid;
  place-items: center;
  min-height: 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #8a5a16;
  font-size: 11px;
  font-weight: 900;
}

.benchmark-transfer {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 7px;
  align-items: center;
}

.benchmark-transfer i {
  height: 1px;
  background: rgba(201, 121, 16, 0.24);
}

.benchmark-transfer b {
  display: grid;
  place-items: center;
  min-height: 30px;
  padding: 0 10px;
  border: 1px solid rgba(201, 121, 16, 0.16);
  border-radius: 999px;
  background: #ffffff;
  color: var(--ink);
  font-size: 12px;
}

.skill-model-visual {
  display: grid;
  grid-template-rows: 40px 74px 40px;
  gap: 10px;
  background: linear-gradient(135deg, #f0f9ee, rgba(255, 255, 255, 0.7));
}

.skill-model-input,
.skill-model-output {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 6px;
}

.skill-model-output {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.skill-model-input span,
.skill-model-output span {
  display: grid;
  place-items: center;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.86);
  color: #3d6437;
  font-size: 11px;
  font-weight: 900;
}

.skill-model-core {
  display: grid;
  place-items: center;
  width: 74px;
  height: 74px;
  margin: 0 auto;
  border: 12px solid rgba(103, 142, 97, 0.18);
  border-radius: 999px;
  background: #ffffff;
  text-align: center;
}

.skill-model-core b {
  color: var(--ink);
  font-size: 17px;
  line-height: 1;
}

.skill-model-core small {
  color: #3d6437;
  font-size: 10px;
  font-weight: 900;
}

.skill-agent-visual {
  display: grid;
  grid-template-rows: 58px 1fr 28px;
  gap: 10px;
  background: linear-gradient(135deg, #f3f8ff, rgba(255, 255, 255, 0.7));
}

.agent-runner {
  display: grid;
  place-items: center;
  border: 1px solid rgba(47, 102, 234, 0.13);
  border-radius: 16px;
  background: #ffffff;
  text-align: center;
}

.agent-runner b {
  color: #315d9a;
  font-size: 15px;
  line-height: 1;
}

.agent-runner span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
}

.agent-task-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
}

.agent-task-list span,
.agent-confirm {
  display: grid;
  place-items: center;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
}

.agent-task-list span {
  border: 1px solid rgba(47, 102, 234, 0.12);
  background: rgba(255, 255, 255, 0.86);
  color: #315d9a;
}

.agent-confirm {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
}

.skill-review-visual {
  display: grid;
  grid-template-rows: 40px 74px 40px;
  gap: 10px;
  background: linear-gradient(135deg, #ffffff, #f7f4ee);
}

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

.review-compare span,
.review-loop span,
.review-gap b,
.review-gap em {
  display: grid;
  place-items: center;
  min-height: 0;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
}

.review-compare span {
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink-soft);
}

.review-gap {
  display: grid;
  grid-template-rows: 28px 36px;
  gap: 8px;
}

.review-gap b {
  border: 1px solid rgba(201, 121, 16, 0.14);
  background: #fff7e9;
  color: #8a5a16;
}

.review-gap em {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-style: normal;
}

.review-loop {
  grid-template-columns: 1fr 18px 1fr;
  align-items: center;
}

.review-loop span {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
}

.review-loop i {
  height: 1px;
  background: rgba(103, 142, 97, 0.22);
}

/* Wider Agent + Skill card area with rebuilt visual diagrams. */
.service-detail-skill {
  grid-template-columns: minmax(260px, 0.46fr) minmax(0, 1.54fr);
  gap: 30px;
}

.service-detail-skill .service-skill-title {
  max-width: 380px;
  font-size: clamp(28px, 2vw, 34px);
}

.skill-left-map,
.skill-left-map > p {
  max-width: 380px;
}

.skill-left-flow article {
  min-height: 78px;
  padding: 13px 15px;
}

.service-detail-skill .service-skill-panel {
  padding: 28px 30px;
}

.service-detail-skill .service-skill-flow {
  gap: 12px;
}

.service-detail-skill .service-skill-flow article {
  grid-template-rows: 22px auto 78px minmax(0, 1fr);
  gap: 9px;
  padding: 16px;
}

.service-detail-skill .service-skill-flow article p {
  min-height: 0;
  font-size: 12.5px;
  line-height: 1.42;
}

.skill-flow-visual {
  display: grid;
  align-self: stretch;
  height: 100%;
  min-height: 0;
  padding: 12px;
  border-radius: 18px;
}

.skill-benchmark-visual {
  grid-template-rows: minmax(0, 1fr) 76px 42px;
  gap: 10px;
}

.benchmark-radar {
  position: relative;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 8px;
  border: 1px solid rgba(201, 121, 16, 0.12);
  border-radius: 16px;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(201, 121, 16, 0.12) calc(50% - 1px), rgba(201, 121, 16, 0.12) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(201, 121, 16, 0.12) calc(50% - 1px), rgba(201, 121, 16, 0.12) calc(50% + 1px), transparent calc(50% + 1px)),
    rgba(255, 255, 255, 0.38);
}

.benchmark-radar span,
.benchmark-layers p,
.benchmark-assets em,
.benchmark-assets strong {
  display: grid;
  place-items: center;
  margin: 0;
  min-width: 0;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.benchmark-radar span {
  min-height: 27px;
  border: 1px solid rgba(201, 121, 16, 0.13);
  background: rgba(255, 255, 255, 0.82);
  color: #8a5a16;
}

.benchmark-radar b {
  position: absolute;
  top: 50%;
  left: 50%;
  display: grid;
  place-items: center;
  width: 68px;
  min-height: 32px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 999px;
  background: #ffffff;
  color: var(--ink);
  font-size: 11px;
  transform: translate(-50%, -50%);
}

.benchmark-layers {
  display: grid;
  gap: 8px;
}

.benchmark-layers p {
  min-height: 20px;
  background: rgba(255, 255, 255, 0.86);
  color: #8a5a16;
}

.benchmark-assets {
  display: grid;
  grid-template-rows: 18px 20px;
  gap: 5px;
}

.benchmark-assets em {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
  font-style: normal;
}

.benchmark-assets strong {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
}

.skill-model-visual {
  grid-template-columns: 1fr;
  grid-template-rows: 52px minmax(0, 1fr) 52px 36px;
  gap: 8px;
}

.rule-column {
  display: grid;
  grid-template-columns: 32px repeat(3, minmax(0, 1fr));
  gap: 5px;
  padding: 8px;
  border: 1px solid rgba(103, 142, 97, 0.13);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.55);
}

.rule-column b,
.rule-column span,
.rule-core,
.rule-footer span {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.rule-column b {
  color: #3d6437;
  writing-mode: horizontal-tb;
}

.rule-column span {
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink-soft);
}

.rule-core {
  align-self: center;
  justify-self: center;
  width: 82px;
  height: 82px;
  border: 12px solid rgba(103, 142, 97, 0.18);
  border-radius: 999px;
  background: #ffffff;
  color: var(--ink);
}

.rule-core strong {
  font-size: 17px;
  line-height: 1;
}

.rule-core small {
  color: #3d6437;
  font-size: 10px;
  font-weight: 900;
}

.rule-footer {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.rule-footer span {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
}

.skill-agent-visual {
  grid-template-rows: 56px minmax(0, 1fr) 40px;
  gap: 10px;
}

.agent-head {
  display: grid;
  place-items: center;
  border: 1px solid rgba(47, 102, 234, 0.13);
  border-radius: 16px;
  background: #ffffff;
  text-align: center;
}

.agent-head b {
  color: #315d9a;
  font-size: 16px;
  line-height: 1;
}

.agent-head span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 850;
}

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

.agent-kanban p,
.agent-human span {
  display: grid;
  place-items: center;
  margin: 0;
  min-width: 0;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.agent-kanban p {
  border: 1px solid rgba(47, 102, 234, 0.12);
  background: rgba(255, 255, 255, 0.86);
  color: #315d9a;
}

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

.agent-human span {
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
}

.skill-review-visual {
  grid-template-rows: 48px minmax(0, 1fr) 40px;
  gap: 10px;
}

.review-score {
  display: grid;
  grid-template-columns: 1fr 28px 1fr;
  gap: 8px;
  align-items: center;
}

.review-score span,
.review-delta b,
.review-delta em,
.review-cycle span {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.review-score span {
  min-height: 34px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink-soft);
}

.review-score i,
.review-cycle i {
  height: 1px;
  background: rgba(103, 142, 97, 0.22);
}

.review-delta {
  display: grid;
  grid-template-rows: 42px minmax(0, 1fr);
  gap: 10px;
  padding: 10px;
  border: 1px solid rgba(201, 121, 16, 0.12);
  border-radius: 16px;
  background: rgba(255, 248, 237, 0.74);
}

.review-delta b {
  border: 1px solid rgba(201, 121, 16, 0.14);
  background: #ffffff;
  color: #8a5a16;
}

.review-delta em {
  border: 1px solid rgba(47, 102, 234, 0.13);
  background: #f3f8ff;
  color: #315d9a;
  font-style: normal;
}

.review-cycle {
  display: grid;
  grid-template-columns: 1fr 14px 1.1fr 14px 1fr;
  gap: 6px;
  align-items: center;
}

.review-cycle span {
  min-height: 32px;
  border: 1px solid rgba(103, 142, 97, 0.13);
  background: #f0f9ee;
  color: #3d6437;
}

/* Agent + Skill final fitting: wider left copy, borderless visual drawings. */
.service-detail-skill {
  grid-template-columns: minmax(335px, 0.58fr) minmax(0, 1.42fr);
  gap: 24px;
}

.service-detail-skill .service-skill-title {
  max-width: 430px;
}

.skill-left-map,
.skill-left-map > p {
  max-width: 430px;
}

.skill-left-flow article {
  min-height: 78px;
  padding: 13px 15px;
}

.skill-left-flow span {
  font-size: 12.5px;
  white-space: nowrap;
}

.service-detail-skill .service-skill-panel {
  padding: 26px;
}

.service-detail-skill .service-skill-flow {
  gap: 10px;
}

.service-detail-skill .service-skill-flow article {
  grid-template-rows: 22px auto 88px minmax(0, 1fr);
  gap: 9px;
  padding: 14px;
}

.service-detail-skill .service-skill-flow article p {
  min-height: 0;
  font-size: 13.5px;
  line-height: 1.42;
}

.service-detail-skill .skill-flow-visual {
  height: 100%;
  padding: 8px;
  border: 0;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.46);
}

.service-detail-skill .skill-flow-visual span,
.service-detail-skill .skill-flow-visual b,
.service-detail-skill .skill-flow-visual strong,
.service-detail-skill .skill-flow-visual em,
.service-detail-skill .skill-flow-visual p {
  font-size: 11px;
}

.service-detail-skill .skill-benchmark-visual {
  grid-template-rows: 112px 76px 42px;
  gap: 10px;
}

.service-detail-skill .benchmark-radar {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 7px;
  padding: 6px;
  border: 0;
  background:
    linear-gradient(90deg, transparent calc(50% - 1px), rgba(201, 121, 16, 0.11) calc(50% - 1px), rgba(201, 121, 16, 0.11) calc(50% + 1px), transparent calc(50% + 1px)),
    linear-gradient(0deg, transparent calc(50% - 1px), rgba(201, 121, 16, 0.11) calc(50% - 1px), rgba(201, 121, 16, 0.11) calc(50% + 1px), transparent calc(50% + 1px));
}

.service-detail-skill .benchmark-radar span,
.service-detail-skill .benchmark-layers p,
.service-detail-skill .benchmark-assets em,
.service-detail-skill .benchmark-assets strong {
  border: 0;
  background: rgba(255, 255, 255, 0.82);
}

.service-detail-skill .benchmark-radar span {
  min-height: 34px;
}

.service-detail-skill .benchmark-radar b {
  width: 64px;
  min-height: 28px;
  border: 0;
  box-shadow: 0 10px 24px rgba(33, 29, 23, 0.08);
}

.service-detail-skill .benchmark-layers {
  gap: 8px;
}

.service-detail-skill .benchmark-layers p {
  min-height: 20px;
}

.service-detail-skill .benchmark-assets {
  grid-template-rows: 18px 20px;
  gap: 5px;
}

.service-detail-skill .skill-model-visual {
  grid-template-columns: 1fr;
  grid-template-rows: 44px 76px 44px 34px;
  gap: 9px;
}

.service-detail-skill .rule-column {
  grid-template-columns: 34px repeat(3, minmax(0, 1fr));
  gap: 6px;
  padding: 0;
  border: 0;
  background: transparent;
}

.service-detail-skill .rule-column b,
.service-detail-skill .rule-column span,
.service-detail-skill .rule-footer span {
  min-height: 34px;
  border: 0;
  background: rgba(255, 255, 255, 0.84);
}

.service-detail-skill .rule-core {
  width: 100%;
  height: auto;
  min-height: 76px;
  border: 0;
  border-radius: 18px;
  background:
    radial-gradient(circle at center, rgba(103, 142, 97, 0.16) 0 34%, transparent 35%),
    rgba(255, 255, 255, 0.62);
}

.service-detail-skill .rule-core strong {
  font-size: 18px;
}

.service-detail-skill .rule-footer {
  gap: 8px;
}

.service-detail-skill .agent-head,
.service-detail-skill .review-delta,
.service-detail-skill .review-score span,
.service-detail-skill .review-cycle span,
.service-detail-skill .agent-kanban p,
.service-detail-skill .agent-human span {
  border: 0;
}

.service-detail-skill .skill-agent-visual {
  grid-template-rows: 56px minmax(0, 1fr) 38px;
  gap: 10px;
}

.service-detail-skill .agent-head {
  background: rgba(255, 255, 255, 0.82);
}

.service-detail-skill .agent-kanban {
  gap: 9px;
}

.service-detail-skill .agent-kanban p,
.service-detail-skill .agent-human span {
  min-height: 34px;
}

.service-detail-skill .skill-review-visual {
  grid-template-rows: 42px minmax(0, 1fr) 36px;
  gap: 10px;
}

.service-detail-skill .review-delta {
  grid-template-rows: 38px minmax(0, 1fr);
  padding: 9px;
  background: rgba(255, 248, 237, 0.76);
}

.service-detail-skill .review-delta em {
  border-radius: 18px;
}

.service-detail-skill .review-cycle {
  grid-template-columns: 1fr 12px 1.1fr 12px 1fr;
  gap: 5px;
}

.service-detail-skill .service-detail-index {
  text-transform: none;
}

.service-detail-skill {
  grid-template-columns: minmax(335px, 0.58fr) minmax(0, 1.42fr);
  gap: 20px;
}

.service-detail-skill .service-skill-panel {
  padding: 22px;
}

.service-detail-skill .service-skill-flow {
  gap: 8px;
}

.service-detail-skill .service-skill-flow article {
  padding: 10px;
}

.service-detail-skill .service-skill-flow article p {
  font-size: 14px;
}

.service-detail-skill .skill-flow-visual {
  padding: 6px;
}

.service-detail-skill .review-delta b,
.service-detail-skill .review-delta em {
  border: 0;
}

/* Final width balance: keep left captions single-line and give the four cards more room. */
.service-detail-skill {
  grid-template-columns: minmax(334px, 0.54fr) minmax(0, 1.46fr);
  gap: 16px;
}

.skill-left-flow article {
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 12px;
  padding-right: 12px;
  padding-left: 12px;
}

/* Rebuilt Agent + Skill card visuals as dense consulting workboards. */
.service-detail-skill .skill-flow-visual {
  height: 100%;
  min-height: 0;
  padding: 10px;
  border: 0;
  border-radius: 18px;
  box-shadow: inset 0 0 0 1px rgba(20, 20, 20, 0.04);
}

.service-detail-skill .skill-benchmark-visual,
.service-detail-skill .skill-model-visual,
.service-detail-skill .skill-agent-visual,
.service-detail-skill .skill-review-visual {
  display: grid;
  gap: 10px;
}

.service-detail-skill .skill-benchmark-visual {
  grid-template-rows: 36px 52px 92px 52px;
  background: linear-gradient(180deg, #fff5e8 0%, #fffaf1 58%, #ffffff 100%);
}

.service-detail-skill .skill-model-visual {
  grid-template-rows: minmax(0, 1fr) 64px 38px;
  background: linear-gradient(180deg, #eaf8ee 0%, #f6fbf5 60%, #ffffff 100%);
}

.service-detail-skill .skill-agent-visual {
  grid-template-rows: 50px 38px minmax(0, 1fr) 38px;
  background: linear-gradient(180deg, #edf4ff 0%, #f6f9ff 58%, #ffffff 100%);
}

.service-detail-skill .skill-review-visual {
  grid-template-rows: 44px minmax(0, 1fr) 38px;
  background: linear-gradient(180deg, #fff4ee 0%, #fff9f6 58%, #ffffff 100%);
}

.service-detail-skill .skill-flow-visual span,
.service-detail-skill .skill-flow-visual b,
.service-detail-skill .skill-flow-visual strong,
.service-detail-skill .skill-flow-visual em,
.service-detail-skill .skill-flow-visual p {
  font-family: var(--body);
  margin: 0;
  min-width: 0;
  font-size: 11.5px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.benchmark-consult-head,
.benchmark-consult-output,
.skill-rule-core,
.skill-rule-footer,
.agent-execute-head,
.agent-execute-check,
.review-consult-score,
.review-consult-loop {
  display: grid;
  min-width: 0;
}

.benchmark-consult-head {
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.benchmark-consult-head span,
.benchmark-consult-head b,
.benchmark-consult-sources span,
.benchmark-consult-filter span,
.benchmark-consult-filter em,
.benchmark-consult-output b,
.benchmark-consult-output span,
.skill-rule-stack b,
.skill-rule-stack span,
.skill-rule-core strong,
.skill-rule-core span,
.skill-rule-footer span,
.agent-execute-head b,
.agent-execute-head span,
.agent-execute-lane span,
.agent-execute-board p,
.agent-execute-check span,
.review-consult-score span,
.review-consult-gap b,
.review-consult-gap span,
.review-consult-loop p {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
}

.benchmark-consult-head span,
.benchmark-consult-head b {
  background: rgba(255, 255, 255, 0.8);
  color: #8a5a16;
}

.benchmark-consult-sources {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.benchmark-consult-sources span {
  background: rgba(255, 255, 255, 0.86);
  color: var(--ink-soft);
}

.benchmark-consult-filter {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  grid-template-rows: 26px repeat(2, minmax(0, 1fr));
  gap: 7px;
  padding: 8px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.5);
}

.benchmark-consult-filter em {
  grid-column: 1 / -1;
  background: #ffffff;
  color: #8a5a16;
  font-style: normal;
}

.benchmark-consult-filter span {
  background: #fff8ed;
  color: #8a5a16;
}

.benchmark-consult-output {
  grid-template-rows: 23px 22px;
  gap: 6px;
}

.benchmark-consult-output b {
  background: #f0f9ee;
  color: #3d6437;
}

.benchmark-consult-output span {
  background: #eef5ff;
  color: #315d9a;
}

.skill-rule-stack {
  display: grid;
  grid-template-rows: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.skill-rule-stack > div {
  display: grid;
  grid-template-columns: 38px repeat(3, minmax(0, 1fr));
  gap: 6px;
  min-width: 0;
}

.skill-rule-stack b {
  background: #dff3df;
  color: #3d6437;
}

.skill-rule-stack span {
  background: rgba(255, 255, 255, 0.82);
  color: var(--ink-soft);
}

.skill-rule-core {
  grid-template-rows: 32px 20px;
  place-items: center;
  border-radius: 18px;
  background:
    radial-gradient(circle at center, rgba(103, 142, 97, 0.18) 0 38%, transparent 39%),
    rgba(255, 255, 255, 0.58);
}

.skill-rule-core strong {
  color: var(--ink);
  font-size: 16px;
}

.skill-rule-core span {
  color: #3d6437;
  font-size: 10.5px;
}

.skill-rule-footer {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.skill-rule-footer span {
  background: #eef5ff;
  color: #315d9a;
}

.agent-execute-head {
  grid-template-rows: 24px 18px;
  place-items: center;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.78);
}

.agent-execute-head b {
  color: #315d9a;
  font-size: 15px;
}

.agent-execute-head span {
  color: var(--muted);
  font-size: 10.5px;
}

.agent-execute-lane {
  display: grid;
  grid-template-columns: 1fr 14px 1fr 14px 1fr;
  gap: 4px;
  align-items: center;
}

.agent-execute-lane span {
  background: rgba(255, 255, 255, 0.84);
  color: #315d9a;
}

.agent-execute-lane i,
.review-consult-loop i {
  height: 1px;
  background: rgba(47, 102, 234, 0.22);
}

.agent-execute-board {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 8px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.48);
}

.agent-execute-board p {
  background: #ffffff;
  color: var(--ink-soft);
}

.agent-execute-check {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.agent-execute-check span {
  background: #f0f9ee;
  color: #3d6437;
}

.review-consult-score {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 7px;
}

.review-consult-score span {
  background: rgba(255, 255, 255, 0.84);
  color: var(--ink-soft);
}

.review-consult-gap {
  display: grid;
  grid-template-rows: 28px repeat(3, minmax(0, 1fr));
  gap: 8px;
  padding: 9px;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.5);
}

.review-consult-gap b {
  background: #fff8ed;
  color: #8a5a16;
}

.review-consult-gap span {
  background: #eef5ff;
  color: #315d9a;
}

.review-consult-loop {
  grid-template-columns: 1fr 10px 1.15fr 10px 1fr;
  gap: 4px;
  align-items: center;
}

.review-consult-loop p {
  background: #f0f9ee;
  color: #3d6437;
}

/* Align all four image boards and rebuild narrow layouts for Skill and Agent. */
.service-detail-skill .skill-flow-visual {
  height: 342px;
  min-height: 342px;
  max-height: 342px;
  padding: 12px;
}

.service-detail-skill .skill-model-visual {
  grid-template-rows: 48px minmax(0, 1fr) 38px;
  gap: 10px;
  background: linear-gradient(180deg, #eaf8ee 0%, #f7fcf7 62%, #ffffff 100%);
}

.service-detail-skill .skill-agent-visual {
  grid-template-rows: 50px minmax(0, 1fr) 38px;
  gap: 10px;
  background: linear-gradient(180deg, #edf4ff 0%, #f7faff 62%, #ffffff 100%);
}

.skill-standard-head,
.skill-standard-footer,
.agent-execute-check {
  display: grid;
  min-width: 0;
}

.skill-standard-head {
  grid-template-rows: 25px 17px;
  place-items: center;
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.76);
}

.skill-standard-head b,
.skill-standard-head span,
.skill-standard-layers em,
.skill-standard-layers strong,
.skill-standard-layers span,
.skill-standard-footer span,
.agent-execute-flow em,
.agent-execute-flow strong,
.agent-execute-flow span {
  display: grid;
  place-items: center;
  min-width: 0;
  margin: 0;
  border-radius: 999px;
  font-family: var(--body);
  font-size: 11.5px;
  font-weight: 900;
  line-height: 1;
  text-align: center;
}

.skill-standard-head b {
  color: #3d6437;
}

.skill-standard-head span {
  color: var(--muted);
  font-size: 10.5px;
}

.skill-standard-layers,
.agent-execute-flow {
  display: grid;
  gap: 10px;
  min-width: 0;
}

.skill-standard-layers {
  grid-template-rows: repeat(3, minmax(0, 1fr));
}

.skill-standard-layers article,
.agent-execute-flow article {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  grid-template-rows: 25px 25px;
  gap: 6px 8px;
  min-width: 0;
  padding: 8px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.54);
}

.skill-standard-layers em,
.agent-execute-flow em {
  grid-row: 1 / span 2;
  background: #dff3df;
  color: #3d6437;
  font-style: normal;
}

.skill-standard-layers strong,
.agent-execute-flow strong {
  justify-content: start;
  color: var(--ink);
  font-size: 12px;
}

.skill-standard-layers span,
.agent-execute-flow span {
  justify-content: start;
  color: var(--muted);
  font-size: 10.5px;
}

.skill-standard-footer {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.skill-standard-footer span {
  background: #eef5ff;
  color: #315d9a;
}

.agent-execute-flow {
  grid-template-rows: repeat(3, minmax(0, 1fr));
}

.agent-execute-flow article {
  background: rgba(255, 255, 255, 0.56);
}

.agent-execute-flow em {
  background: #eef5ff;
  color: #315d9a;
}

.service-detail-skill .agent-execute-check {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.service-detail-skill .agent-execute-check span {
  display: grid;
  place-items: center;
  min-width: 0;
  border-radius: 999px;
  background: #f0f9ee;
  color: #3d6437;
  font-size: 11.5px;
  font-weight: 900;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article,
.service-detail-skill .service-skill-flow .agent-execute-flow article {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  grid-template-rows: 24px 24px;
  gap: 6px 8px;
  align-content: center;
  min-width: 0;
  width: auto;
  height: auto;
  min-height: 0;
  padding: 8px;
  overflow: visible;
  border: 0;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.56);
  box-shadow: none;
}

.service-detail-skill .service-skill-flow .skill-standard-layers em,
.service-detail-skill .service-skill-flow .agent-execute-flow em {
  grid-row: 1 / span 2;
  min-height: 48px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers strong,
.service-detail-skill .service-skill-flow .skill-standard-layers span,
.service-detail-skill .service-skill-flow .agent-execute-flow strong,
.service-detail-skill .service-skill-flow .agent-execute-flow span {
  justify-content: start;
  min-height: 0;
  white-space: nowrap;
}

.service-detail-skill .review-consult-loop {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}

.service-detail-skill .review-consult-loop i {
  display: none;
}

.service-detail-skill .review-consult-loop p {
  min-height: 38px;
  padding: 0 4px;
  background: #f0f9ee;
  color: #3d6437;
  white-space: nowrap;
}

/* Compress Skill and Agent inner boards to match the Review board height rhythm. */
.service-detail-skill .skill-model-visual,
.service-detail-skill .skill-agent-visual {
  grid-template-rows: 44px 186px 34px;
  gap: 8px;
  align-content: center;
}

.service-detail-skill .skill-standard-head,
.service-detail-skill .agent-execute-head {
  min-height: 44px;
}

.service-detail-skill .skill-standard-layers,
.service-detail-skill .agent-execute-flow {
  gap: 7px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article,
.service-detail-skill .service-skill-flow .agent-execute-flow article {
  grid-template-rows: 19px 19px;
  gap: 4px 7px;
  padding: 6px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers em,
.service-detail-skill .service-skill-flow .agent-execute-flow em {
  min-height: 42px;
}

.service-detail-skill .skill-standard-footer,
.service-detail-skill .agent-execute-check {
  min-height: 34px;
}

/* Align internal first and last rows to the Review board baseline. */
.service-detail-skill .skill-benchmark-visual {
  grid-template-rows: 46px 68px 104px 70px;
  gap: 10px;
  align-content: stretch;
}

.service-detail-skill .benchmark-consult-head span,
.service-detail-skill .benchmark-consult-head b,
.service-detail-skill .benchmark-consult-sources span {
  min-height: 0;
}

.service-detail-skill .benchmark-consult-filter {
  grid-template-rows: 28px repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.service-detail-skill .benchmark-consult-output {
  grid-template-rows: 30px 30px;
  gap: 8px;
}

.service-detail-skill .skill-model-visual,
.service-detail-skill .skill-agent-visual {
  grid-template-rows: 44px 220px 38px;
  gap: 8px;
  align-content: stretch;
}

.service-detail-skill .skill-standard-footer,
.service-detail-skill .agent-execute-check {
  min-height: 38px;
}

.service-detail-skill .skill-standard-layers,
.service-detail-skill .agent-execute-flow {
  gap: 8px;
}

/* Fix Review footer tags after generic card paragraph rules. */
.service-detail-skill .service-skill-flow .review-consult-loop {
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.2fr) minmax(0, 0.9fr);
  gap: 5px;
  align-items: stretch;
}

.service-detail-skill .service-skill-flow .review-consult-loop p {
  display: grid;
  place-items: center;
  min-height: 38px;
  height: 38px;
  padding: 0 3px;
  border-radius: 999px;
  background: #f0f9ee;
  color: #3d6437;
  font-size: 10.5px;
  font-weight: 900;
  line-height: 1;
  white-space: nowrap;
}

.service-detail-skill .service-skill-flow .review-consult-loop {
  transform: translateY(-4px);
}

/* Improve readability inside all Agent + Skill visual boards. */
.service-detail-skill .skill-flow-visual span,
.service-detail-skill .skill-flow-visual b,
.service-detail-skill .skill-flow-visual strong,
.service-detail-skill .skill-flow-visual em,
.service-detail-skill .skill-flow-visual p {
  font-size: 12.5px;
  line-height: 1.05;
}

.service-detail-skill .skill-flow-visual {
  padding: 10px;
}

.service-detail-skill .benchmark-consult-filter,
.service-detail-skill .review-consult-gap {
  padding: 7px;
}

.service-detail-skill .skill-standard-layers,
.service-detail-skill .agent-execute-flow {
  gap: 7px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article,
.service-detail-skill .service-skill-flow .agent-execute-flow article {
  gap: 4px 6px;
  padding: 6px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers span,
.service-detail-skill .service-skill-flow .agent-execute-flow span {
  font-size: 11.5px;
}

.service-detail-skill .service-skill-flow .review-consult-loop p {
  font-size: 11.5px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers em,
.service-detail-skill .service-skill-flow .agent-execute-flow em {
  font-size: 13px;
  line-height: 1;
}

.service-detail-skill .service-skill-flow .skill-standard-layers strong,
.service-detail-skill .service-skill-flow .agent-execute-flow strong {
  font-size: 15px;
  font-weight: 950;
  line-height: 1.08;
}

.service-detail-skill .service-skill-flow .skill-standard-layers span,
.service-detail-skill .service-skill-flow .agent-execute-flow span {
  font-size: 12.5px;
  line-height: 1.12;
}

.service-detail-skill .skill-standard-head {
  grid-template-rows: 24px 20px;
}

.service-detail-skill .agent-execute-head {
  grid-template-rows: 24px 20px;
}

.service-detail-skill .skill-standard-head b,
.service-detail-skill .skill-standard-head span,
.service-detail-skill .agent-execute-head b,
.service-detail-skill .agent-execute-head span,
.service-detail-skill .service-skill-flow .skill-standard-layers strong,
.service-detail-skill .service-skill-flow .agent-execute-flow strong {
  min-height: 16px;
  line-height: 1.15;
}

/* Make the six inner step titles stronger than their descriptions. */
.service-detail-skill .service-skill-flow .skill-standard-layers article,
.service-detail-skill .service-skill-flow .agent-execute-flow article {
  grid-template-rows: 20px 19px;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article strong,
.service-detail-skill .service-skill-flow .agent-execute-flow article strong {
  min-height: 18px;
  font-size: 16px !important;
  font-weight: 950;
  line-height: 1.08 !important;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article span,
.service-detail-skill .service-skill-flow .agent-execute-flow article span {
  font-size: 13px !important;
  line-height: 1.12 !important;
}

/* Enlarge Review board text without changing the card rhythm. */
.service-detail-skill .skill-review-visual .review-consult-score span {
  font-size: 13.5px !important;
  font-weight: 900;
}

.service-detail-skill .skill-review-visual .review-consult-gap b,
.service-detail-skill .skill-review-visual .review-consult-gap span {
  font-size: 14px !important;
  font-weight: 950;
  line-height: 1.05 !important;
}

.service-detail-skill .service-skill-flow .skill-review-visual .review-consult-loop p {
  font-size: 12.5px !important;
  font-weight: 950;
}

/* Harmonize the other three visual boards with the Review board type scale. */
.service-detail-skill .skill-benchmark-visual .benchmark-consult-head span,
.service-detail-skill .skill-benchmark-visual .benchmark-consult-head b,
.service-detail-skill .skill-benchmark-visual .benchmark-consult-filter em,
.service-detail-skill .skill-benchmark-visual .benchmark-consult-output b {
  font-size: 13.5px !important;
  font-weight: 950;
  line-height: 1.05 !important;
}

.service-detail-skill .skill-benchmark-visual .benchmark-consult-sources span,
.service-detail-skill .skill-benchmark-visual .benchmark-consult-filter span,
.service-detail-skill .skill-benchmark-visual .benchmark-consult-output span {
  font-size: 13px !important;
  font-weight: 950;
  line-height: 1.05 !important;
}

.service-detail-skill .skill-benchmark-visual .benchmark-consult-sources {
  gap: 2px;
}

.service-detail-skill .skill-benchmark-visual .benchmark-consult-sources span {
  font-size: 12.8px !important;
  white-space: nowrap;
}

.service-detail-skill .skill-standard-head b,
.service-detail-skill .agent-execute-head b {
  font-size: 14px !important;
  font-weight: 950;
}

.service-detail-skill .skill-standard-head span,
.service-detail-skill .agent-execute-head span {
  font-size: 13.5px !important;
  font-weight: 950;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article,
.service-detail-skill .service-skill-flow .agent-execute-flow article {
  grid-template-columns: 28px minmax(0, 1fr);
}

.service-detail-skill .service-skill-flow .skill-standard-layers article em,
.service-detail-skill .service-skill-flow .agent-execute-flow article em {
  font-size: 13.5px !important;
}

.service-detail-skill .service-skill-flow .skill-standard-layers article span,
.service-detail-skill .service-skill-flow .agent-execute-flow article span {
  font-size: 13.5px !important;
  line-height: 1.08 !important;
}

.service-detail-skill .skill-standard-footer span,
.service-detail-skill .agent-execute-check span {
  font-size: 13.5px !important;
  font-weight: 950;
}

/* Bring the consulting diagnosis map up to the same readable type scale. */
.service-detail-consulting .diagnosis-goal-visual .priority-axis-y,
.service-detail-consulting .diagnosis-goal-visual .priority-axis-x {
  font-size: 13px !important;
  min-height: 15px;
  line-height: 1.15 !important;
}

.service-detail-consulting .diagnosis-goal-visual .priority-cell {
  gap: 5px;
  padding: 8px 9px;
}

.service-detail-consulting .diagnosis-goal-visual .priority-cell div {
  min-height: 17px;
  font-size: 15px !important;
  font-weight: 950;
  line-height: 1.08 !important;
}

.service-detail-consulting .diagnosis-goal-visual .priority-cell p {
  font-size: 12.5px !important;
  font-weight: 850;
  line-height: 1.12 !important;
}

.service-detail-consulting .diagnosis-goal-visual .priority-decision {
  width: 82px;
  min-height: 34px;
  font-size: 13.5px !important;
  font-weight: 950;
}

.service-detail-consulting .consulting-flow-board {
  grid-template-rows: 40px 88px 27px;
  gap: 8px;
}

.service-detail-consulting .consulting-flow-board article {
  padding: 6px 9px;
}

.service-detail-consulting .flow-board-chain {
  grid-template-columns: 78px minmax(0, 1fr);
  align-items: center;
}

.service-detail-consulting .flow-board-chain b {
  height: auto;
  min-height: 27px;
  font-size: 13.5px !important;
  line-height: 1 !important;
}

.service-detail-consulting .flow-board-chain span {
  min-height: 28px;
  padding: 0 8px;
  font-size: 13.5px !important;
  font-weight: 950;
  line-height: 1 !important;
}

.service-detail-consulting .flow-board-break,
.service-detail-consulting .flow-board-owner {
  align-content: center;
  padding: 7px 8px;
}

.service-detail-consulting .flow-board-break {
  grid-template-rows: 24px 29px;
  gap: 6px 3px;
  padding-right: 5px;
  padding-left: 5px;
}

.service-detail-consulting .flow-board-owner {
  grid-template-rows: 24px 24px 24px;
}

.service-detail-consulting .flow-board-break b,
.service-detail-consulting .flow-board-owner b {
  min-height: 24px;
  font-size: 14px !important;
  line-height: 1 !important;
}

.service-detail-consulting .flow-board-break span,
.service-detail-consulting .flow-board-owner span {
  min-height: 26px;
  padding: 0 2px;
  font-size: 13.5px !important;
  font-weight: 950;
  line-height: 1 !important;
}

.service-detail-consulting .flow-board-break span {
  padding: 0;
  font-size: 13px !important;
}

.service-detail-consulting .flow-board-output {
  grid-template-columns: 72px minmax(0, 1fr);
  gap: 7px;
}

.service-detail-consulting .flow-board-output span,
.service-detail-consulting .flow-board-output b {
  min-height: 27px;
  font-size: 13px !important;
  font-weight: 950;
  line-height: 1 !important;
}

.service-detail-consulting .gap-score-head span,
.service-detail-consulting .gap-score-row b,
.service-detail-consulting .gap-score-row span,
.service-detail-consulting .gap-score-row em,
.service-detail-consulting .gap-score-output span,
.service-detail-consulting .gap-score-output b {
  font-size: 13.5px !important;
  font-weight: 950;
  line-height: 1 !important;
}

.service-detail-consulting .consulting-node-launch .score-row em,
.service-detail-consulting .consulting-node-launch .score-row p,
.service-detail-consulting .consulting-node-launch .launch-shortlist div,
.service-detail-consulting .consulting-node-launch .launch-shortlist p,
.service-detail-consulting .consulting-node-launch .launch-scope p {
  font-size: 13.5px !important;
  font-weight: 950;
  line-height: 1 !important;
}

/* Service hero graphic text scale: enlarge small labels without changing card titles. */
.service-page .service-stage-top span {
  font-size: 13.5px;
  font-weight: 950;
}

.service-page .service-diagnosis-list {
  gap: 10px;
}

.service-page .service-diagnosis-list span {
  min-height: 38px;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
}

.service-page .service-method-source small,
.service-page .service-method-core small {
  min-height: 26px;
  font-size: 13px;
  font-weight: 950;
}

.service-page .service-method-source span,
.service-page .service-method-core span {
  font-size: 14px;
  font-weight: 820;
  line-height: 1.28;
}

.service-page .service-result-graphic {
  height: 92px;
  padding: 8px 10px;
}

.service-page .service-result-skill .service-result-graphic {
  grid-template-columns: 126px 18px 68px;
  gap: 7px;
}

.service-page .skill-source-list {
  align-self: center;
  height: 76px;
  gap: 5px;
  max-height: 100%;
  grid-template-rows: repeat(3, 22px);
  align-content: center;
  padding: 0;
  border: 0 !important;
  border-radius: 0;
  background: transparent !important;
  box-shadow: none !important;
}

.service-page .skill-source-list span,
.service-page .app-interface span,
.service-page .review-signal-grid span {
  min-height: 22px;
  font-size: 13px;
  font-weight: 950;
  line-height: 1;
}

.service-page .skill-source-list span {
  border: 0 !important;
  box-shadow: none !important;
}

.service-page .skill-callable {
  grid-template-rows: 18px 15px;
  align-content: center;
  gap: 5px;
  width: 64px;
  height: 64px;
}

.service-page .agent-token,
.service-page .review-skill-call {
  grid-template-rows: 18px 15px;
  align-content: center;
  gap: 5px;
}

.service-page .skill-callable b,
.service-page .agent-token b,
.service-page .review-skill-call b {
  display: grid;
  min-height: 18px;
  place-items: center;
  font-size: 14px;
  font-weight: 950;
  line-height: 1.12;
}

.service-page .skill-callable span,
.service-page .review-skill-call span,
.service-page .agent-token span {
  display: grid;
  min-height: 15px;
  place-items: center;
  font-size: 12px;
  font-weight: 900;
  line-height: 1.12;
}

.service-page .service-result-app .service-result-graphic {
  grid-template-columns: 62px 150px;
  gap: 10px;
}

.service-page .agent-token {
  width: 58px;
  height: 64px;
}

.service-page .agent-token b {
  font-size: 13.5px;
}

.service-page .app-interface {
  min-height: 64px;
  gap: 7px;
  padding: 8px;
}

.service-page .service-result-review .service-result-graphic {
  grid-template-columns: 136px 30px 62px;
  gap: 8px;
  padding-right: 8px;
  padding-left: 8px;
}

.service-page .review-signal-grid {
  grid-template-columns: repeat(2, 64px);
  gap: 8px;
}

.service-page .review-check {
  width: 30px;
  height: 30px;
}

.service-page .review-skill-call {
  width: 62px;
  height: 64px;
}

.service-page .review-signal-grid span {
  min-height: 28px;
  padding: 0 8px;
  font-size: 13px;
}

/* 03 workflow heading: keep it below the service-content hero hierarchy. */
#workflow {
  overflow-x: clip;
}

#workflow .service-section-heading {
  max-width: 980px;
  margin-right: auto;
  margin-left: auto;
}

#workflow .service-workflow-index {
  display: inline-flex;
  align-items: center;
  min-height: 36px;
  padding: 0 16px;
  border: 1px solid rgba(103, 142, 97, 0.18);
  border-radius: 999px;
  background: rgba(232, 246, 229, 0.9);
  color: #3d6437;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
  text-transform: none;
}

#workflow .service-workflow-title {
  max-width: 1040px;
  margin-top: 20px;
  font-size: clamp(36px, 4.1vw, 58px);
  line-height: 1.12;
  white-space: nowrap;
}

#workflow .service-workflow-lede {
  max-width: 940px;
  margin-top: 22px;
  font-size: clamp(18px, 1.35vw, 21px);
  line-height: 1.52;
}

#workflow .service-implementation-map {
  display: grid;
  grid-template-rows: auto;
  gap: 0;
  margin-top: 52px;
  padding: 28px;
  border: 1px solid rgba(20, 20, 20, 0.08);
  border-radius: 34px;
  background:
    linear-gradient(90deg, rgba(20, 20, 20, 0.04) 1px, transparent 1px),
    linear-gradient(0deg, rgba(20, 20, 20, 0.035) 1px, transparent 1px),
    linear-gradient(135deg, #e4ecff 0%, #ffffff 48%, #e4f7ee 100%);
  background-size: 72px 72px, 72px 72px, auto;
  box-shadow: var(--shadow);
}

#workflow .service-implementation-visual {
  display: grid;
  grid-template-rows: auto 1fr;
  gap: 18px;
  min-width: 0;
  margin: 0;
}

#workflow .service-implementation-visual figcaption {
  display: inline-flex;
  align-items: center;
  justify-self: start;
  min-height: 38px;
  padding: 0 18px;
  border: 1px solid rgba(44, 93, 176, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.74);
  color: #28579e;
  font-size: 15px;
  font-weight: 950;
  line-height: 1;
}

#workflow .implementation-flow-map {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  grid-template-rows: minmax(500px, 1fr) auto;
  gap: 28px;
  min-height: 610px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#workflow .implementation-lane {
  position: relative;
  display: grid;
  grid-template-rows: 112px minmax(0, 1fr);
  gap: 8px;
  min-width: 0;
  padding: 16px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 18px 44px rgba(33, 29, 23, 0.06);
}

#workflow .implementation-lane::before {
  content: "AI-APP 功能覆盖";
  position: absolute;
  bottom: 16px;
  left: 16px;
  z-index: 3;
  display: inline-flex;
  align-items: center;
  min-height: 26px;
  padding: 0 11px;
  border: 1px solid rgba(var(--lane-accent-rgb), 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.82);
  color: var(--lane-accent);
  font-size: 11px;
  font-weight: 950;
  line-height: 1;
  box-shadow: 0 8px 20px rgba(var(--lane-accent-rgb), 0.06);
}

#workflow .implementation-lane:not(:last-of-type)::after {
  content: "→";
  position: absolute;
  top: 208px;
  right: -25px;
  z-index: 2;
  display: block;
  width: auto;
  height: auto;
  transform: translateY(-50%);
  border: 0;
  border-radius: 0;
  background: none;
  color: #28579e;
  font-size: 22px;
  font-weight: 950;
  line-height: 1;
  box-shadow: none;
}

#workflow .implementation-lane-head {
  display: grid;
  gap: 9px;
  align-content: start;
}

#workflow .implementation-lane-head small {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  min-height: 28px;
  padding: 0 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.75);
  color: var(--muted);
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}

#workflow .implementation-lane-head strong {
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(26px, 2.2vw, 36px);
  font-weight: 650;
  line-height: 1.02;
}

#workflow .implementation-lane-head span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  min-height: 34px;
  padding: 0 14px;
  border-radius: 999px;
  font-size: 15px;
  font-weight: 950;
  line-height: 1;
}

#workflow .implementation-lane-growth {
  --lane-accent: #28579e;
  --lane-accent-rgb: 44, 93, 176;
  background: linear-gradient(180deg, rgba(231, 240, 255, 0.94), rgba(255, 255, 255, 0.84));
}

#workflow .implementation-lane-ops {
  --lane-accent: #356f31;
  --lane-accent-rgb: 53, 111, 49;
  background: linear-gradient(180deg, rgba(233, 248, 229, 0.94), rgba(255, 255, 255, 0.84));
}

#workflow .implementation-lane-fran {
  --lane-accent: #a46209;
  --lane-accent-rgb: 164, 98, 9;
  background: linear-gradient(180deg, rgba(255, 244, 225, 0.96), rgba(255, 255, 255, 0.86));
}

#workflow .implementation-lane-train {
  --lane-accent: #6740b6;
  --lane-accent-rgb: 103, 64, 182;
  background: linear-gradient(180deg, rgba(241, 234, 255, 0.96), rgba(255, 255, 255, 0.86));
}

#workflow .implementation-lane-growth .implementation-lane-head span {
  background: #eaf2ff;
  color: #28579e;
}

#workflow .implementation-lane-ops .implementation-lane-head span {
  background: #eaf7e8;
  color: #356f31;
}

#workflow .implementation-lane-fran .implementation-lane-head span {
  background: #fff1dc;
  color: #a46209;
}

#workflow .implementation-lane-train .implementation-lane-head span {
  background: #f0e8ff;
  color: #6740b6;
}

#workflow .implementation-coverage-map {
  position: relative;
  display: grid;
  grid-template-rows: auto auto;
  gap: 30px;
  align-content: start;
  min-width: 0;
  min-height: 340px;
}

#workflow .implementation-coverage-map::before {
  content: none;
}

#workflow .implementation-process-list,
#workflow .implementation-app-functions {
  position: relative;
  display: grid;
  gap: 8px;
  min-width: 0;
  padding-top: 26px;
}

#workflow .implementation-process-list::before,
#workflow .implementation-app-functions::before {
  position: absolute;
  top: 0;
  left: 0;
  color: rgba(77, 76, 71, 0.72);
  font-size: 12px;
  font-weight: 950;
  line-height: 1;
}

#workflow .implementation-process-list::before {
  content: "细分业务流程";
}

#workflow .implementation-app-functions::before {
  content: "AI-APP 功能覆盖";
}

#workflow .implementation-process-list b,
#workflow .implementation-app-functions span {
  display: grid;
  place-items: center;
  min-height: 34px;
  padding: 0 10px;
  border: 1px solid rgba(20, 20, 20, 0.06);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.76);
  color: var(--ink);
  font-size: 15px;
  font-weight: 950;
  line-height: 1.12;
  text-align: center;
}

#workflow .implementation-process-list {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-content: start;
  overflow: visible;
}

#workflow .implementation-process-list b {
  position: relative;
  min-height: 70px;
  padding: 10px 6px;
  border-radius: 20px;
  background: rgba(255, 255, 255, 0.78);
  color: var(--ink);
  font-size: 18px;
  font-weight: 900;
  line-height: 1.18;
  white-space: nowrap;
  overflow: visible;
  box-shadow: 0 14px 28px rgba(33, 29, 23, 0.055), inset 0 1px 0 rgba(255, 255, 255, 0.9);
}

#workflow .implementation-process-list b span {
  display: block;
}

#workflow .implementation-process-list b:not(:last-child)::after {
  content: "→";
  position: absolute;
  top: 50%;
  right: -16px;
  z-index: 1;
  display: block;
  width: auto;
  height: auto;
  transform: translateY(-50%);
  border: 0;
  border-radius: 0;
  background: none;
  color: #28579e;
  font-size: 16px;
  font-weight: 950;
  line-height: 1;
  box-shadow: none;
}

#workflow .implementation-lane-growth .implementation-process-list b {
  border-color: rgba(44, 93, 176, 0.14);
  background: linear-gradient(180deg, #ffffff, #eef5ff);
  color: #1f4d91;
}

#workflow .implementation-lane-fran .implementation-process-list b {
  border-color: rgba(164, 98, 9, 0.16);
  background: linear-gradient(180deg, #ffffff, #fff3df);
  color: #8b5408;
}

#workflow .implementation-lane-ops .implementation-process-list b {
  border-color: rgba(53, 111, 49, 0.15);
  background: linear-gradient(180deg, #ffffff, #edf8ea);
  color: #2f662b;
}

#workflow .implementation-lane-train .implementation-process-list b {
  border-color: rgba(103, 64, 182, 0.16);
  background: linear-gradient(180deg, #ffffff, #f1eaff);
  color: #5c39a8;
}

#workflow .implementation-lane-growth .implementation-process-list b::after {
  color: #28579e;
}

#workflow .implementation-lane-fran .implementation-process-list b::after {
  color: #a46209;
}

#workflow .implementation-lane-ops .implementation-process-list b::after {
  color: #356f31;
}

#workflow .implementation-lane-train .implementation-process-list b::after {
  color: #6740b6;
}

#workflow .implementation-app-functions {
  grid-template-columns: 1fr;
  position: relative;
  z-index: 2;
  align-content: start;
  gap: 10px;
  padding: 20px 0 0;
  border: 0;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
}

#workflow .implementation-app-functions::before {
  content: none;
}

#workflow .implementation-app-functions span {
  --link-height: 60px;
  position: relative;
  z-index: 1;
  display: grid;
  place-items: center;
  width: 46%;
  min-height: 34px;
  padding: 0 8px;
  border-radius: 14px;
  font-size: 14px;
  line-height: 1;
  white-space: nowrap;
  overflow: visible;
}

#workflow .implementation-app-functions span::before {
  content: "";
  position: absolute;
  bottom: 100%;
  left: 50%;
  z-index: -1;
  width: 2px;
  height: calc(var(--link-height) - 7px);
  transform: translateX(-50%);
  border-radius: 999px 999px 0 0;
  background: linear-gradient(180deg, rgba(var(--lane-accent-rgb), 0.42), rgba(var(--lane-accent-rgb), 0.78));
  pointer-events: none;
}

#workflow .implementation-app-functions span::after {
  content: "";
  position: absolute;
  bottom: calc(100% - 2px);
  left: 50%;
  z-index: 2;
  width: 0;
  height: 0;
  transform: translateX(-50%);
  border-right: 5px solid transparent;
  border-left: 5px solid transparent;
  border-top: 7px solid var(--lane-accent);
  background: none;
  pointer-events: none;
}

#workflow .implementation-app-functions span:nth-child(2) {
  --link-height: 104px;
}

#workflow .implementation-app-functions span:nth-child(3) {
  --link-height: 148px;
}

#workflow .implementation-app-functions span:nth-child(4) {
  --link-height: 192px;
}

#workflow .implementation-app-functions .map-all::before {
  content: none;
}

#workflow .implementation-app-functions .map-all::after {
  content: none;
}

#workflow .implementation-app-functions .map-c1 {
  justify-self: start;
}

#workflow .implementation-app-functions .map-c2 {
  justify-self: center;
}

#workflow .implementation-app-functions .map-c3 {
  justify-self: end;
}

#workflow .implementation-app-functions .map-all {
  justify-self: center;
  width: 58%;
  min-height: 34px;
  margin: 0;
}

#workflow .implementation-lane-train .implementation-app-functions .map-c1 {
  font-size: 10px;
}

#workflow .implementation-lane-growth .implementation-app-functions span {
  background: rgba(234, 242, 255, 0.86);
  color: #28579e;
}

#workflow .implementation-lane-ops .implementation-app-functions span {
  background: rgba(234, 247, 232, 0.86);
  color: #356f31;
}

#workflow .implementation-lane-fran .implementation-app-functions span {
  background: rgba(255, 241, 220, 0.86);
  color: #a46209;
}

#workflow .implementation-lane-train .implementation-app-functions span {
  background: rgba(240, 232, 255, 0.86);
  color: #6740b6;
}

#workflow .implementation-spine {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: auto 1fr auto 1fr auto 1fr auto;
  gap: 12px;
  align-items: center;
  min-height: 42px;
  padding: 0;
  border: 0;
  border-radius: 0;
  background: transparent;
}

#workflow .implementation-spine span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 0 16px;
  border-radius: 999px;
  background: #eef5ff;
  color: #28579e;
  font-size: 15px;
  font-weight: 950;
  white-space: nowrap;
}

#workflow .implementation-spine i {
  display: block;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(44, 93, 176, 0.1), rgba(44, 93, 176, 0.42));
}

#workflow .service-implementation-copy {
  display: grid;
  grid-template-columns: minmax(360px, 0.74fr) minmax(0, 1fr);
  gap: 16px 28px;
  align-items: center;
  padding: 24px;
  border: 1px solid rgba(20, 20, 20, 0.07);
  border-radius: 26px;
  background: rgba(255, 255, 255, 0.76);
}

#workflow .service-implementation-copy > span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  justify-self: start;
  min-height: 34px;
  padding: 0 14px;
  border: 1px solid rgba(103, 142, 97, 0.18);
  border-radius: 999px;
  background: rgba(232, 246, 229, 0.9);
  color: #3d6437;
  font-size: 14px;
  font-weight: 950;
  line-height: 1;
}

#workflow .service-implementation-copy h3 {
  margin: 0;
  color: var(--ink);
  font-family: var(--display);
  font-size: clamp(30px, 2.8vw, 44px);
  font-weight: 650;
  line-height: 1.14;
}

#workflow .service-implementation-copy p {
  grid-row: 1 / span 2;
  grid-column: 2;
  margin: 0;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.55;
}

#workflow .implementation-copy-points {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

#workflow .implementation-copy-points article {
  display: grid;
  gap: 6px;
  min-height: 72px;
  padding: 14px 16px;
  border: 1px solid rgba(20, 20, 20, 0.06);
  border-radius: 18px;
  background: rgba(255, 255, 255, 0.72);
}

#workflow .implementation-copy-points b {
  color: var(--ink);
  font-size: 17px;
  font-weight: 950;
}

#workflow .implementation-copy-points span {
  color: var(--muted);
  font-size: 15px;
  line-height: 1.4;
}

@media (max-width: 1180px) {
  #workflow .implementation-flow-map {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    grid-template-rows: auto auto auto;
  }

  #workflow .implementation-lane:not(:last-of-type)::after {
    display: none;
  }

  #workflow .service-implementation-copy {
    grid-template-columns: 1fr;
  }

  #workflow .service-implementation-copy p {
    grid-row: auto;
    grid-column: auto;
  }
}

@media (max-width: 760px) {
  #workflow .service-workflow-title {
    white-space: normal;
  }

  #workflow .service-implementation-map {
    padding: 18px;
  }

  #workflow .implementation-flow-map,
  #workflow .implementation-copy-points {
    grid-template-columns: 1fr;
  }

  #workflow .implementation-spine {
    grid-template-columns: 1fr;
    border-radius: 22px;
  }

  #workflow .implementation-spine i {
    display: none;
  }
}

/* Keep hero CTA-to-first-module spacing consistent with the product page. */
.cases-page .growth-keys-section {
  padding-top: 28px;
}

.service-page .service-hero-stage {
  margin-top: 76px;
}

.about-company-hero-v2 {
  padding-bottom: 38px;
}

.about-company-statement.about-company-module-section {
  padding-top: 38px;
  border-top: 0;
}

@media (max-width: 720px) {
  body.home .home-hero-title {
    width: min(100%, 360px);
    max-width: 100%;
    font-size: clamp(36px, 10vw, 42px);
    line-height: 1.14;
  }

  body.home .home-hero-title .title-line,
  body.home .home-hero-lede span {
    white-space: normal;
  }

  body.home .home-hero-lede {
    width: min(100%, 340px);
    max-width: 100%;
    font-size: 17px;
    line-height: 1.62;
  }
}

@media (max-width: 380px) {
  body.home .home-hero-title {
    width: min(100%, 330px);
    font-size: clamp(34px, 10vw, 38px);
  }
}
