:root {
  --bg: #f4f5f2;
  --surface: #ffffff;
  --surface-2: #eef0ec;
  --ink: #171a18;
  --muted: #68706a;
  --line: #d9ddd8;
  --line-strong: #b9c0ba;
  --acid: #d9f45b;
  --acid-strong: #bddc2c;
  --blue: #2f6fed;
  --coral: #ef6a4b;
  --green: #16835c;
  --amber: #d28a16;
  --purple: #7257d9;
  --sidebar: #1c211e;
  --sidebar-muted: #a7b0aa;
  --radius: 8px;
  --shadow: 0 18px 48px rgba(28, 33, 30, 0.14);
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: "Noto Sans SC", system-ui, sans-serif;
  letter-spacing: 0;
  overflow-x: hidden;
}

button, input { font: inherit; }
button { color: inherit; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 252px minmax(0, 1fr); }

.sidebar {
  position: sticky;
  top: 0;
  height: 100vh;
  padding: 22px 16px 16px;
  background: var(--sidebar);
  color: #f8faf7;
  display: flex;
  flex-direction: column;
  z-index: 20;
}

.brand { display: flex; gap: 11px; align-items: center; color: inherit; text-decoration: none; padding: 0 6px 22px; }
.brand-mark { width: 38px; height: 38px; display: grid; place-items: center; background: var(--acid); color: var(--ink); border-radius: 6px; }
.brand-mark svg { width: 22px; }
.brand span:last-child { min-width: 0; display: grid; gap: 2px; }
.brand strong { font-size: 15px; }
.brand small { color: var(--sidebar-muted); font-size: 10px; line-height: 1.35; max-width: 170px; }

.nav-list { display: grid; gap: 4px; }
.nav-item {
  width: 100%; min-height: 44px; border: 0; border-radius: 6px; background: transparent; color: var(--sidebar-muted);
  display: grid; grid-template-columns: 20px 1fr auto; align-items: center; gap: 10px; padding: 0 12px; text-align: left; cursor: pointer;
}
.nav-item svg { width: 18px; }
.nav-item:hover { background: rgba(255,255,255,.07); color: #fff; }
.nav-item.is-active { background: #303831; color: #fff; box-shadow: inset 3px 0 0 var(--acid); }
.nav-count { font: 600 10px "Roboto Mono", monospace; color: #849088; }

.sidebar-note { margin-top: auto; display: flex; gap: 9px; align-items: flex-start; padding: 14px 10px; border-top: 1px solid #353c37; }
.sidebar-note div { display: grid; gap: 3px; }
.sidebar-note strong { font-size: 12px; }
.sidebar-note small { font-size: 10px; color: var(--sidebar-muted); }
.status-dot { width: 8px; height: 8px; margin-top: 5px; border-radius: 50%; background: var(--acid); box-shadow: 0 0 0 4px rgba(217,244,91,.12); }

.member-card { border: 1px solid #465048; border-radius: 8px; background: #283029; color: #fff; padding: 12px; display: grid; grid-template-columns: 34px 1fr 18px; gap: 9px; align-items: center; text-align: left; cursor: pointer; }
.member-card:hover { border-color: var(--acid); }
.member-card > svg { width: 16px; color: var(--acid); }
.member-card span:nth-child(2) { display: grid; gap: 2px; }
.member-card strong { font-size: 12px; }
.member-card small { font-size: 10px; color: var(--sidebar-muted); }
.feedback-card { border: 1px solid rgba(255,255,255,.13); border-radius: 8px; background: transparent; color: #dfe6dc; padding: 11px 12px; display: grid; grid-template-columns: 28px 1fr; gap: 9px; align-items: center; text-align: left; cursor: pointer; }
.feedback-card:hover { border-color: var(--acid); background: rgba(217,255,71,.08); }
.feedback-card > svg { width: 18px; color: var(--acid); }
.feedback-card span { display: grid; gap: 2px; }
.feedback-card strong { font-size: 12px; }
.feedback-card small { color: var(--sidebar-muted); font-size: 10px; line-height: 1.45; }
.legal-links { display: flex; flex-wrap: wrap; gap: 8px 10px; padding: 0 2px; }
.legal-links a { color: var(--sidebar-muted); font-size: 10px; text-decoration: none; }
.legal-links a:hover { color: var(--acid); }
.member-icon { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 6px; background: var(--acid); color: var(--ink); }
.member-icon svg { width: 17px; }

.main-column { min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 15; height: 68px; padding: 0 32px; border-bottom: 1px solid var(--line); background: rgba(244,245,242,.94); backdrop-filter: blur(12px); display: flex; align-items: center; justify-content: space-between; gap: 20px; }
.search-trigger { width: min(480px, 60vw); height: 40px; border: 1px solid var(--line); background: var(--surface); border-radius: 6px; display: flex; align-items: center; gap: 10px; padding: 0 12px; color: var(--muted); cursor: pointer; }
.search-trigger:hover { border-color: var(--line-strong); }
.search-trigger svg { width: 17px; }
.search-trigger span { flex: 1; text-align: left; font-size: 13px; }
kbd { padding: 2px 6px; border: 1px solid var(--line); border-bottom-width: 2px; border-radius: 4px; background: var(--surface-2); font: 500 10px "Roboto Mono", monospace; }
.topbar-actions { display: flex; align-items: center; gap: 9px; }
.icon-button { position: relative; width: 38px; height: 38px; border: 1px solid var(--line); border-radius: 6px; background: var(--surface); display: grid; place-items: center; cursor: pointer; }
.icon-button:hover { background: var(--surface-2); }
.icon-button svg { width: 18px; }
.notification-dot { position: absolute; right: 8px; top: 7px; width: 6px; height: 6px; border-radius: 50%; background: var(--coral); box-shadow: 0 0 0 2px #fff; }
.avatar { width: 38px; height: 38px; border: 0; border-radius: 50%; background: var(--ink); color: #fff; font-size: 12px; cursor: pointer; }
.mobile-menu { display: none; }

#app { width: min(1180px, calc(100% - 64px)); margin: 0 auto; padding: 34px 0 70px; }
.page-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 24px; margin-bottom: 24px; }
.eyebrow { margin: 0 0 7px; color: var(--green); font: 600 11px "Roboto Mono", monospace; text-transform: uppercase; }
h1, h2, h3, p { margin-top: 0; }
h1 { margin-bottom: 8px; font-size: clamp(28px, 3vw, 42px); line-height: 1.12; letter-spacing: 0; }
.page-subtitle { margin: 0; color: var(--muted); font-size: 14px; line-height: 1.7; }
.header-actions { display: flex; gap: 8px; flex: none; }
.primary-button, .secondary-button { min-height: 40px; padding: 0 15px; border-radius: 6px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; cursor: pointer; font-weight: 700; font-size: 13px; }
.primary-button { border: 1px solid var(--ink); background: var(--ink); color: #fff; }
.primary-button:hover { background: #303630; }
.secondary-button { border: 1px solid var(--line-strong); background: var(--surface); }
.secondary-button:hover { background: var(--surface-2); }
.primary-button svg, .secondary-button svg { width: 16px; }
.dark-button { border-color: rgba(255,255,255,.22); background: rgba(255,255,255,.06); color: #eef6ed; }
.dark-button:hover { background: rgba(255,255,255,.12); }

.stats-strip { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); margin-bottom: 18px; overflow: hidden; }
.stat { min-height: 80px; padding: 17px 20px; border-right: 1px solid var(--line); display: grid; align-content: center; gap: 3px; }
.stat:last-child { border-right: 0; }
.stat strong { font: 700 22px "Roboto Mono", monospace; }
.stat span { color: var(--muted); font-size: 11px; }

.command-map { margin: 18px 0; padding: 22px; border: 1px solid #303a33; border-radius: 10px; background: #111713; color: #f4f8f0; display: grid; grid-template-columns: minmax(260px, .72fr) minmax(0, 1.28fr); gap: 24px; overflow: hidden; position: relative; }
.command-map::before { content: ""; position: absolute; inset: 0; background-image: linear-gradient(rgba(217,244,91,.05) 1px, transparent 1px), linear-gradient(90deg, rgba(217,244,91,.04) 1px, transparent 1px); background-size: 36px 36px; opacity: .85; pointer-events: none; }
.command-map::after { content: ""; position: absolute; left: 22px; right: 22px; top: 50%; height: 1px; background: linear-gradient(90deg, transparent, rgba(217,244,91,.28), transparent); pointer-events: none; }
.command-copy, .tree-canvas { position: relative; z-index: 1; }
.command-copy { display: grid; align-content: center; gap: 12px; }
.command-copy .eyebrow { color: var(--acid); margin: 0; }
.command-copy h2 { margin: 0; font-size: 28px; line-height: 1.18; max-width: 420px; }
.command-copy p:not(.eyebrow) { margin: 0; color: #b6c1b8; font-size: 13px; line-height: 1.75; max-width: 430px; }
.command-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 8px; }
.tree-canvas { min-height: 342px; display: grid; grid-template-columns: 148px minmax(0, 1fr); align-items: center; gap: 28px; }
.tree-root { width: 132px; min-height: 132px; border: 1px solid rgba(217,244,91,.42); border-radius: 8px; background: radial-gradient(circle at 30% 20%, rgba(217,244,91,.35), rgba(217,244,91,.08) 38%, rgba(18,24,20,.95) 72%); color: #fff; display: grid; place-items: center; align-content: center; gap: 6px; cursor: pointer; box-shadow: 0 0 38px rgba(217,244,91,.12); }
.tree-root span { width: 42px; height: 42px; border-radius: 50%; display: grid; place-items: center; background: var(--acid); color: #111713; font: 900 16px "Roboto Mono", monospace; }
.tree-root strong { font-size: 16px; }
.tree-root em { color: #9ba79e; font-size: 10px; font-style: normal; }
.tree-branches { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; align-items: stretch; position: relative; }
.tree-branches::before { content: ""; position: absolute; left: -28px; right: calc(100% - 12px); top: 50%; height: 1px; background: rgba(217,244,91,.4); }
.tree-branch { min-width: 0; position: relative; display: grid; grid-template-rows: auto 1fr; gap: 10px; }
.tree-branch::before { content: ""; position: absolute; left: 50%; top: 42px; bottom: 0; width: 1px; background: rgba(255,255,255,.12); }
.tree-branch-head { min-height: 42px; border: 1px solid rgba(255,255,255,.16); border-top: 3px solid var(--branch-color, var(--acid)); border-radius: 7px; background: rgba(255,255,255,.06); color: #fff; font-size: 12px; font-weight: 800; cursor: pointer; position: relative; z-index: 1; }
.tree-branch-head:hover, .tree-leaf:hover { border-color: var(--branch-color, var(--acid)); transform: translateY(-2px); }
.tree-leaves { display: grid; gap: 8px; position: relative; z-index: 1; }
.tree-leaf { min-height: 68px; padding: 10px; border: 1px solid rgba(255,255,255,.13); border-radius: 7px; background: rgba(17,23,19,.86); color: #eef6ed; display: grid; align-content: center; gap: 4px; text-align: left; cursor: pointer; transition: transform .16s ease, border-color .16s ease, background .16s ease; }
.tree-leaf strong { font-size: 12px; }
.tree-leaf span { color: #9faa9f; font-size: 10px; line-height: 1.45; }
.tone-blue { --branch-color: #54a3ff; }
.tone-green { --branch-color: #27d17f; }
.tone-amber { --branch-color: #f0a530; }
.tone-acid { --branch-color: var(--acid); }

.section-block { margin-top: 18px; border: 1px solid var(--line); background: var(--surface); border-radius: var(--radius); overflow: hidden; }
.section-heading { padding: 18px 20px; border-bottom: 1px solid var(--line); display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.section-heading h2 { margin: 0; font-size: 16px; }
.section-heading p { margin: 3px 0 0; color: var(--muted); font-size: 11px; }
.text-button { border: 0; background: transparent; color: var(--blue); cursor: pointer; font-size: 12px; font-weight: 600; }

.map-switcher { display: flex; gap: 7px; margin-bottom: 18px; overflow-x: auto; scrollbar-width: thin; padding-bottom: 2px; }
.map-switch { flex: none; min-height: 38px; padding: 0 13px; border: 1px solid var(--line); border-radius: 5px; background: var(--surface); color: var(--muted); font-size: 11px; font-weight: 600; cursor: pointer; }
.map-switch:hover { border-color: var(--line-strong); color: var(--ink); }
.map-switch.is-active { border-color: var(--ink); background: var(--ink); color: #fff; }

.power-map { padding: 26px 20px 24px; overflow-x: auto; }
.map-track { min-width: 870px; display: grid; grid-template-columns: repeat(7, 1fr); gap: 24px; align-items: stretch; position: relative; }
.map-track::before { content: ""; position: absolute; left: 6%; right: 6%; top: 38px; height: 2px; background: var(--line-strong); }
.map-node { position: relative; z-index: 1; border: 1px solid var(--line); border-top: 4px solid var(--node-color, var(--blue)); border-radius: 6px; background: var(--surface); min-height: 126px; padding: 14px 12px 12px; text-align: left; cursor: pointer; transition: transform .16s ease, box-shadow .16s ease; }
.map-node:hover { transform: translateY(-3px); box-shadow: 0 10px 24px rgba(25,32,27,.09); border-color: var(--line-strong); }
.map-node-icon { width: 40px; height: 40px; margin: -36px 0 21px; border: 5px solid var(--surface); border-radius: 50%; background: var(--node-color, var(--blue)); color: #fff; display: grid; place-items: center; }
.map-node-icon svg { width: 18px; }
.map-node strong { display: block; font-size: 13px; margin-bottom: 5px; }
.map-node small { color: var(--muted); font-size: 10px; line-height: 1.5; }
.map-node em { position: absolute; bottom: 10px; right: 10px; font: 600 9px "Roboto Mono", monospace; color: var(--muted); font-style: normal; }
.locked-node::after { content: "会员"; position: absolute; top: 8px; right: 8px; padding: 2px 5px; background: var(--ink); color: #fff; border-radius: 3px; font-size: 8px; }

.dashboard-grid { display: grid; grid-template-columns: minmax(0, 1.35fr) minmax(280px, .65fr); gap: 18px; margin-top: 18px; }
.panel { border: 1px solid var(--line); background: var(--surface); border-radius: var(--radius); overflow: hidden; }
.focus-card { padding: 22px; min-height: 250px; position: relative; }
.focus-card::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 5px; background: var(--coral); }
.tag-row { display: flex; gap: 6px; margin-bottom: 16px; }
.tag { padding: 4px 7px; border-radius: 4px; background: var(--surface-2); color: var(--muted); font-size: 9px; font-weight: 700; }
.tag.hot { background: #fff0ec; color: #b94930; }
.focus-card h2 { font-size: 24px; margin-bottom: 9px; }
.focus-card > p { color: var(--muted); font-size: 13px; line-height: 1.75; max-width: 620px; }
.relation-mini { display: flex; align-items: center; gap: 8px; margin: 20px 0; overflow-x: auto; }
.relation-mini span { flex: none; padding: 8px 10px; border: 1px solid var(--line); border-radius: 4px; font-size: 10px; background: var(--surface); }
.relation-mini i { flex: none; width: 20px; height: 1px; background: var(--line-strong); position: relative; }
.relation-mini i::after { content: ""; position: absolute; right: -1px; top: -3px; border-left: 5px solid var(--line-strong); border-top: 3px solid transparent; border-bottom: 3px solid transparent; }
.card-actions { display: flex; gap: 8px; }

.update-list { list-style: none; margin: 0; padding: 7px 18px 14px; }
.update-item { display: grid; grid-template-columns: 42px 1fr; gap: 10px; padding: 13px 0; border-bottom: 1px solid var(--line); }
.update-item:last-child { border-bottom: 0; }
.update-date { font: 600 9px "Roboto Mono", monospace; color: var(--muted); padding-top: 3px; }
.update-item strong { display: block; font-size: 12px; margin-bottom: 3px; }
.update-item p { margin: 0; font-size: 10px; color: var(--muted); line-height: 1.5; }

.filter-bar { display: flex; align-items: center; gap: 8px; margin-bottom: 18px; overflow-x: auto; }
.filter-button { flex: none; border: 1px solid var(--line); border-radius: 5px; background: var(--surface); min-height: 34px; padding: 0 11px; font-size: 11px; cursor: pointer; }
.filter-button.is-active { background: var(--ink); color: #fff; border-color: var(--ink); }
.library-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.library-card { min-height: 178px; padding: 18px; border: 1px solid var(--line); background: var(--surface); border-radius: 7px; text-align: left; cursor: pointer; position: relative; }
.library-card:hover { border-color: var(--line-strong); box-shadow: 0 8px 22px rgba(28,33,30,.07); }
.library-card .card-icon { width: 34px; height: 34px; display: grid; place-items: center; border-radius: 5px; background: var(--surface-2); color: var(--green); margin-bottom: 20px; }
.library-card .card-icon svg { width: 17px; }
.library-card h3 { margin-bottom: 7px; font-size: 15px; }
.library-card p { margin-bottom: 18px; min-height: 36px; color: var(--muted); font-size: 11px; line-height: 1.6; }
.card-meta { display: flex; justify-content: space-between; color: var(--muted); font-size: 9px; }
.lock-badge { position: absolute; top: 14px; right: 14px; display: flex; align-items: center; gap: 4px; color: var(--muted); font-size: 9px; }
.lock-badge svg { width: 11px; }

.detail-layout { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 18px; }
.detail-main, .detail-side { display: grid; gap: 14px; align-content: start; }
.detail-card { border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); padding: 22px; }
.detail-card h2 { font-size: 15px; margin-bottom: 15px; }
.detail-card p { color: #3f4741; font-size: 13px; line-height: 1.8; }
.position-strip { display: flex; gap: 8px; align-items: center; overflow-x: auto; }
.position-strip span { flex: none; padding: 8px 10px; border-radius: 4px; background: var(--surface-2); font-size: 10px; }
.position-strip span.current { background: var(--acid); font-weight: 800; }
.position-strip i { width: 16px; height: 1px; background: var(--line-strong); flex: none; }
.data-list { display: grid; gap: 0; }
.data-row { display: grid; grid-template-columns: 86px 1fr; gap: 14px; padding: 12px 0; border-bottom: 1px solid var(--line); }
.data-row:last-child { border-bottom: 0; }
.data-row dt { color: var(--muted); font-size: 10px; }
.data-row dd { margin: 0; font-size: 12px; line-height: 1.6; }
.video-link { display: grid; grid-template-columns: 74px 1fr; gap: 12px; text-decoration: none; color: inherit; }
.video-thumb { height: 48px; border-radius: 5px; background: #252b27; color: var(--acid); display: grid; place-items: center; }
.video-thumb svg { width: 18px; }
.video-link strong { display: block; font-size: 11px; margin-bottom: 4px; }
.video-link small { color: var(--muted); font-size: 9px; }
.back-button { margin-bottom: 17px; }

.company-table { width: 100%; border-collapse: collapse; border: 1px solid var(--line); background: var(--surface); border-radius: var(--radius); overflow: hidden; }
.company-table th, .company-table td { padding: 14px 16px; border-bottom: 1px solid var(--line); text-align: left; font-size: 11px; }
.company-table th { color: var(--muted); font-size: 9px; background: var(--surface-2); }
.company-table tr:last-child td { border-bottom: 0; }
.company-table tbody tr { cursor: pointer; }
.company-table tbody tr:hover { background: #fafbf9; }
.ticker { font: 600 10px "Roboto Mono", monospace; }
.role-pill { display: inline-flex; padding: 4px 7px; border-radius: 4px; background: #eaf1ff; color: #275ebd; font-size: 9px; }
.company-zh { display: inline-block; margin-left: 8px; color: var(--muted); font-size: 10px; font-weight: 500; }
.company-bottleneck-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.company-bottleneck-tags span,
.company-bottleneck-tags em { display: inline-flex; align-items: center; min-height: 24px; padding: 4px 7px; border: 1px solid rgba(217,244,91,.18); border-radius: 4px; background: rgba(217,244,91,.08); color: var(--ink); font-size: 9px; font-style: normal; font-weight: 700; }
.company-bottleneck-tags em { color: var(--acid); }
.company-bottleneck-empty { color: var(--muted); font-size: 10px; }
.market-tabs { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 8px; margin-bottom: 16px; }
.market-tab { min-height: 52px; padding: 0 15px; border: 1px solid var(--line); border-radius: 6px; background: var(--surface); display: flex; align-items: center; justify-content: space-between; cursor: pointer; }
.market-tab span { font-size: 13px; font-weight: 700; }
.market-tab em { color: var(--muted); font-size: 10px; font-style: normal; }
.market-tab.is-active { border-color: var(--ink); box-shadow: inset 3px 0 0 var(--acid); }
.market-tab.is-active em { color: var(--green); }

.path-list { display: grid; gap: 12px; }
.path-card { border: 1px solid var(--line); background: var(--surface); border-radius: var(--radius); padding: 20px; display: grid; grid-template-columns: 48px 1fr auto; gap: 15px; align-items: center; cursor: pointer; }
.path-card:hover { border-color: var(--line-strong); }
.path-number { width: 42px; height: 42px; border-radius: 6px; background: var(--acid); display: grid; place-items: center; font: 700 13px "Roboto Mono", monospace; }
.path-card h3 { margin: 0 0 5px; font-size: 14px; }
.path-card p { margin: 0; color: var(--muted); font-size: 10px; }
.path-meta { display: flex; align-items: center; gap: 12px; color: var(--muted); font-size: 10px; }

.learning-format-note { margin-bottom: 16px; padding: 13px 15px; border: 1px solid #cbdca1; border-radius: 6px; background: #f6fadf; display: flex; align-items: center; gap: 10px; color: #4e594b; font-size: 11px; }
.learning-format-note svg { width: 18px; color: var(--green); flex: none; }
.learning-format-note span { display: grid; gap: 2px; }
.learning-format-note strong { color: var(--ink); }
.path-progress { display: flex; gap: 8px; margin-bottom: 18px; }
.path-progress span { padding: 6px 9px; border: 1px solid var(--line); border-radius: 4px; background: var(--surface); color: var(--muted); font-size: 10px; }
.reading-list { display: grid; gap: 14px; }
.reading-chapter { border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); padding: 24px; display: grid; grid-template-columns: 42px minmax(0, 1fr); gap: 18px; }
.chapter-index { width: 38px; height: 38px; border-radius: 5px; background: var(--ink); color: var(--acid); display: grid; place-items: center; font: 700 11px "Roboto Mono", monospace; }
.chapter-copy h2 { margin-bottom: 9px; font-size: 17px; }
.chapter-copy > p { max-width: 760px; color: #414942; font-size: 13px; line-height: 1.85; }
.learning-figure { margin: 18px 0 0; padding: 16px; border: 1px solid var(--line); border-radius: 6px; background: var(--surface-2); display: flex; align-items: center; gap: 8px; overflow-x: auto; }
.learning-figure span { flex: 1 0 88px; min-height: 38px; padding: 8px 10px; border: 1px solid var(--line-strong); border-radius: 4px; background: var(--surface); display: grid; place-items: center; text-align: center; font-size: 10px; font-weight: 700; }
.learning-figure i { flex: none; display: grid; place-items: center; color: var(--green); }
.learning-figure i svg { width: 15px; }

.plain-language-card { border: 1px solid #bfcf85; border-left: 5px solid var(--acid-strong); border-radius: var(--radius); background: #f8fbe8; padding: 24px; }
.plain-label { display: inline-block; margin-bottom: 12px; color: var(--green); font: 700 10px "Roboto Mono", monospace; }
.plain-language-card h2 { margin-bottom: 18px; max-width: 760px; font-size: 19px; line-height: 1.65; }
.analogy-line { display: flex; gap: 9px; align-items: flex-start; padding: 13px; border-radius: 5px; background: rgba(255,255,255,.75); color: #465046; font-size: 12px; line-height: 1.7; }
.analogy-line svg { width: 17px; margin-top: 2px; color: var(--amber); flex: none; }
.factor-list { display: grid; gap: 13px; margin-top: 20px; }
.factor-row { display: grid; grid-template-columns: 118px minmax(80px, 1fr) 30px; gap: 12px; align-items: center; }
.factor-row > div { display: grid; gap: 2px; }
.factor-row strong { font-size: 11px; }
.factor-row small { color: var(--muted); font-size: 8px; }
.factor-row em { color: var(--muted); font: 600 9px "Roboto Mono", monospace; font-style: normal; text-align: right; }
.factor-track { height: 7px; border-radius: 4px; background: var(--surface-2); overflow: hidden; }
.factor-track i { display: block; height: 100%; border-radius: inherit; background: var(--coral); }
.analysis-note { margin: 17px 0 0 !important; padding-top: 13px; border-top: 1px solid var(--line); color: var(--muted) !important; font-size: 10px !important; line-height: 1.65 !important; }
.market-size-card { border-top: 4px solid var(--blue); }
.market-size-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; margin-bottom: 14px; }
.market-size-head > div { display: grid; gap: 7px; }
.market-size-head span { color: var(--muted); font-size: 10px; }
.market-size-head strong { font-size: 24px; line-height: 1.25; }
.market-size-head em { padding: 5px 7px; border-radius: 4px; background: var(--surface-2); color: var(--muted); font: 600 9px "Roboto Mono", monospace; font-style: normal; }
.related-company-summary > strong { display: block; margin-bottom: 7px; font: 800 28px "Roboto Mono", monospace; }
.related-company-summary p { font-size: 10px; }
.context-banner { margin-bottom: 13px; padding: 11px 14px; border: 1px solid #cbdca1; border-radius: 6px; background: #f6fadf; display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.context-banner > span { display: flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 700; }
.context-banner svg { width: 15px; color: var(--green); }
.empty-company-state { min-height: 220px; border: 1px solid var(--line); border-radius: var(--radius); background: var(--surface); display: grid; place-items: center; align-content: center; gap: 8px; color: var(--muted); text-align: center; }
.empty-company-state svg { width: 24px; color: var(--green); }
.empty-company-state strong { color: var(--ink); font-size: 13px; }
.empty-company-state span { font-size: 10px; }
.upstream-trace-card { border-top: 4px solid var(--amber); }
.trace-heading { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; margin-bottom: 16px; }
.trace-heading h2 { margin-bottom: 4px; }
.trace-heading p { margin: 0; color: var(--muted); font-size: 10px; }
.trace-heading > span { flex: none; padding: 5px 7px; border-radius: 4px; background: #fff5dd; color: #9a6412; font-size: 9px; font-weight: 700; }
.raw-material-tags { display: flex; flex-wrap: wrap; gap: 7px; margin-bottom: 17px; }
.raw-material-tags span, .raw-material-tags button { min-height: 31px; padding: 6px 9px; border: 1px solid #dccb9e; border-radius: 4px; background: #fffaf0; display: inline-flex; align-items: center; gap: 6px; color: var(--ink); font-size: 10px; font-weight: 600; }
.raw-material-tags button { cursor: pointer; }
.raw-material-tags button:hover { border-color: var(--amber); background: #fff4d8; }
.raw-material-tags svg { width: 13px; color: var(--amber); }
.consumer-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 8px; }
.consumer-grid button { min-height: 92px; padding: 12px; border: 1px solid var(--line); border-radius: 5px; background: var(--surface); display: grid; grid-template-columns: 30px 1fr 16px; grid-template-rows: auto auto; gap: 3px 9px; align-items: center; text-align: left; cursor: pointer; }
.consumer-grid button:hover { border-color: var(--line-strong); background: var(--surface-2); }
.consumer-grid .card-icon { grid-row: 1 / 3; width: 30px; height: 30px; margin: 0; }
.consumer-grid .card-icon svg { width: 15px; }
.consumer-grid strong { font-size: 11px; }
.consumer-grid small { color: var(--muted); font-size: 8px; }
.consumer-grid button > svg { grid-column: 3; grid-row: 1 / 3; width: 14px; color: var(--muted); }
.trace-flow { display: grid; grid-template-columns: repeat(4, minmax(110px, 1fr)); gap: 25px; align-items: stretch; overflow-x: auto; }
.trace-flow > .trace-step { min-width: 110px; min-height: 74px; padding: 11px 32px 11px 11px; border: 1px solid var(--line); border-radius: 5px; background: var(--surface-2); color: var(--ink); display: grid; align-content: center; gap: 5px; text-align: left; position: relative; }
.trace-flow > button.trace-step { cursor: pointer; }
.trace-flow > button.trace-step:hover, .trace-flow > button.trace-step:focus-visible { border-color: var(--amber); background: #fffaf0; outline: none; }
.trace-flow > .trace-step.is-static { cursor: default; opacity: .82; }
.trace-step > span { position: absolute; right: 10px; top: 10px; color: var(--muted); }
.trace-step > span svg { width: 13px; }
.trace-flow > button.current { border-color: var(--ink); background: var(--ink); color: #fff; }
.trace-flow > button.current:hover, .trace-flow > button.current:focus-visible { border-color: var(--green); background: #202521; }
.trace-flow small { color: var(--muted); font-size: 8px; }
.trace-flow .current small, .trace-flow .current > span { color: #b9c3bc; }
.trace-flow strong { font-size: 10px; line-height: 1.5; }
.trace-flow > i { position: absolute; display: none; }
.scrim { position: fixed; inset: 0; z-index: 50; background: rgba(13,16,14,.48); opacity: 0; pointer-events: none; transition: opacity .18s ease; }
.scrim.is-visible { opacity: 1; pointer-events: auto; }
.search-panel { position: fixed; z-index: 60; left: 50%; top: 9vh; transform: translate(-50%, -12px); width: min(620px, calc(100% - 28px)); max-height: 72vh; overflow: auto; background: var(--surface); border: 1px solid var(--line); border-radius: 8px; box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: opacity .16s ease, transform .16s ease; }
.search-panel.is-visible { opacity: 1; pointer-events: auto; transform: translate(-50%, 0); }
.search-box { height: 62px; display: grid; grid-template-columns: 24px 1fr 38px; gap: 10px; align-items: center; padding: 0 14px 0 19px; border-bottom: 1px solid var(--line); }
.search-box > svg { width: 19px; color: var(--muted); }
.search-box input { width: 100%; border: 0; outline: 0; font-size: 15px; }
.search-meta { display: flex; justify-content: space-between; padding: 13px 18px; color: var(--muted); font-size: 10px; }
.search-meta strong { color: var(--ink); }
.search-results { padding: 0 10px 12px; }
.search-result { width: 100%; border: 0; background: transparent; border-radius: 6px; padding: 11px 10px; display: grid; grid-template-columns: 34px 1fr auto; gap: 10px; align-items: center; text-align: left; cursor: pointer; }
.search-result:hover { background: var(--surface-2); }
.result-icon { width: 32px; height: 32px; display: grid; place-items: center; border-radius: 5px; background: var(--surface-2); color: var(--green); }
.result-icon svg { width: 15px; }
.search-result strong { display: block; font-size: 11px; margin-bottom: 2px; }
.search-result small { color: var(--muted); font-size: 9px; }
.result-type { color: var(--muted); font-size: 9px; }

.modal { position: fixed; z-index: 60; left: 50%; top: 50%; transform: translate(-50%, calc(-50% - 12px)); width: min(620px, calc(100% - 28px)); max-height: calc(100vh - 28px); overflow: auto; background: var(--surface); border: 1px solid var(--line); border-radius: 8px; padding: 30px; box-shadow: var(--shadow); opacity: 0; pointer-events: none; transition: opacity .16s ease, transform .16s ease; }
#membership-modal { width: min(860px, calc(100% - 48px)); }
#membership-modal h2 { max-width: 640px; }
.modal.is-visible { opacity: 1; pointer-events: auto; transform: translate(-50%, -50%); }
.modal-close { position: absolute; right: 14px; top: 14px; }
.modal-kicker { display: block; color: var(--green); font: 600 10px "Roboto Mono", monospace; margin-bottom: 13px; }
.modal h2 { max-width: 390px; font-size: 24px; line-height: 1.35; }
.modal > p { color: var(--muted); font-size: 12px; line-height: 1.7; }
.price-line { display: flex; align-items: baseline; gap: 5px; padding: 18px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
.price-line strong { font: 800 34px "Roboto Mono", monospace; }
.price-line span { color: var(--muted); font-size: 11px; }
.price-line em { margin-left: auto; background: var(--acid); padding: 4px 7px; border-radius: 4px; font-size: 9px; font-style: normal; font-weight: 700; }
.billing-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; padding: 16px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); align-items: stretch; }
.billing-card { min-height: 214px; padding: 16px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface-2); display: grid; grid-template-rows: auto auto auto 1fr auto; gap: 9px; }
.billing-card.is-featured { border-color: var(--green); box-shadow: inset 0 3px 0 var(--green); background: #fbfdf5; }
.billing-card.is-featured h3,
.billing-card.is-featured strong { color: #101711; }
.billing-card.is-featured span,
.billing-card.is-featured small { color: #536457; }
.billing-card header { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.billing-card h3 { margin: 0; font-size: 14px; }
.billing-card em { padding: 4px 7px; border-radius: 4px; background: #122015; color: var(--acid); border: 1px solid rgba(217,244,91,.35); font-style: normal; font-size: 9px; font-weight: 800; white-space: nowrap; }
.billing-card strong { font: 800 28px "Roboto Mono", monospace; letter-spacing: 0; }
.billing-card span { color: var(--muted); font-size: 11px; }
.billing-card small { color: var(--muted); font-size: 10px; line-height: 1.5; }
.billing-card button { min-height: 42px; margin-top: 6px; align-self: end; }
.benefit-list { list-style: none; padding: 16px 0 6px; margin: 0; display: grid; gap: 10px; }
.benefit-list li { display: flex; align-items: center; gap: 8px; font-size: 11px; }
.benefit-list svg { width: 15px; color: var(--green); }
.full-width { width: 100%; }
.legal-note { display: block; color: var(--muted); font-size: 9px; line-height: 1.6; margin-top: 12px; text-align: center; }
.legal-note a { color: var(--acid); text-decoration: none; }
.legal-note a:hover { text-decoration: underline; }
.empty-state { padding: 30px; text-align: center; color: var(--muted); font-size: 12px; }
.submission-modal, .feedback-modal { width: min(720px, calc(100% - 28px)); }
.submission-form { display: grid; gap: 12px; margin-top: 18px; }
.submission-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.submission-form label { display: grid; gap: 7px; color: var(--muted); font-size: 11px; font-weight: 700; }
.submission-form input,
.submission-form select,
.submission-form textarea { width: 100%; border: 1px solid var(--line); border-radius: 6px; background: #fff; color: #111711; padding: 11px 12px; font: 500 13px var(--font); outline: none; }
.submission-form input::placeholder,
.submission-form textarea::placeholder { color: #737b74; opacity: 1; }
.submission-form select { color-scheme: light; }
.submission-form select option { background: #fff; color: #111711; }
.submission-form select option:checked { background: #1f6fd1; color: #fff; }
.submission-form textarea { min-height: 112px; resize: vertical; line-height: 1.6; }
.submission-form input:focus,
.submission-form select:focus,
.submission-form textarea:focus { border-color: var(--green); box-shadow: 0 0 0 3px rgba(0, 136, 89, .12); }
.submission-status { min-height: 18px; color: var(--green); font-size: 12px; font-weight: 700; }
.submission-status.is-error { color: #b24b35; }
.empty-state .secondary-button { margin-top: 14px; }
.page-actions { display: inline-flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }
.related-company-summary .submission-link { margin-top: 10px; }
.mobile-nav { display: none; }

.upstream-band { border-top: 1px solid var(--line-strong); padding: 20px; background: var(--surface-2); }
.upstream-band-heading { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 16px; }
.upstream-band-heading > span { flex: none; padding-top: 3px; color: var(--green); font: 700 9px "Roboto Mono", monospace; letter-spacing: 0; }
.upstream-band-heading h3 { margin: 0 0 4px; font-size: 14px; }
.upstream-band-heading p { margin: 0; color: var(--muted); font-size: 10px; line-height: 1.55; }
.upstream-node-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(138px, 1fr)); gap: 8px; }
.upstream-node { min-height: 76px; padding: 11px; border: 1px solid var(--line); border-radius: 5px; background: var(--surface); color: var(--ink); text-align: left; cursor: pointer; position: relative; }
.upstream-node:hover { border-color: var(--line-strong); box-shadow: 0 5px 14px rgba(28,33,30,.06); }
.upstream-node > span { display: grid; place-items: center; width: 24px; height: 24px; margin-bottom: 8px; color: var(--green); }
.upstream-node svg { width: 16px; height: 16px; }
.upstream-node strong, .upstream-node small { display: block; }
.upstream-node strong { font-size: 11px; margin-bottom: 3px; }
.upstream-node small { color: var(--muted); font-size: 9px; }

.library-sections { display: grid; gap: 28px; }
.library-section { padding: 22px 0 4px; border-top: 2px solid var(--ink); }
.library-section-header { display: flex; align-items: flex-end; justify-content: space-between; gap: 16px; margin-bottom: 18px; }
.library-section-header span { color: var(--muted); font: 700 9px "Roboto Mono", monospace; }
.library-section-header h2 { margin: 3px 0 0; font-size: 22px; }
.library-section-header > strong { color: var(--muted); font-size: 10px; font-weight: 500; }
.library-subsection { padding: 0 0 22px; }
.library-subsection + .library-subsection { margin-top: 2px; }
.library-subheading { display: flex; align-items: center; gap: 8px; margin-bottom: 10px; }
.library-subheading h3 { margin: 0; font-size: 12px; }
.library-subheading span { display: grid; place-items: center; min-width: 21px; height: 21px; border: 1px solid var(--line); border-radius: 50%; color: var(--muted); font-size: 9px; }
.upstream-subsection { margin-top: 6px; padding: 18px 16px 20px; border-top: 1px dashed var(--line-strong); background: var(--surface-2); }
.tech-summary { display: flex; align-items: stretch; gap: 10px; margin-bottom: 18px; }
.tech-summary > div { min-width: 118px; padding: 14px 16px; border: 1px solid var(--line); background: var(--surface); }
.tech-summary > div strong, .tech-summary > div span { display: block; }
.tech-summary > div strong { font-size: 22px; line-height: 1; }
.tech-summary > div span { margin-top: 5px; color: var(--muted); font-size: 9px; }
.tech-summary > p { flex: 1; margin: 0; padding: 13px 15px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); color: var(--muted); font-size: 9px; line-height: 2.2; }
.tech-route-list { display: grid; gap: 16px; }
.tech-route { scroll-margin-top: 82px; border: 1px solid var(--line); border-radius: 7px; background: var(--surface); overflow: hidden; }
.tech-route-header { min-height: 112px; padding: 20px; display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; border-bottom: 1px solid var(--line); }
.tech-route-header span { color: var(--green); font: 700 9px "Roboto Mono", monospace; }
.tech-route-header h2 { margin: 5px 0 7px; font-size: 19px; }
.tech-route-header p { max-width: 720px; margin: 0; color: var(--muted); font-size: 11px; line-height: 1.65; }
.tech-route-header > i { flex: none; width: 38px; height: 38px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 5px; color: var(--green); }
.tech-route-header > i svg { width: 18px; }
.route-options { display: grid; grid-template-columns: repeat(auto-fit, minmax(190px, 1fr)); border-bottom: 1px solid var(--line); }
.route-option { min-height: 116px; padding: 16px 18px; border-right: 1px solid var(--line); }
.route-option:last-child { border-right: 0; }
.route-option > div { display: flex; align-items: center; justify-content: space-between; gap: 9px; margin-bottom: 9px; }
.route-option strong { font-size: 12px; }
.route-option p { margin: 0; color: var(--muted); font-size: 10px; line-height: 1.65; }
.route-status { display: inline-flex; align-items: center; min-height: 20px; padding: 0 6px; border-radius: 3px; font-size: 8px; font-weight: 700; white-space: nowrap; }
.route-status.mainstream { background: #e6f2ea; color: #17633d; }
.route-status.ramping { background: #e9eefb; color: #315aa8; }
.route-status.emerging { background: #fff0df; color: #9a5a12; }
.route-status.coexist { background: #eeeeeb; color: #5d625c; }
.route-decision { padding: 14px 18px; display: flex; align-items: center; gap: 14px; border-bottom: 1px solid var(--line); background: var(--surface-2); }
.route-decision > strong { flex: none; font-size: 10px; }
.route-decision > div { display: flex; flex-wrap: wrap; gap: 6px; }
.route-decision span { padding: 4px 7px; border: 1px solid var(--line); border-radius: 3px; background: var(--surface); color: var(--muted); font-size: 9px; }
.route-links { padding: 14px 18px 16px; display: grid; gap: 9px; }
.route-links > div { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; }
.route-links strong { width: 60px; font-size: 9px; color: var(--muted); }
.route-links button { border: 0; border-bottom: 1px solid var(--line-strong); background: transparent; padding: 3px 2px; color: var(--ink); font-size: 9px; cursor: pointer; }
.route-links button:hover { color: var(--green); border-color: var(--green); }
@media (max-width: 980px) {
  .app-shell { grid-template-columns: 210px minmax(0, 1fr); }
  .sidebar { padding-left: 12px; padding-right: 12px; }
  .dashboard-grid, .detail-layout { grid-template-columns: 1fr; }
  .library-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  #app { width: min(100% - 40px, 900px); }
}

@media (max-width: 720px) {
  body { padding-bottom: 62px; }
  .app-shell { display: block; }
  .sidebar {
    position: fixed;
    left: 0;
    top: 0;
    z-index: 80;
    width: 260px;
    color: #f7fbf4;
    transform: translateX(-100%);
    transition: transform .18s ease;
    box-shadow: none;
  }
  .sidebar.is-open { transform: translateX(0); box-shadow: var(--shadow); }
  .sidebar .brand strong,
  .sidebar .nav-item span:first-of-type,
  .sidebar-note strong,
  .member-card strong,
  .feedback-card strong {
    color: #f7fbf4;
  }
  .sidebar .brand small,
  .sidebar-note small,
  .member-card small,
  .feedback-card small,
  .legal-links a {
    color: #b9c7bd;
  }
  .sidebar .nav-item {
    color: #dbe7dd;
  }
  .sidebar .nav-item svg {
    color: #b9c7bd;
    stroke-width: 2.2;
  }
  .sidebar .nav-item.is-active {
    color: #fff;
    background: rgba(217, 244, 91, .16);
  }
  .sidebar .nav-item.is-active svg {
    color: var(--acid);
  }
  .sidebar .nav-count {
    color: #c4d49f;
  }
  .topbar { height: 58px; padding: 0 14px; gap: 10px; }
  .mobile-menu { display: grid; flex: none; }
  .search-trigger { width: 100%; }
  .search-trigger kbd { display: none; }
  .topbar-actions .icon-button { display: none; }
  .avatar { width: 34px; height: 34px; flex: none; }
  #app { width: calc(100% - 28px); padding: 24px 0 30px; }
  .page-header { align-items: flex-start; margin-bottom: 18px; }
  .page-header h1 { font-size: 27px; }
  .header-actions { display: none; }
  .stats-strip { grid-template-columns: repeat(2, 1fr); }
  .stat { min-height: 68px; padding: 13px 15px; }
  .stat:nth-child(2) { border-right: 0; }
  .stat:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .stat strong { font-size: 19px; }
  .command-map { grid-template-columns: 1fr; padding: 18px; }
  .command-copy h2 { font-size: 23px; }
  .tree-canvas { min-height: 0; grid-template-columns: 1fr; gap: 18px; }
  .tree-root { width: 100%; min-height: 88px; }
  .tree-branches { grid-template-columns: 1fr; }
  .tree-branches::before, .tree-branch::before { display: none; }
  .tree-branch { gap: 8px; }
  .section-heading { padding: 15px; }
  .map-switcher { margin-left: -14px; margin-right: -14px; padding: 0 14px 4px; }
  .power-map { padding: 25px 15px 18px; overflow: visible; }
  .map-track { min-width: 0; grid-template-columns: 1fr; gap: 10px; }
  .map-track::before { left: 20px; right: auto; top: 15px; bottom: 15px; width: 2px; height: auto; }
  .map-node { min-height: 86px; padding: 13px 36px 13px 58px; }
  .map-node-icon { position: absolute; left: 6px; top: 50%; margin: 0; transform: translateY(-50%); width: 34px; height: 34px; border-width: 4px; }
  .map-node em { bottom: 11px; }
  .dashboard-grid { margin-top: 12px; gap: 12px; }
  .focus-card { padding: 19px; }
  .focus-card h2 { font-size: 21px; }
  .library-grid { grid-template-columns: 1fr; }
  .library-card { min-height: 158px; }
  .detail-card { padding: 18px; }
  .detail-layout { gap: 12px; }
  .company-table th:nth-child(3), .company-table td:nth-child(3) { display: none; }
  .company-table th, .company-table td { padding: 12px 10px; }
  .company-zh { display: block; margin: 3px 0 0; }
  .market-tabs { grid-template-columns: repeat(2, 1fr); }
  .path-card { grid-template-columns: 42px 1fr; }
  .path-meta { grid-column: 2; }
  .consumer-grid { grid-template-columns: 1fr; }
  .trace-heading { display: grid; }
  .trace-heading > span { justify-self: start; }
  .trace-flow { grid-template-columns: repeat(4, 145px); gap: 8px; }  .reading-chapter { grid-template-columns: 1fr; padding: 18px; gap: 12px; }
  .chapter-index { width: 34px; height: 34px; }
  .learning-figure { padding: 12px; }
  .plain-language-card { padding: 19px; }
  .plain-language-card h2 { font-size: 16px; }
  .factor-row { grid-template-columns: 92px minmax(64px, 1fr) 25px; gap: 8px; }
  .market-size-head { display: grid; }
  .context-banner { align-items: flex-start; }  .modal { padding: 26px 20px 22px; }
  #membership-modal { width: min(620px, calc(100% - 28px)); }
  .modal h2 { font-size: 21px; padding-right: 30px; }
  .submission-grid { grid-template-columns: 1fr; }
  .tech-summary { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .billing-grid { grid-template-columns: 1fr; }
  .tech-summary > div { min-width: 0; }
  .tech-summary > p { grid-column: 1 / -1; border: 1px solid var(--line); }
  .tech-route-header { min-height: 0; padding: 16px; }
  .route-options { grid-template-columns: 1fr; }
  .route-option { min-height: 0; border-right: 0; border-bottom: 1px solid var(--line); }
  .route-option:last-child { border-bottom: 0; }
  .route-decision { align-items: flex-start; flex-direction: column; }
  .route-links strong { width: 100%; }
  .mobile-nav { position: fixed; z-index: 40; left: 0; right: 0; bottom: 0; height: 62px; padding-bottom: env(safe-area-inset-bottom); background: rgba(255,255,255,.96); border-top: 1px solid var(--line); display: grid; grid-template-columns: repeat(6, 1fr); }
  .mobile-nav button { border: 0; background: transparent; color: var(--muted); display: grid; justify-items: center; align-content: center; gap: 3px; font-size: 9px; cursor: pointer; }
  .mobile-nav button svg { width: 18px; }
  .mobile-nav button.is-active { color: var(--ink); font-weight: 700; }
  .mobile-nav button.is-active svg { color: var(--green); }
}

@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; transition: none !important; }
}

/* Membership access boundaries */
.is-access-locked {
  position: relative;
}

.library-card.is-access-locked .card-icon,
.library-card.is-access-locked h3,
.library-card.is-access-locked p,
.library-card.is-access-locked .card-meta,
.industry-chip.is-access-locked > span,
.industry-chip.is-access-locked > strong,
.industry-chip.is-access-locked > small,
.industry-row.is-access-locked .industry-row-stage,
.company-table tr.is-access-locked td > *:not(.inline-lock),
.market-tab.is-access-locked em {
  filter: blur(4px);
  opacity: .42;
  user-select: none;
}

.library-card.is-access-locked,
.industry-chip.is-access-locked,
.company-table tr.is-access-locked,
.market-tab.is-access-locked,
.filter-button.is-access-locked,
.industry-track-tabs button.is-access-locked {
  border-color: rgba(217,244,91,.22);
  background:
    linear-gradient(135deg, rgba(217,244,91,.06), rgba(255,255,255,.02)),
    var(--surface);
}

.library-card.is-access-locked::after,
.company-table tr.is-access-locked td:first-child::after,
.industry-chip.is-access-locked::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background-image: repeating-linear-gradient(135deg, rgba(217,244,91,.08) 0 1px, transparent 1px 8px);
  opacity: .38;
}

.lock-badge,
.access-lock-mark,
.inline-lock {
  z-index: 2;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  min-height: 22px;
  padding: 3px 7px;
  border: 1px solid rgba(217,244,91,.28);
  border-radius: 4px;
  background: rgba(12, 20, 14, .92);
  color: var(--acid) !important;
  font-size: 9px;
  font-weight: 900;
  line-height: 1;
  filter: none !important;
  opacity: 1 !important;
}

.lock-badge svg,
.access-lock-mark svg,
.inline-lock svg,
.filter-button.is-access-locked svg,
.industry-track-tabs button.is-access-locked svg,
.market-tab.is-access-locked svg {
  width: 12px;
  height: 12px;
  color: var(--acid);
  stroke: var(--acid);
}

.inline-lock {
  position: static;
  margin: 7px 0 0;
  width: max-content;
}

.access-lock-mark {
  position: absolute;
  right: 10px;
  top: 10px;
}

.access-mask-note {
  position: absolute;
  left: 14px;
  right: 14px;
  bottom: 12px;
  z-index: 2;
  padding: 8px 9px;
  border: 1px solid rgba(217,244,91,.2);
  border-radius: 5px;
  background: rgba(8, 14, 10, .92);
  color: #dce7dc;
  font-size: 9px;
  line-height: 1.45;
}

.access-preview-banner {
  margin: -4px 0 14px;
  padding: 11px 13px;
  border: 1px solid rgba(217,244,91,.25);
  border-radius: 6px;
  background: rgba(217,244,91,.08);
  color: #dce7dc;
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 11px;
}

.access-preview-banner svg {
  width: 16px;
  color: var(--acid);
}

.access-preview-banner .text-button {
  margin-left: auto;
  color: var(--acid);
  font-weight: 900;
}

/* Full-system redesign: dark command-map interface */
:root {
  --bg: #080d0a;
  --surface: #101712;
  --surface-2: #161f18;
  --ink: #f3f8f0;
  --muted: #9aa79d;
  --line: #263229;
  --line-strong: #465646;
  --acid: #d9f45b;
  --acid-strong: #bfe836;
  --blue: #5ba8ff;
  --coral: #ff755f;
  --green: #29d182;
  --amber: #f0a530;
  --purple: #9a7cff;
  --sidebar: #0b120e;
  --sidebar-muted: #8d9a91;
  --shadow: 0 22px 70px rgba(0, 0, 0, .34);
}

body {
  background:
    radial-gradient(circle at 8% 0%, rgba(217,244,91,.09), transparent 28%),
    linear-gradient(180deg, #0a100c, #070b08 52%, #080d0a);
}

.topbar { background: rgba(8, 13, 10, .86); border-bottom-color: rgba(217,244,91,.12); }
.search-trigger, .icon-button, .avatar { background: rgba(255,255,255,.04); border-color: rgba(255,255,255,.12); color: #eaf3e8; }
.search-trigger span, .search-trigger kbd, .company-table td, .library-card p, .detail-card p, .section-heading p, .page-header p { color: var(--muted); }
.sidebar { border-right: 1px solid rgba(217,244,91,.12); background: linear-gradient(180deg, #101711, #080d0a); }
.nav-item.is-active { background: rgba(217,244,91,.12); box-shadow: inset 3px 0 0 var(--acid); }
.member-card, .feedback-card { background: rgba(255,255,255,.045); border-color: rgba(217,244,91,.18); }

#app { width: min(1480px, calc(100% - 48px)); }
.page-header { padding: 24px; border: 1px solid rgba(217,244,91,.16); border-radius: 10px; background: linear-gradient(135deg, rgba(217,244,91,.08), rgba(255,255,255,.025)); }
.page-header h1, .plain-language-card h2, .detail-card h2, .section-heading h2, .tech-route h2, .library-section-header h2 { color: #fff; }
.eyebrow, .page-header .eyebrow { color: var(--acid); }

.primary-button { background: var(--acid); color: #111711; border-color: var(--acid); }
.secondary-button, .text-button, .filter-button, .market-tab, .path-card, .library-card, .panel, .section-block, .detail-card, .tech-route, .company-table, .modal, .search-panel, .account-panel, .auth-modal {
  background: rgba(16, 23, 18, .92);
  border-color: rgba(217,244,91,.14);
  color: var(--ink);
}
.secondary-button:hover, .filter-button:hover, .library-card:hover, .path-card:hover, .market-tab:hover { border-color: rgba(217,244,91,.42); background: rgba(217,244,91,.07); }
.filter-button.is-active, .market-tab.is-active, .map-switch.is-active { background: var(--acid); border-color: var(--acid); color: #111711; }
.stats-strip, .company-table th, .data-row, .learning-figure, .position-strip, .route-option, .upstream-band, .plain-language-card {
  background: rgba(255,255,255,.035);
  border-color: rgba(217,244,91,.13);
  color: var(--ink);
}
.company-table tbody tr:hover { background: rgba(217,244,91,.06); }
.role-pill, .tag, .lock-badge { background: rgba(217,244,91,.12); color: var(--acid); }
.tag.hot { background: rgba(240,165,48,.15); color: #ffd692; }
.plain-language-card { border-left-color: var(--acid); }
.analogy-line, .raw-material-tags span, .raw-material-tags button, .trace-step, .consumer-grid button { background: rgba(255,255,255,.04); border-color: rgba(217,244,91,.14); color: var(--ink); }
.trace-step.current, .position-strip .current { background: var(--acid); color: #111711; border-color: var(--acid); }
.trace-step.current small, .trace-step.current strong { color: #111711; }
.mobile-nav { background: rgba(8,13,10,.96); border-top-color: rgba(217,244,91,.16); }
.mobile-nav button { color: var(--muted); }
.mobile-nav button.is-active { color: var(--acid); }

.god-tree-page { display: grid; gap: 18px; min-height: calc(100vh - 140px); }
.god-tree-toolbar {
  min-height: 132px;
  padding: 26px;
  border: 1px solid rgba(217,244,91,.18);
  border-radius: 12px;
  background:
    linear-gradient(rgba(217,244,91,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217,244,91,.045) 1px, transparent 1px),
    radial-gradient(circle at 84% 20%, rgba(217,244,91,.16), transparent 34%),
    #0f1711;
  background-size: 34px 34px, 34px 34px, auto, auto;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 20px;
}
.god-tree-toolbar span { color: var(--acid); font: 800 12px "Roboto Mono", monospace; letter-spacing: .08em; }
.god-tree-toolbar h1 { margin: 8px 0 8px; color: #fff; font-size: clamp(34px, 5vw, 72px); line-height: .95; letter-spacing: 0; }
.god-tree-toolbar p { margin: 0; max-width: 760px; color: #b8c5ba; font-size: 13px; line-height: 1.7; }
.god-tree-actions { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; justify-content: flex-end; }
.god-tree-actions strong { min-width: 56px; text-align: center; color: var(--acid); font: 900 12px "Roboto Mono", monospace; }

.god-tree-viewport {
  height: calc(100vh - 250px);
  min-height: 680px;
  overflow: auto;
  border: 1px solid rgba(217,244,91,.18);
  border-radius: 12px;
  background:
    linear-gradient(rgba(217,244,91,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217,244,91,.035) 1px, transparent 1px),
    radial-gradient(circle at 50% 0%, rgba(217,244,91,.08), transparent 38%),
    #090f0b;
  background-size: 42px 42px, 42px 42px, auto, auto;
}
.god-tree-canvas { min-width: 1040px; padding: 34px 34px 80px; zoom: var(--tree-zoom); position: relative; }
.god-root {
  width: min(440px, 60%);
  min-height: 116px;
  margin: 0 auto 34px;
  border: 1px solid rgba(217,244,91,.55);
  border-radius: 12px;
  background: radial-gradient(circle at 50% 25%, rgba(217,244,91,.32), rgba(217,244,91,.08) 48%, rgba(14,22,16,.98));
  color: #fff;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 7px;
  cursor: pointer;
  box-shadow: 0 0 44px rgba(217,244,91,.12);
}
.god-root span { width: 46px; height: 46px; border-radius: 50%; display: grid; place-items: center; background: var(--acid); color: #111711; font: 900 18px "Roboto Mono", monospace; }
.god-root strong { font-size: 22px; }
.god-root small { max-width: 320px; color: #b8c5ba; line-height: 1.5; }
.god-tree-trunk { width: 2px; height: 40px; margin: -18px auto 0; background: linear-gradient(var(--acid), rgba(217,244,91,.15)); }
.god-layer { display: grid; grid-template-columns: 70px minmax(0, 1fr); gap: 18px; align-items: stretch; margin: 0 0 24px; }
.god-layer-rail { display: grid; justify-items: center; grid-template-rows: 42px 1fr; }
.god-layer-rail span { width: 42px; height: 42px; border: 1px solid rgba(217,244,91,.32); border-radius: 50%; display: grid; place-items: center; background: #101812; color: var(--acid); font: 800 12px "Roboto Mono", monospace; }
.god-layer-rail i { width: 1px; background: linear-gradient(rgba(217,244,91,.42), rgba(217,244,91,.06)); }
.god-layer-body { padding: 18px; border: 1px solid rgba(217,244,91,.16); border-radius: 12px; background: rgba(16,23,18,.82); box-shadow: inset 0 1px 0 rgba(255,255,255,.04); }
.god-layer-header { margin-bottom: 14px; display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.god-layer-header span { color: var(--green); font: 800 10px "Roboto Mono", monospace; letter-spacing: .08em; }
.god-layer-header h2 { margin: 4px 0 0; color: #fff; font-size: 22px; }
.god-layer-header strong { flex: none; padding: 6px 9px; border-radius: 5px; background: rgba(217,244,91,.11); color: var(--acid); font-size: 11px; }
.god-branch-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 12px; }
.god-branch { min-width: 0; border: 1px solid rgba(255,255,255,.08); border-radius: 9px; background: rgba(255,255,255,.025); overflow: hidden; }
.god-branch-title { min-height: 42px; padding: 10px 12px; border-bottom: 1px solid rgba(217,244,91,.12); display: flex; align-items: center; justify-content: space-between; gap: 10px; }
.god-branch-title strong { color: #eaf3e8; font-size: 12px; }
.god-branch-title span { color: var(--acid); font: 800 10px "Roboto Mono", monospace; }
.god-node-grid { padding: 10px; display: grid; grid-template-columns: repeat(auto-fill, minmax(136px, 1fr)); gap: 8px; }
.god-node {
  min-height: 78px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 7px;
  background: rgba(7,12,9,.88);
  color: #f4f8f0;
  display: grid;
  grid-template-columns: 18px 1fr;
  grid-template-rows: auto auto;
  gap: 4px 8px;
  text-align: left;
  cursor: pointer;
}
.god-node:hover { border-color: var(--acid); background: rgba(217,244,91,.08); transform: translateY(-1px); }
.god-node span { grid-row: 1 / 3; color: var(--acid); }
.god-node span svg { width: 16px; }
.god-node strong { font-size: 12px; line-height: 1.35; }
.god-node small { color: var(--muted); font-size: 9px; line-height: 1.35; }
.god-node.locked-node { opacity: .78; }

@media (max-width: 960px) {
  #app { width: calc(100% - 28px); }
  .god-tree-toolbar { align-items: flex-start; flex-direction: column; }
  .god-tree-actions { justify-content: flex-start; }
  .god-tree-viewport { height: calc(100vh - 280px); min-height: 600px; }
  .god-tree-canvas { min-width: 880px; padding: 24px; }
}

@media (max-width: 720px) {
  .god-tree-viewport { min-height: 620px; overflow-x: hidden; }
  .god-tree-canvas { min-width: 100%; padding: 22px 14px 80px; }
  .god-root { width: 100%; }
  .god-layer { grid-template-columns: 34px minmax(0, 1fr); gap: 8px; }
  .god-layer-rail span { width: 32px; height: 32px; font-size: 10px; }
  .god-layer-body { padding: 12px; }
  .god-layer-header { display: grid; }
  .god-branch-grid { grid-template-columns: 1fr; }
  .god-node-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .god-node { min-height: 70px; padding: 9px; }
}

/* Single draggable global tree */
.god-tree-viewport {
  overflow: hidden;
  cursor: grab;
  user-select: none;
  touch-action: none;
}
.god-tree-viewport.is-dragging { cursor: grabbing; }
.god-tree-canvas {
  width: min(1180px, calc(100vw - 340px));
  min-width: 1080px;
  margin: 0 auto;
  transform: translate(var(--tree-pan-x, 0), var(--tree-pan-y, 0)) scale(var(--tree-zoom, 1));
  transform-origin: 50% 72px;
  zoom: 1 !important;
  transition: transform .12s ease;
}
.god-tree-viewport.is-dragging .god-tree-canvas { transition: none; }
.god-tree-spine {
  width: 2px;
  height: 46px;
  margin: -12px auto 0;
  background: linear-gradient(var(--acid), rgba(217,244,91,.18));
}
.god-trunk-grid {
  position: relative;
  display: grid;
  gap: 28px;
}
.god-trunk-grid::before {
  content: "";
  position: absolute;
  left: 50%;
  top: 0;
  bottom: 0;
  width: 1px;
  background: linear-gradient(rgba(217,244,91,.28), rgba(217,244,91,.04));
}
.god-trunk {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.god-trunk:nth-child(even) {
  grid-template-columns: minmax(0, 1fr) 260px;
}
.god-trunk:nth-child(even) .god-trunk-node { grid-column: 2; }
.god-trunk:nth-child(even) .god-module-grid { grid-column: 1; grid-row: 1; }
.god-trunk-node {
  min-height: 164px;
  padding: 18px;
  border: 1px solid rgba(217,244,91,.28);
  border-radius: 12px;
  background: radial-gradient(circle at 30% 0%, rgba(217,244,91,.18), transparent 48%), rgba(16,23,18,.96);
  box-shadow: 0 0 32px rgba(0,0,0,.18);
}
.god-trunk-node span {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: var(--acid);
  color: #111711;
  display: grid;
  place-items: center;
  font: 900 11px "Roboto Mono", monospace;
}
.god-trunk-node h2 { margin: 14px 0 8px; color: #fff; font-size: 24px; }
.god-trunk-node p { margin: 0 0 14px; color: #b8c5ba; font-size: 12px; line-height: 1.65; }
.god-trunk-node strong { display: inline-flex; padding: 5px 8px; border-radius: 5px; background: rgba(217,244,91,.12); color: var(--acid); font-size: 10px; }
.god-module-grid {
  display: grid;
  gap: 12px;
}
.god-module {
  border: 1px solid rgba(217,244,91,.14);
  border-radius: 12px;
  background: rgba(12,18,14,.94);
  overflow: hidden;
}
.god-module-head {
  padding: 12px 14px;
  border-bottom: 1px solid rgba(217,244,91,.12);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 12px;
}
.god-module-head span { color: var(--green); font: 800 9px "Roboto Mono", monospace; letter-spacing: .08em; }
.god-module-head h3 { margin: 0; color: #fff; font-size: 16px; }
.god-module-head strong { grid-row: 1 / 3; grid-column: 2; align-self: center; color: var(--acid); font: 900 12px "Roboto Mono", monospace; }
.god-branch-list { padding: 10px; display: grid; gap: 8px; }
.god-branch-title {
  width: 100%;
  min-height: 50px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: rgba(255,255,255,.035);
  color: #f4f8f0;
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 10px;
  align-items: center;
  padding: 10px 12px;
  text-align: left;
  cursor: pointer;
}
.god-branch-title:hover { border-color: rgba(217,244,91,.44); background: rgba(217,244,91,.07); }
.god-branch-title strong { font-size: 13px; }
.god-branch-title span { color: var(--acid); font-size: 10px; }
.god-branch-title em { color: var(--muted); font-size: 10px; font-style: normal; }
.god-branch.is-open .god-branch-title { border-color: var(--acid); }
.god-leaf-grid {
  margin: 8px 0 2px 18px;
  padding-left: 12px;
  border-left: 1px solid rgba(217,244,91,.24);
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.god-leaf {
  min-height: 82px;
  padding: 10px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 8px;
  background: rgba(5,10,7,.9);
  color: #f4f8f0;
  display: grid;
  grid-template-columns: 18px 1fr;
  grid-template-rows: auto auto;
  gap: 4px 8px;
  text-align: left;
  cursor: pointer;
}
.god-leaf:hover { border-color: var(--acid); background: rgba(217,244,91,.08); }
.god-leaf span { grid-row: 1 / 3; color: var(--acid); }
.god-leaf span svg { width: 16px; }
.god-leaf strong { font-size: 12px; }
.god-leaf small { color: var(--muted); font-size: 9px; line-height: 1.45; max-height: 28px; overflow: hidden; }

@media (max-width: 960px) {
  .god-tree-canvas { width: 100%; min-width: 100%; }
  .god-trunk, .god-trunk:nth-child(even) { grid-template-columns: 1fr; }
  .god-trunk:nth-child(even) .god-trunk-node, .god-trunk:nth-child(even) .god-module-grid { grid-column: auto; grid-row: auto; }
  .god-trunk-grid::before { left: 17px; }
  .god-trunk-node { min-height: 0; }
  .god-leaf-grid { grid-template-columns: 1fr; margin-left: 8px; }
}

/* Branching canopy mode: one tree, no framed board */
.god-tree-page { margin: -10px -12px 0; gap: 12px; }
.god-tree-toolbar {
  margin: 0;
  border: 0;
  border-radius: 0;
  background:
    linear-gradient(rgba(217,244,91,.045) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217,244,91,.035) 1px, transparent 1px),
    radial-gradient(circle at 72% 12%, rgba(217,244,91,.14), transparent 34%),
    transparent;
}
.god-tree-viewport {
  height: calc(100vh - 220px);
  min-height: 760px;
  border: 0;
  border-radius: 0;
  background:
    radial-gradient(circle at 50% 12%, rgba(217,244,91,.13), transparent 20%),
    radial-gradient(circle at 20% 42%, rgba(41,209,130,.06), transparent 24%),
    radial-gradient(circle at 82% 48%, rgba(91,168,255,.055), transparent 24%),
    linear-gradient(rgba(217,244,91,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217,244,91,.032) 1px, transparent 1px),
    #080d0a;
  background-size: auto, auto, auto, 42px 42px, 42px 42px, auto;
}
.god-tree-canvas {
  width: 1660px;
  min-width: 1660px;
  min-height: 1580px;
  padding: 54px 92px 160px;
  transform-origin: 50% 90px;
}
.god-root {
  position: relative;
  z-index: 3;
  margin-bottom: 96px;
}
.god-root::after {
  content: "";
  position: absolute;
  left: 50%;
  top: calc(100% + 1px);
  width: 2px;
  height: 76px;
  background: linear-gradient(var(--acid), rgba(217,244,91,.18));
}
.god-tree-spine { display: none; }
.god-trunk-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 112px 140px;
  align-items: start;
}
.god-trunk-grid::before {
  left: 15%;
  right: 15%;
  top: -38px;
  bottom: auto;
  width: auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217,244,91,.42), transparent);
}
.god-trunk {
  grid-template-columns: 230px minmax(0, 1fr);
  gap: 14px;
}
.god-trunk:nth-child(even) {
  grid-template-columns: minmax(0, 1fr) 230px;
}
.god-trunk::before {
  content: "";
  position: absolute;
  top: -38px;
  width: 1px;
  height: 38px;
  background: linear-gradient(rgba(217,244,91,.42), rgba(217,244,91,.08));
}
.god-trunk:nth-child(odd)::before { left: 115px; }
.god-trunk:nth-child(even)::before { right: 115px; }
.god-trunk-node {
  min-height: 190px;
  border-color: rgba(217,244,91,.34);
}
.god-module-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
}
.god-module {
  position: relative;
  overflow: visible;
}
.god-module::before {
  content: "";
  position: absolute;
  top: 28px;
  width: 14px;
  height: 1px;
  background: rgba(217,244,91,.28);
}
.god-trunk:nth-child(odd) .god-module::before { left: -14px; }
.god-trunk:nth-child(even) .god-module::before { right: -14px; }
.god-branch-list { gap: 7px; }
.god-branch-title { min-height: 46px; }

@media (max-width: 960px) {
  .god-tree-page { margin: 0; }
  .god-tree-viewport { height: calc(100vh - 280px); min-height: 660px; }
  .god-tree-canvas { width: 100%; min-width: 100%; min-height: 0; padding: 22px 14px 100px; }
  .god-root { margin-bottom: 54px; }
  .god-root::after { height: 42px; }
  .god-trunk-grid { grid-template-columns: 1fr; gap: 28px; }
  .god-trunk-grid::before, .god-trunk::before, .god-module::before { display: none; }
  .god-trunk, .god-trunk:nth-child(even) { grid-template-columns: 1fr; }
  .god-module-grid { grid-template-columns: 1fr; }
}

/* Dark theme readability pass */
.brand-mark,
.member-icon,
.path-number,
.chapter-index {
  background: var(--acid);
  color: #101711 !important;
  border-color: rgba(217, 244, 91, .42);
  font-weight: 900;
}

.brand-mark svg,
.member-icon svg,
.path-number svg,
.chapter-index svg {
  color: #101711;
  stroke: #101711;
}

.page-subtitle,
.path-card p,
.chapter-copy > p,
.reading-chapter p,
.learning-format-note,
.section-heading p,
.detail-card p,
.library-card p,
.plain-language-card p,
.god-root small,
.god-trunk-node p,
.god-node small,
.god-leaf small,
.god-tree-toolbar p {
  color: #c8d4cb !important;
}

.chapter-copy h2,
.reading-chapter h2,
.path-card h3,
.section-heading h2,
.detail-card h2,
.library-card h3 {
  color: #f7fbf4;
}

.learning-format-note {
  background: rgba(217, 244, 91, .10);
  border-color: rgba(217, 244, 91, .26);
}

.learning-format-note strong {
  color: #f7fbf4;
}

/* Global tree v2: full-canopy overview */
.god-tree-viewport {
  height: calc(100vh - 206px);
  min-height: 760px;
  overflow: hidden;
  background:
    radial-gradient(circle at 50% 8%, rgba(217,244,91,.16), transparent 18%),
    radial-gradient(circle at 15% 42%, rgba(41,209,130,.07), transparent 24%),
    radial-gradient(circle at 88% 44%, rgba(91,168,255,.06), transparent 24%),
    linear-gradient(rgba(217,244,91,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(217,244,91,.032) 1px, transparent 1px),
    #080d0a;
  background-size: auto, auto, auto, 44px 44px, 44px 44px, auto;
}

.god-tree-canvas {
  width: 2360px;
  min-width: 2360px;
  min-height: 1360px;
  padding: 44px 70px 120px;
  transform-origin: 50% 72px;
}

.god-root {
  width: 420px;
  min-height: 104px;
  margin-bottom: 112px;
}

.god-root::after {
  height: 96px;
}

.god-trunk-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 52px;
  align-items: start;
}

.god-trunk-grid::before {
  left: 8%;
  right: 8%;
  top: -52px;
  bottom: auto;
  width: auto;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(217,244,91,.58), transparent);
}

.god-trunk,
.god-trunk:nth-child(even) {
  display: grid;
  grid-template-columns: 1fr;
  gap: 24px;
}

.god-trunk:nth-child(even) .god-trunk-node,
.god-trunk:nth-child(even) .god-module-grid {
  grid-column: auto;
  grid-row: auto;
}

.god-trunk::before,
.god-trunk:nth-child(odd)::before,
.god-trunk:nth-child(even)::before {
  left: 50%;
  right: auto;
  top: -52px;
  width: 2px;
  height: 52px;
  background: linear-gradient(rgba(217,244,91,.58), rgba(217,244,91,.12));
  transform: translateX(-50%);
}

.god-trunk::after {
  content: "";
  position: absolute;
  left: 50%;
  top: 190px;
  bottom: 0;
  width: 1px;
  background: linear-gradient(rgba(217,244,91,.30), rgba(217,244,91,.04));
  transform: translateX(-50%);
}

.god-trunk-node {
  position: relative;
  z-index: 2;
  min-height: 178px;
  border-radius: 14px;
}

.god-module-grid {
  position: relative;
  z-index: 2;
  display: grid;
  grid-template-columns: 1fr;
  gap: 18px;
}

.god-module {
  border-radius: 12px;
}

.god-module::before {
  left: 50%;
  right: auto;
  top: -19px;
  width: 1px;
  height: 19px;
  background: rgba(217,244,91,.28);
  transform: translateX(-50%);
}

.god-trunk:nth-child(odd) .god-module::before,
.god-trunk:nth-child(even) .god-module::before {
  left: 50%;
  right: auto;
}

.god-layer-list {
  padding: 10px;
  display: grid;
  gap: 10px;
}

.god-layer-node {
  position: relative;
  border: 1px solid rgba(217,244,91,.14);
  border-radius: 10px;
  background: rgba(255,255,255,.025);
  padding: 9px;
}

.god-layer-node::before {
  content: "";
  position: absolute;
  left: 18px;
  top: 42px;
  bottom: 12px;
  width: 1px;
  background: rgba(217,244,91,.18);
}

.god-layer-node.is-simple::before {
  display: none;
}

.god-layer-node > header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 0 2px 8px;
  color: #f7fbf4;
}

.god-layer-node > header span {
  color: #d9f45b;
  font: 900 11px "Roboto Mono", monospace;
}

.god-layer-node > header strong {
  color: #101711;
  background: #d9f45b;
  border-radius: 999px;
  padding: 3px 7px;
  font: 900 10px "Roboto Mono", monospace;
}

.god-layer-node .god-branch-list {
  padding: 0;
  gap: 7px;
}

.god-layer-node:not(.is-simple) .god-branch {
  margin-left: 18px;
}

.god-layer-node:not(.is-simple) .god-branch-title::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 50%;
  width: 18px;
  height: 1px;
  background: rgba(217,244,91,.22);
}

.god-branch-title {
  position: relative;
}

.god-leaf-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

@media (max-width: 960px) {
  .god-tree-canvas {
    width: 1180px;
    min-width: 1180px;
    min-height: 1500px;
    transform-origin: 0 0;
  }
  .god-trunk-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* Global tree v3: branch forks at every depth */
.god-module-head {
  position: relative;
}

.god-module-head::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: -16px;
  width: 1px;
  height: 16px;
  background: linear-gradient(rgba(217,244,91,.34), rgba(217,244,91,.08));
}

.god-layer-list {
  position: relative;
  margin: 0 10px 12px 22px;
  padding: 18px 0 0 28px;
}

.god-layer-list::before {
  content: "";
  position: absolute;
  left: 12px;
  top: 0;
  bottom: 18px;
  width: 1px;
  background: linear-gradient(rgba(217,244,91,.36), rgba(217,244,91,.08));
}

.god-layer-node {
  position: relative;
}

.god-layer-node::after {
  content: "";
  position: absolute;
  left: -16px;
  top: 24px;
  width: 16px;
  height: 1px;
  background: rgba(217,244,91,.30);
}

.god-layer-node::before,
.god-layer-node.is-simple::before {
  display: block;
  left: 16px;
  top: 38px;
  bottom: 14px;
  background: linear-gradient(rgba(217,244,91,.24), rgba(217,244,91,.06));
}

.god-layer-node .god-branch-list {
  position: relative;
  margin-left: 12px;
  padding-left: 18px;
}

.god-layer-node .god-branch-list::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  bottom: 8px;
  width: 1px;
  background: linear-gradient(rgba(217,244,91,.26), rgba(217,244,91,.06));
}

.god-layer-node:not(.is-simple) .god-branch,
.god-layer-node.is-simple .god-branch {
  position: relative;
  margin-left: 0;
}

.god-branch::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 24px;
  width: 18px;
  height: 1px;
  background: rgba(217,244,91,.26);
}

.god-layer-node:not(.is-simple) .god-branch-title::before {
  display: none;
}

.god-leaf-grid {
  position: relative;
  margin: 9px 0 3px 20px;
  padding-left: 18px;
  border-left: 0;
}

.god-leaf-grid::before {
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 1px;
  background: linear-gradient(rgba(217,244,91,.28), rgba(217,244,91,.06));
}

.god-leaf {
  position: relative;
}

.god-leaf::before {
  content: "";
  position: absolute;
  left: -18px;
  top: 24px;
  width: 18px;
  height: 1px;
  background: rgba(217,244,91,.24);
}

/* Global tree v4: expanded logic-tree forks */
.god-module {
  overflow: visible;
}

.god-module-head {
  z-index: 3;
  border-radius: 12px 12px 0 0;
}

.god-module-head::after {
  left: 50%;
  bottom: -22px;
  height: 22px;
}

.god-layer-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 18px 16px;
  margin: 0;
  padding: 28px 12px 14px;
}

.god-layer-list::before {
  left: 16%;
  right: 16%;
  top: 12px;
  bottom: auto;
  width: auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217,244,91,.36), transparent);
}

.god-layer-node {
  display: grid;
  gap: 10px;
  padding: 0;
  border: 0;
  background: transparent;
}

.god-layer-node::after {
  left: 50%;
  top: -16px;
  width: 1px;
  height: 16px;
  background: rgba(217,244,91,.30);
  transform: translateX(-50%);
}

.god-layer-node::before,
.god-layer-node.is-simple::before {
  left: 50%;
  top: 36px;
  bottom: 18px;
  width: 1px;
  background: linear-gradient(rgba(217,244,91,.22), rgba(217,244,91,.04));
  transform: translateX(-50%);
}

.god-layer-node > header {
  min-height: 42px;
  padding: 9px 10px;
  border: 1px solid rgba(217,244,91,.28);
  border-radius: 9px;
  background: radial-gradient(circle at 20% 0%, rgba(217,244,91,.12), transparent 60%), rgba(8,13,10,.94);
  box-shadow: 0 0 18px rgba(0,0,0,.16);
}

.god-layer-node.is-simple > header {
  display: none;
}

.god-layer-node .god-branch-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin: 0;
  padding: 16px 0 0;
}

.god-layer-node .god-branch-list::before {
  left: 18%;
  right: 18%;
  top: 6px;
  bottom: auto;
  width: auto;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(217,244,91,.28), transparent);
}

.god-branch::before {
  left: 50%;
  top: -10px;
  width: 1px;
  height: 10px;
  background: rgba(217,244,91,.24);
  transform: translateX(-50%);
}

.god-branch-title {
  min-height: 58px;
  grid-template-columns: 1fr auto;
  align-content: center;
  border-color: rgba(217,244,91,.16);
  background: rgba(255,255,255,.045);
}

.god-branch-title strong {
  display: block;
  font-size: 12px;
  line-height: 1.25;
}

.god-branch-title span {
  grid-column: 1;
  font-size: 9px;
}

.god-branch-title em {
  grid-row: 1 / 3;
  grid-column: 2;
  align-self: center;
  color: rgba(217,244,91,.78);
}

.god-leaf-grid {
  grid-column: 1 / -1;
}

@media (max-width: 960px) {
  .god-layer-list,
  .god-layer-node .god-branch-list {
    grid-template-columns: 1fr;
  }
}

/* Global tree v5: no inner boxes, pure branch diagram */
.god-module {
  border-color: rgba(217,244,91,.12);
  background: rgba(8,13,10,.62);
}

.god-layer-node,
.god-layer-node > header,
.god-branch-title,
.god-leaf {
  box-shadow: none;
}

.god-layer-node > header {
  min-height: 22px;
  padding: 0 0 0 14px;
  border: 0;
  border-radius: 0;
  background: transparent;
  justify-content: flex-start;
}

.god-layer-node > header::before {
  content: "";
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--acid);
  box-shadow: 0 0 10px rgba(217,244,91,.55);
  margin-left: -14px;
}

.god-layer-node > header strong {
  margin-left: auto;
  background: transparent;
  color: var(--acid);
  padding: 0;
}

.god-branch-title {
  min-height: 38px;
  padding: 4px 0 4px 14px;
  border: 0;
  border-radius: 0;
  background: transparent;
  display: grid;
  grid-template-columns: 1fr auto;
}

.god-branch-title:hover {
  border-color: transparent;
  background: rgba(217,244,91,.045);
}

.god-branch-title::after {
  content: "";
  position: absolute;
  left: 1px;
  top: 15px;
  width: 6px;
  height: 6px;
  border: 1px solid rgba(217,244,91,.72);
  border-radius: 50%;
  background: #080d0a;
}

.god-branch-title strong {
  color: #f7fbf4;
  font-size: 11px;
}

.god-branch-title span {
  color: rgba(217,244,91,.84);
  font-size: 9px;
}

.god-branch-title em {
  padding-left: 8px;
  font-size: 9px;
}

.god-branch.is-open .god-branch-title {
  border-color: transparent;
  background: rgba(217,244,91,.055);
}

.god-leaf-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 4px 12px;
  margin-top: 4px;
}

.god-leaf {
  min-height: 30px;
  padding: 3px 0 3px 18px;
  border: 0;
  border-radius: 0;
  background: transparent;
  grid-template-columns: 0 1fr;
  gap: 0;
}

.god-leaf:hover {
  border-color: transparent;
  background: rgba(217,244,91,.055);
}

.god-leaf span {
  display: none;
}

.god-leaf::after {
  content: "";
  position: absolute;
  left: 3px;
  top: 12px;
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: rgba(217,244,91,.82);
}

.god-leaf strong {
  font-size: 10px;
  line-height: 1.2;
}

.god-leaf small {
  display: none;
}

/* Global tree v6: remove module frames too */
.god-module {
  border: 0;
  background: transparent;
}

.god-module-head {
  padding: 0 0 8px;
  border-bottom: 0;
  background: transparent;
}

.god-module-head h3 {
  font-size: 13px;
}

.god-module-head strong {
  font-size: 10px;
}

/* Product Design tree correction: same-depth nodes align as logic-tree siblings */
.god-layer-list {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  grid-auto-flow: row;
  gap: 20px 22px;
}

.god-layer-node {
  align-content: start;
  align-items: start;
  min-height: 0;
}

.god-layer-node.is-simple > header {
  display: flex;
}

.god-layer-node::before,
.god-layer-node.is-simple::before {
  top: 26px;
  bottom: auto;
  height: calc(100% - 26px);
  opacity: .7;
}

.god-layer-node > header {
  width: 100%;
  min-height: 20px;
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 0 0 4px 14px;
}

.god-layer-node > header span {
  white-space: normal;
  line-height: 1.25;
}

.god-layer-node .god-branch-list {
  width: 100%;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: start;
  gap: 8px 10px;
  padding-top: 12px;
}

.god-branch {
  min-height: 0;
}

.god-branch-title {
  min-height: 0;
  align-items: start;
  padding: 2px 0 3px 14px;
}

.god-branch-title strong,
.god-branch-title span,
.god-branch-title em {
  line-height: 1.25;
}

.god-branch-title::after {
  top: 8px;
}

/* Product Design v7: unbounded horizontal logic tree */
.god-tree-canvas {
  width: 6800px;
  min-width: 6800px;
  min-height: 1680px;
  margin: 0;
  padding: 44px 140px 160px;
  transform-origin: 0 72px;
}

.god-root {
  margin-left: 1420px;
}

.god-root::after {
  left: 50%;
}

.god-trunk-grid {
  display: flex;
  align-items: flex-start;
  gap: 170px;
  width: max-content;
}

.god-trunk-grid::before {
  left: 310px;
  right: auto;
  width: 3000px;
}

.god-trunk,
.god-trunk:nth-child(even) {
  width: max-content;
  min-width: 720px;
}

.god-trunk::before,
.god-trunk:nth-child(odd)::before,
.god-trunk:nth-child(even)::before {
  left: 310px;
}

.god-trunk::after {
  left: 310px;
}

.god-trunk-node {
  width: 620px;
}

.god-module-grid {
  width: max-content;
}

.god-module {
  width: max-content;
  min-width: 620px;
}

.god-module-head {
  width: 620px;
}

.god-module-head::after {
  left: 310px;
}

.god-layer-list {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: 56px;
  width: max-content;
  min-width: 620px;
}

.god-layer-list::before {
  left: 40px;
  right: auto;
  width: calc(100% - 80px);
}

.god-layer-node {
  flex: 0 0 auto;
  width: max-content;
  min-width: 190px;
}

.god-layer-node::after {
  left: 32px;
}

.god-layer-node::before,
.god-layer-node.is-simple::before {
  left: 32px;
}

.god-layer-node .god-branch-list {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: 14px;
  width: max-content;
}

.god-layer-node .god-branch-list::before {
  left: 28px;
  right: auto;
  width: calc(100% - 56px);
}

.god-branch {
  flex: 0 0 148px;
  width: 148px;
}

.god-leaf-grid {
  display: flex;
  flex-wrap: nowrap;
  width: max-content;
}

.god-leaf {
  flex: 0 0 128px;
}

/* Product Design v8: industry map homepage */
.industry-map-page {
  margin: -10px -12px 0;
  display: grid;
  gap: 14px;
  min-height: calc(100vh - 140px);
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
}

.industry-map-hero {
  padding: 34px 28px;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 24px;
  background:
    radial-gradient(circle at 18% 0, rgba(217, 244, 91, .18), transparent 32%),
    linear-gradient(135deg, rgba(10, 22, 14, .98), rgba(3, 8, 6, .98));
  border-bottom: 1px solid rgba(217, 244, 91, .14);
}

.industry-map-hero span,
.industry-overview > header span,
.industry-focus-head span,
.industry-insight > header span {
  color: var(--green);
  font: 800 11px "Roboto Mono", monospace;
  letter-spacing: 0;
}

.industry-map-hero h1 {
  margin: 8px 0;
  color: #fff;
  font-size: clamp(38px, 5vw, 76px);
  line-height: .96;
}

.industry-map-hero p {
  max-width: 760px;
  margin: 0;
  color: #c8d4cb;
  font-size: 13px;
  line-height: 1.75;
}

.industry-map-actions {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.industry-track-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-width: 0;
  max-width: 100%;
  overflow-x: hidden;
  overflow-y: visible;
  padding: 0 28px 8px;
  border-bottom: 1px solid rgba(217, 244, 91, .12);
  box-sizing: border-box;
}

.industry-track-tabs button {
  flex: 0 1 auto;
  min-width: 0;
  max-width: 100%;
  min-height: 38px;
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  border: 1px solid rgba(217, 244, 91, .15);
  border-radius: 0;
  background: rgba(255, 255, 255, .025);
  color: #d9e4d8;
  cursor: pointer;
  white-space: nowrap;
}

.industry-track-tabs button.is-active {
  background: var(--acid);
  color: #101711;
  border-color: var(--acid);
  font-weight: 900;
}

.industry-track-tabs span {
  color: inherit;
  opacity: .72;
  font: 900 10px "Roboto Mono", monospace;
}

.industry-map-shell {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 16px;
  align-items: start;
  padding: 0 28px 32px;
}

.industry-map-shell.is-single {
  grid-template-columns: minmax(0, 1fr);
}

.industry-main {
  display: grid;
  gap: 16px;
  min-width: 0;
}

.industry-overview,
.industry-focus,
.industry-insight {
  border: 1px solid rgba(217, 244, 91, .14);
  background: rgba(8, 13, 10, .72);
}

.industry-overview > header,
.industry-focus-head,
.industry-insight > header {
  min-height: 56px;
  padding: 14px 16px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-bottom: 1px solid rgba(217, 244, 91, .12);
}

.industry-overview > header strong {
  color: var(--acid);
  font: 900 12px "Roboto Mono", monospace;
}

.industry-row {
  width: 100%;
  display: grid;
  grid-template-columns: 44px minmax(170px, 220px) repeat(4, minmax(145px, 1fr));
  gap: 10px;
  padding: 12px 14px;
  border: 0;
  border-bottom: 1px solid rgba(217, 244, 91, .09);
  background: transparent;
  color: #f6fbf3;
  text-align: left;
  cursor: pointer;
}

.industry-row:hover,
.industry-row.is-active {
  background: rgba(217, 244, 91, .06);
}

.industry-row-index {
  color: var(--acid);
  font: 900 12px "Roboto Mono", monospace;
}

.industry-row-title strong {
  display: block;
  font-size: 15px;
}

.industry-row-title em {
  display: block;
  margin-top: 3px;
  color: #9fb0a4;
  font-style: normal;
  font-size: 10px;
}

.industry-row-stage {
  min-width: 0;
  display: grid;
  align-content: start;
  gap: 6px;
}

.industry-row-stage small {
  color: #7f8b82;
  font-size: 9px;
}

.industry-chip {
  min-height: 48px;
  padding: 8px 9px;
  display: grid;
  grid-template-columns: 18px 1fr;
  gap: 3px 7px;
  border: 1px solid rgba(217, 244, 91, .13);
  border-radius: 0;
  background: rgba(255, 255, 255, .025);
  color: #f7fbf4;
  text-align: left;
  cursor: pointer;
}

.industry-chip:hover {
  border-color: rgba(217, 244, 91, .45);
  background: rgba(217, 244, 91, .07);
}

.industry-chip > span {
  grid-row: 1 / 3;
  color: var(--acid);
}

.industry-chip svg {
  width: 15px;
  height: 15px;
}

.industry-chip strong {
  font-size: 12px;
  line-height: 1.25;
}

.industry-chip small {
  color: #9fb0a4;
  font-size: 9px;
}

.industry-chip em:not(.access-lock-mark) {
  grid-column: 2;
  color: rgba(217, 244, 91, .78);
  font-style: normal;
  font: 800 8px "Roboto Mono", monospace;
  text-transform: uppercase;
}

.industry-chip.is-compact {
  min-height: 28px;
  padding: 4px 6px;
  grid-template-columns: 1fr;
}

.industry-chip.is-compact > span,
.industry-chip.is-compact small {
  display: none;
}

.industry-chip.is-compact strong {
  font-size: 10px;
}

.industry-empty {
  color: #718076;
  font-size: 10px;
}

.industry-focus-head h2,
.industry-insight h2 {
  margin: 2px 0 0;
  color: #fff;
  font-size: 20px;
}

.industry-demand-drivers {
  padding: 12px 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  border-bottom: 1px solid rgba(217, 244, 91, .10);
  background: rgba(217, 244, 91, .035);
}

.industry-demand-drivers strong {
  margin-right: 4px;
  color: var(--acid);
  font-size: 12px;
}

.industry-demand-drivers span {
  padding: 5px 8px;
  border: 1px solid rgba(217, 244, 91, .18);
  background: rgba(0, 0, 0, .16);
  color: #dbe9da;
  font-size: 10px;
}

.industry-swimlanes {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
  align-items: stretch;
}

.industry-lane {
  min-height: 0;
  padding: 14px;
  border-right: 1px solid rgba(217, 244, 91, .10);
  border-bottom: 1px solid rgba(217, 244, 91, .10);
}

.industry-lane:last-child {
  border-right: 0;
}

.industry-lane header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  margin-bottom: 12px;
}

.industry-lane header strong {
  color: var(--acid);
  font-size: 14px;
}

.industry-lane header span {
  padding: 2px 7px;
  border: 1px solid rgba(217, 244, 91, .16);
  border-radius: 999px;
  color: var(--acid);
  font: 900 10px "Roboto Mono", monospace;
  line-height: 1.45;
}

.industry-lane > div {
  display: grid;
  gap: 8px;
}

.industry-insight {
  position: sticky;
  top: 86px;
  display: grid;
}

.industry-insight section {
  padding: 14px 16px;
  display: grid;
  gap: 10px;
  border-top: 1px solid rgba(217, 244, 91, .10);
}

.industry-insight section strong {
  color: #f7fbf4;
  font-size: 13px;
}

.insight-list {
  display: grid;
  gap: 7px;
}

.insight-list button,
.insight-tags button {
  padding: 5px 0;
  border: 0;
  border-bottom: 1px solid rgba(217, 244, 91, .10);
  background: transparent;
  color: #dce8df;
  text-align: left;
  cursor: pointer;
}

.insight-list button span {
  display: block;
  margin-top: 2px;
  color: #8fa096;
  font-size: 9px;
}

.insight-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.insight-tags button {
  padding: 5px 7px;
  border: 1px solid rgba(217, 244, 91, .14);
}

@media (max-width: 1100px) {
  .industry-map-shell {
    grid-template-columns: 1fr;
  }

  .industry-insight {
    position: static;
  }

  .industry-row {
    grid-template-columns: 38px minmax(150px, 1fr);
  }

  .industry-row-stage {
    grid-column: 2;
  }

  .industry-swimlanes {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 720px) {
  .industry-map-page {
    margin: 0;
  }

  .industry-map-hero {
    padding: 24px 16px;
    display: grid;
  }

  .industry-map-hero h1 {
    font-size: 42px;
  }

  .industry-track-tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    padding: 0 16px 8px;
  }

  .industry-track-tabs button {
    flex: 0 0 auto;
  }

  .industry-map-shell {
    padding: 0 16px 28px;
  }

  .industry-overview {
    overflow: hidden;
  }

  .industry-row {
    display: grid;
    grid-template-columns: 34px 1fr;
    gap: 8px;
    padding: 12px;
  }

  .industry-row-stage {
    display: none;
  }

  .industry-swimlanes {
    grid-template-columns: 1fr;
  }

  .industry-lane {
    min-height: 0;
    border-right: 0;
    border-bottom: 1px solid rgba(217, 244, 91, .10);
  }
}

/* Access boundary final overrides */
.company-table tr.is-access-locked td:first-child {
  position: relative;
}

.library-card.is-access-locked,
.industry-chip.is-access-locked,
.company-table tr.is-access-locked,
.market-tab.is-access-locked,
.filter-button.is-access-locked,
.industry-track-tabs button.is-access-locked,
.path-card.locked-node,
.god-leaf.locked-node {
  overflow: hidden;
  border-color: rgba(217, 244, 91, .28) !important;
  background:
    linear-gradient(135deg, rgba(217, 244, 91, .08), rgba(255, 255, 255, .018)),
    rgba(16, 23, 18, .92) !important;
}

.lock-badge,
.access-lock-mark,
.inline-lock,
.subscription-lock {
  z-index: 4;
  display: inline-flex !important;
  align-items: center;
  justify-content: center;
  gap: 5px;
  min-height: 22px;
  padding: 3px 7px;
  border: 1px solid rgba(217, 244, 91, .36) !important;
  border-radius: 4px;
  background: rgba(7, 12, 9, .96) !important;
  color: var(--acid) !important;
  font-size: 9px !important;
  font-style: normal;
  font-weight: 900 !important;
  line-height: 1;
  filter: none !important;
  opacity: 1 !important;
  text-shadow: none !important;
}

.lock-badge svg,
.access-lock-mark svg,
.inline-lock svg,
.subscription-lock svg {
  width: 12px !important;
  height: 12px !important;
  color: var(--acid) !important;
  stroke: var(--acid) !important;
}

.industry-row-title i,
.market-tab.is-access-locked span i,
.filter-button.is-access-locked i,
.industry-track-tabs button.is-access-locked i {
  margin-left: 6px;
  width: 13px;
  height: 13px;
  color: var(--acid);
  stroke: var(--acid);
  vertical-align: -2px;
}

.access-preview-banner {
  border-color: rgba(217, 244, 91, .30) !important;
  background: rgba(217, 244, 91, .09) !important;
  color: #edf6e9 !important;
}

.access-preview-banner .text-button {
  color: var(--acid) !important;
}

.radar-free-banner {
  margin: -4px 0 16px;
}

.radar-subscription.is-limit-locked {
  position: relative;
  border-style: dashed;
  opacity: .82;
}

.radar-subscription.is-limit-locked .subscription-copy {
  filter: blur(3px);
  opacity: .48;
}

.subscription-lock {
  margin-left: auto;
  white-space: nowrap;
}


.score-pill {
  position: absolute;
  top: 14px;
  right: 14px;
  min-width: 34px;
  padding: 4px 8px;
  border: 1px solid rgba(217, 244, 91, .36);
  border-radius: 999px;
  background: rgba(217, 244, 91, .11);
  color: var(--acid);
  font: 800 11px "Roboto Mono", monospace;
  text-align: center;
}

.score-card {
  border-top: 4px solid var(--acid);
}

.score-summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
  padding: 14px 16px;
  border: 1px solid rgba(217, 244, 91, .18);
  border-radius: 8px;
  background: rgba(217, 244, 91, .08);
}

.score-summary div {
  display: grid;
  gap: 4px;
}

.score-summary span {
  color: var(--muted);
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0;
}

.score-summary strong {
  color: var(--acid);
  font: 900 38px "Roboto Mono", monospace;
  line-height: 1;
}

.score-summary em {
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(217, 244, 91, .16);
  color: var(--acid);
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  white-space: nowrap;
}

.industry-chip small {
  line-height: 1.45;
}


.industry-track-tabs,
.filter-bar,
.map-switcher,
.relation-mini,
.position-strip,
.learning-figure,
.trace-flow {
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  scroll-snap-type: x proximity;
}

.industry-track-tabs button,
.filter-button,
.map-switch,
.relation-mini span,
.position-strip span,
.learning-figure span,
.trace-flow > .trace-step {
  scroll-snap-align: start;
}

.industry-track-tabs::-webkit-scrollbar,
.filter-bar::-webkit-scrollbar,
.map-switcher::-webkit-scrollbar,
.relation-mini::-webkit-scrollbar,
.position-strip::-webkit-scrollbar,
.learning-figure::-webkit-scrollbar,
.trace-flow::-webkit-scrollbar {
  height: 0;
}

.mobile-swipe-hint {
  display: none;
}

@media (max-width: 720px) {
  .industry-track-tabs,
  .filter-bar {
    touch-action: pan-x;
    cursor: grab;
  }

  .industry-track-tabs::after,
  .filter-bar::after {
    content: "";
    flex: 0 0 18px;
  }
}


.source-library-card { display: grid; gap: 16px; }
.source-library-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; }
.source-library-head h2 { margin: 0 0 8px; }
.source-library-head p { margin: 0; color: var(--muted); max-width: 760px; }
.source-library-head > span { min-width: 36px; height: 36px; display: grid; place-items: center; border: 1px solid rgba(217,244,91,.28); background: rgba(217,244,91,.1); color: var(--acid); font: 800 13px "Roboto Mono", monospace; }
.source-list { display: grid; gap: 10px; }
.source-item { border: 1px solid var(--line); background: rgba(255,255,255,.02); padding: 14px; display: grid; gap: 12px; }
.source-item header { display: flex; align-items: flex-start; justify-content: space-between; gap: 12px; }
.source-item header strong { display: block; color: var(--ink); font-size: 14px; }
.source-item header span { display: block; margin-top: 4px; color: var(--muted); font-size: 11px; line-height: 1.5; }
.source-item header em { min-width: 28px; height: 28px; display: grid; place-items: center; background: var(--acid); color: #101510; font-style: normal; font-weight: 900; }
.source-item.tier-B header em { background: rgba(0,220,160,.22); color: var(--green); border: 1px solid rgba(0,220,160,.36); }
.source-item.tier-C header em { background: rgba(255,255,255,.08); color: var(--muted); border: 1px solid var(--line); }
.source-item dl { display: grid; gap: 8px; margin: 0; }
.source-item dl div { display: grid; grid-template-columns: 120px minmax(0,1fr); gap: 12px; }
.source-item dt { color: var(--muted); font-size: 10px; }
.source-item dd { margin: 0; color: var(--ink); font-size: 11px; line-height: 1.55; }
.source-item a { justify-self: start; color: var(--acid); text-decoration: none; font-weight: 800; display: inline-flex; align-items: center; gap: 6px; }
.source-item a svg { width: 14px; height: 14px; }
.source-tier-note { display: grid; gap: 6px; padding-top: 12px; border-top: 1px solid var(--line); color: var(--muted); font-size: 10px; line-height: 1.5; }
@media (max-width: 760px) {
  .source-library-head { display: grid; }
  .source-item dl div { grid-template-columns: 1fr; gap: 4px; }
}
