:root {
  --bg: #f4f7fa;
  --surface: #ffffff;
  --ink: #122033;
  --muted: #6e7c8d;
  --navy: #0c1726;
  --navy-2: #15283f;
  --cyan: #18b8c9;
  --cyan-soft: #e1f7fa;
  --green: #69d092;
  --green-soft: #e8f8ef;
  --amber: #f2b84b;
  --amber-soft: #fff3d8;
  --purple: #8d7cf6;
  --purple-soft: #efedff;
  --red: #e86c70;
  --red-soft: #fde9ea;
  --line: #dce4ea;
  --shadow: 0 14px 34px rgba(26, 46, 70, 0.08);
  font-family: Inter, "PingFang SC", "Microsoft YaHei", system-ui, -apple-system, sans-serif;
  color: var(--ink);
  background: var(--bg);
}

* { box-sizing: border-box; }
body { margin: 0; min-width: 1180px; background: var(--bg); }
button, input, select { font: inherit; }
button { cursor: pointer; }

.app-shell { min-height: 100vh; display: grid; grid-template-columns: 260px 1fr; }
.sidebar { position: fixed; inset: 0 auto 0 0; width: 260px; padding: 28px 20px; display: flex; flex-direction: column; background: var(--navy); color: white; z-index: 10; }
.brand { display: flex; align-items: center; gap: 12px; padding: 0 7px 28px; }
.brand-mark { width: 42px; height: 42px; border: 1px solid rgba(255,255,255,.22); display: grid; place-items: center; font-weight: 900; letter-spacing: -.06em; color: var(--cyan); border-radius: 11px; }
.brand strong, .brand span { display: block; }
.brand strong { font-size: 19px; letter-spacing: .02em; }
.brand span { color: #93a8bd; font-size: 12px; margin-top: 3px; }
.nav-list { display: grid; gap: 7px; }
.nav-item { border: 0; background: transparent; color: #91a4b7; text-align: left; padding: 13px 15px; border-radius: 10px; display: flex; gap: 13px; align-items: center; }
.nav-item span { color: #526a83; font-size: 11px; font-weight: 700; }
.nav-item:hover { color: white; background: rgba(255,255,255,.05); }
.nav-item.active { color: white; background: var(--navy-2); box-shadow: inset 3px 0 var(--cyan); }
.nav-item.active span { color: var(--cyan); }
.sidebar-card { margin-top: auto; padding: 18px; background: rgba(255,255,255,.055); border: 1px solid rgba(255,255,255,.08); border-radius: 14px; }
.sidebar-card strong { display: block; font-size: 17px; margin-top: 7px; }
.sidebar-card p { margin: 4px 0 15px; color: #a6b6c6; font-size: 12px; line-height: 1.5; }
.mini-progress { height: 4px; background: #213650; margin-bottom: 8px; border-radius: 99px; overflow: hidden; }
.mini-progress i { display: block; height: 100%; background: var(--cyan); }
.sidebar-card small { color: #7f94aa; }
.sidebar-foot { padding: 22px 8px 0; display: flex; gap: 10px; align-items: center; }
.status-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 5px rgba(105,201,146,.12); }
.sidebar-foot strong, .sidebar-foot small { display: block; }
.sidebar-foot small { color: #758aa0; font-size: 11px; }

.main { grid-column: 2; min-height: 100vh; padding: 0 34px 50px; }
.topbar { height: 104px; display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid var(--line); margin-bottom: 28px; }
.eyebrow { display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .14em; color: #7a8998; font-weight: 800; }
.topbar h1 { margin: 7px 0 0; font-size: 24px; letter-spacing: -.03em; }
.top-actions { display: flex; align-items: center; gap: 12px; }
.source-badge { padding: 9px 12px; background: var(--amber-soft); color: #8d6616; border: 1px solid #f3d79f; border-radius: 8px; font-size: 12px; }

.view { display: none; }
.view.active { display: block; animation: rise .25s ease-out; }
@keyframes rise { from { opacity: .3; transform: translateY(5px); } to { opacity: 1; transform: none; } }

.overview-hero { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: 20px; }
.hero-card { min-height: 370px; background: var(--navy); color: white; box-shadow: var(--shadow); display: grid; grid-template-columns: 1.2fr .8fr; overflow: hidden; position: relative; border-radius: 18px; }
.hero-card:after { content: ""; position: absolute; width: 260px; height: 260px; border: 1px solid rgba(23,185,199,.16); right: -110px; top: -80px; border-radius: 50%; }
.hero-copy { padding: 46px 20px 42px 46px; position: relative; z-index: 2; }
.hero-copy h2 { font-size: 32px; line-height: 1.25; letter-spacing: -.04em; max-width: 720px; margin: 24px 0 16px; }
.hero-copy p { color: #a9bbc9; line-height: 1.8; max-width: 730px; font-size: 14px; }
.hero-actions { display: flex; gap: 12px; margin-top: 28px; }
.company-hero-card { grid-template-columns: 1.18fr .82fr; background: linear-gradient(135deg, #081421 0%, #102b45 58%, #0a1624 100%); }
.company-proof-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-top: 28px; max-width: 740px; }
.company-proof-row div { padding: 13px 12px; border: 1px solid rgba(255,255,255,.12); background: rgba(255,255,255,.055); border-radius: 12px; }
.company-proof-row strong, .company-proof-row span { display: block; }
.company-proof-row strong { font-size: 17px; color: #ffffff; }
.company-proof-row span { margin-top: 4px; color: #91a8ba; font-size: 11px; }
.precision-visual { position: relative; display: grid; place-items: center; min-height: 370px; overflow: hidden; background: radial-gradient(circle at 50% 44%, rgba(24,184,201,.2), rgba(14,30,49,.28) 42%, rgba(8,20,33,.82) 72%); }
.visual-grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px); background-size: 34px 34px; mask-image: radial-gradient(circle, #000 0%, transparent 76%); }
.bearing-visual { position: relative; width: 220px; height: 220px; display: grid; place-items: center; }
.bearing-visual .ring { position: absolute; border-radius: 50%; border-style: solid; }
.bearing-visual .outer { inset: 0; border-width: 18px; border-color: rgba(24,184,201,.95); box-shadow: 0 0 50px rgba(24,184,201,.28), inset 0 0 25px rgba(255,255,255,.16); }
.bearing-visual .middle { inset: 42px; border-width: 13px; border-color: rgba(255,255,255,.8); }
.bearing-visual .inner { inset: 82px; border-width: 10px; border-color: rgba(105,208,146,.95); }
.bearing-visual .ball { position: absolute; width: 18px; height: 18px; border-radius: 50%; background: #f6fcff; box-shadow: 0 0 16px rgba(255,255,255,.35); }
.bearing-visual .b1 { top: 18px; left: 101px; }
.bearing-visual .b2 { right: 21px; top: 101px; }
.bearing-visual .b3 { bottom: 18px; left: 101px; }
.bearing-visual .b4 { left: 21px; top: 101px; }
.bearing-visual strong { position: relative; z-index: 2; font-size: 24px; letter-spacing: .08em; color: #ffffff; }
.capability-stack { position: absolute; right: 22px; bottom: 22px; display: grid; gap: 8px; }
.capability-stack span { color: #cce8ee; border: 1px solid rgba(83,217,227,.18); background: rgba(7,20,29,.5); padding: 7px 10px; border-radius: 999px; font-size: 11px; font-weight: 800; }
.customer-wall-card { background: white; padding: 24px; box-shadow: var(--shadow); border: 1px solid var(--line); border-radius: 18px; }
.customer-wall-card h3 { margin: 8px 0 18px; font-size: 20px; }
.customer-group { padding: 12px 0; border-top: 1px solid var(--line); }
.customer-group span { display: block; color: #7a8998; font-size: 11px; font-weight: 900; letter-spacing: .08em; margin-bottom: 8px; }
.customer-group div { display: flex; flex-wrap: wrap; gap: 7px; }
.customer-group b { display: inline-flex; align-items: center; min-height: 28px; padding: 5px 9px; border-radius: 8px; background: #f6f9fb; border: 1px solid #e2e9ee; color: #1b2e42; font-size: 12px; }
.hero-orbit { position: relative; display: grid; place-items: center; min-height: 360px; overflow: hidden; background: radial-gradient(circle at center, #132b42, #0e1e31 70%); }
.orbit-ring { position: absolute; border-radius: 50%; border: 1px solid rgba(24,184,201,.35); }
.ring-a { width: 260px; height: 260px; animation: spin 18s linear infinite; }
.ring-b { width: 190px; height: 190px; border-color: rgba(105,208,146,.28); animation: spin 14s linear reverse infinite; }
.orbit-core { width: 92px; height: 92px; display: grid; place-items: center; border-radius: 50%; border: 11px solid var(--cyan); color: #fff; font-size: 21px; font-weight: 900; box-shadow: 0 0 48px rgba(24,184,201,.26); }
.orbit-label { position: absolute; color: #c9d6df; font-size: 12px; background: rgba(255,255,255,.06); padding: 5px 8px; border-radius: 999px; }
.l1 { top: 62px; left: 75px; }
.l2 { top: 112px; right: 50px; }
.l3 { right: 85px; bottom: 92px; color: #70e1ed; }
.l4 { bottom: 54px; left: 88px; }
.l5 { left: 45px; top: 183px; }
@keyframes spin { to { transform: rotate(360deg); } }

.pill { display: inline-flex; align-items: center; padding: 6px 9px; border-radius: 6px; font-size: 11px; font-weight: 800; letter-spacing: .04em; }
.pill.cyan { background: rgba(23,185,199,.15); color: #53d9e3; border: 1px solid rgba(83,217,227,.25); }
.pill.amber { background: var(--amber-soft); color: #93670e; }
.primary-button, .secondary-button, .ghost-button { border: 0; padding: 12px 18px; border-radius: 8px; font-weight: 800; transition: .18s ease; }
.primary-button { background: var(--cyan); color: #07141d; }
.primary-button:hover { background: #34ced9; transform: translateY(-1px); }
.secondary-button { background: white; color: var(--ink); border: 1px solid var(--line); }
.secondary-button:hover { border-color: #aebbc6; }
.ghost-button { background: transparent; color: var(--ink); border: 1px solid var(--line); }
.full { width: 100%; }
.text-button { border: 0; background: transparent; color: #0a8793; font-weight: 800; padding: 4px; }

.readiness-card { background: var(--surface); padding: 25px; box-shadow: var(--shadow); border-top: 3px solid var(--green); border-radius: 16px; }
.card-head { display: flex; justify-content: space-between; color: var(--muted); }
.card-head strong { color: var(--ink); font-size: 24px; }
.radial { width: 122px; height: 122px; border-radius: 50%; margin: 24px auto; display: grid; place-items: center; background: conic-gradient(var(--green) 0 66%, #e8edf1 66% 100%); position: relative; }
.radial:after { content: ""; position: absolute; inset: 10px; background: white; border-radius: 50%; }
.radial div { position: relative; z-index: 1; text-align: center; }
.radial strong, .radial span { display: block; }
.radial strong { font-size: 30px; }
.radial span { font-size: 11px; color: var(--muted); }
.check-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 12px; font-size: 13px; }
.check-list li:before { content: "!"; display: inline-grid; place-items: center; width: 18px; height: 18px; border-radius: 50%; background: var(--amber-soft); color: #9b6b0d; margin-right: 8px; font-weight: 800; }
.check-list li.done:before { content: "✓"; background: var(--green-soft); color: #29754a; }

.industry-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; margin: 20px 0; }
.industry-card { background: white; border: 1px solid var(--line); padding: 18px; min-height: 178px; display: flex; flex-direction: column; justify-content: space-between; transition: .18s ease; box-shadow: 0 8px 26px rgba(28,46,66,.04); border-radius: 16px; }
.industry-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); border-color: #b8d7db; }
.industry-card.active { border-color: var(--cyan); box-shadow: inset 0 0 0 2px rgba(24,184,201,.22), var(--shadow); }
.industry-card span { color: #8a98a5; font-size: 11px; font-weight: 800; letter-spacing: .08em; }
.industry-card h3 { margin: 8px 0 6px; font-size: 19px; }
.industry-card p { color: var(--muted); margin: 0; font-size: 12px; line-height: 1.55; }
.industry-card button { align-self: flex-start; margin-top: 14px; border: 0; background: #eef7f8; color: #087f88; padding: 8px 10px; font-weight: 800; border-radius: 7px; }
.industry-icon { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 12px; font-size: 20px; margin-bottom: 15px; }
.industry-icon.green { background: var(--green-soft); color: #2e7550; }
.industry-icon.cyan { background: var(--cyan-soft); color: #087f88; }
.industry-icon.purple { background: var(--purple-soft); color: #6552d5; }
.industry-icon.amber { background: var(--amber-soft); color: #8d6616; }
.industry-icon.blue { background: #e7f0ff; color: #2e5b9a; }

.metric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; margin: 20px 0; }
.metric-grid article { background: white; padding: 20px 22px; border: 1px solid var(--line); border-radius: 14px; }
.metric-grid span, .metric-grid small, .metric-grid strong { display: block; }
.metric-grid span { color: var(--muted); font-size: 12px; }
.metric-grid strong { font-size: 29px; margin: 9px 0 4px; letter-spacing: -.04em; }
.metric-grid small { color: #8d9aa8; }
.content-grid { display: grid; gap: 20px; }
.content-grid.two-thirds { grid-template-columns: 1.55fr .85fr; }
.panel { background: white; border: 1px solid var(--line); box-shadow: 0 8px 26px rgba(28,46,66,.04); padding: 24px; border-radius: 16px; }
.panel-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 20px; margin-bottom: 22px; }
.panel-head h3 { margin: 6px 0 0; font-size: 20px; }
.fact-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.fact-grid div { padding: 16px; background: white; }
.fact-grid span, .fact-grid strong { display: block; }
.fact-grid span { color: var(--muted); font-size: 11px; margin-bottom: 7px; }
.fact-grid strong { font-size: 13px; }
.source-note { margin-top: 18px; padding: 16px; background: #f7f9fb; border-left: 3px solid var(--cyan); border-radius: 10px; }
.source-note p { color: var(--muted); line-height: 1.6; font-size: 12px; margin: 7px 0; }
.source-note a { color: #087f88; text-decoration: none; font-size: 12px; font-weight: 800; }
.step-list { list-style: none; padding: 0; margin: 0; display: grid; gap: 14px; }
.step-list li { display: flex; align-items: center; gap: 13px; }
.step-list > li > span { flex: 0 0 30px; height: 30px; border: 1px solid var(--line); display: grid; place-items: center; color: var(--cyan); font-weight: 900; border-radius: 8px; }
.step-list strong, .step-list small { display: block; }
.step-list small { margin-top: 3px; color: var(--muted); }

.selector-layout { display: grid; grid-template-columns: 380px minmax(0,1fr); gap: 22px; align-items: start; }
.form-panel { position: sticky; top: 18px; }
.drop-zone { border: 1.5px dashed #a9bac7; background: #f8fbfd; padding: 18px; display: grid; place-items: center; text-align: center; border-radius: 16px; margin-bottom: 18px; transition: .18s ease; }
.drop-zone.dragging, .drop-zone.busy { border-color: var(--cyan); background: var(--cyan-soft); }
.drop-icon { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: white; color: var(--cyan); font-size: 24px; border: 1px solid var(--line); margin-bottom: 9px; }
.drop-zone strong { display: block; font-size: 15px; }
.drop-zone p { margin: 7px 0 13px; color: var(--muted); line-height: 1.55; font-size: 12px; }
.recognized-panel { margin-bottom: 20px; }
.mini-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 10px; }
.recognized-dimension-summary { padding: 12px 13px; margin-bottom: 10px; border: 1px solid #b7dfc8; background: var(--green-soft); border-radius: 12px; }
.recognized-dimension-summary span, .recognized-dimension-summary strong, .recognized-dimension-summary small { display: block; }
.recognized-dimension-summary span { color: #537061; font-size: 10px; font-weight: 900; letter-spacing: .08em; }
.recognized-dimension-summary strong { margin-top: 4px; font-size: 14px; }
.recognized-dimension-summary small { margin-top: 5px; color: #61786a; font-size: 11px; line-height: 1.45; }
.recognized-fields { max-height: 210px; overflow: auto; display: grid; grid-template-columns: 1fr 1fr; gap: 8px; padding-right: 4px; }
.recognized-fields div { border: 1px solid var(--line); padding: 9px; border-radius: 9px; background: #fafcfd; }
.recognized-fields div.ok { border-color: #b7dfc8; background: var(--green-soft); }
.recognized-fields div.pending { opacity: .72; }
.recognized-fields span, .recognized-fields strong { display: block; }
.recognized-fields span { color: #758393; font-size: 10px; }
.recognized-fields strong { margin-top: 4px; font-size: 12px; word-break: break-word; }
.preset-block > label { font-size: 12px; font-weight: 800; }
.preset-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 8px; margin: 10px 0 20px; }
.preset { border: 1px solid var(--line); background: #f8fafb; color: var(--muted); padding: 9px; font-size: 12px; border-radius: 8px; }
.preset.active { border-color: var(--cyan); color: #087f88; background: var(--cyan-soft); font-weight: 800; }
.field-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 13px; }
.field-grid label, .sales-form label { display: grid; gap: 6px; color: #607080; font-size: 11px; font-weight: 800; }
input, select { width: 100%; background: white; border: 1px solid #ccd7df; border-radius: 8px; padding: 10px; color: var(--ink); outline: none; }
input:focus, select:focus { border-color: var(--cyan); box-shadow: 0 0 0 3px rgba(23,185,199,.12); }
.form-panel .primary-button { margin-top: 18px; }
.form-hint { color: #8896a4; font-size: 11px; line-height: 1.55; margin: 12px 0 0; }

.results-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 14px; }
.results-head h2 { margin: 6px 0 0; }
.result-summary { display: flex; align-items: baseline; gap: 5px; }
.result-summary strong { font-size: 28px; }
.result-summary span { color: var(--muted); font-size: 12px; }
.risk-strip { display: flex; gap: 8px; flex-wrap: wrap; padding: 14px; margin-bottom: 14px; background: var(--amber-soft); border: 1px solid #f0d492; border-radius: 14px; }
.risk-strip span { font-size: 11px; color: #7a5712; padding: 3px 6px; background: rgba(255,255,255,.58); border-radius: 6px; }
.result-list { display: grid; gap: 12px; }
.result-card { background: white; border: 1px solid var(--line); display: grid; grid-template-columns: 1fr auto; gap: 18px; padding: 20px; transition: .18s ease; border-radius: 16px; }
.result-card:hover { border-color: #a9cdd1; box-shadow: var(--shadow); transform: translateY(-1px); }
.result-card h3 { margin: 8px 0 4px; font-size: 19px; }
.result-card p { margin: 0; color: var(--muted); font-size: 12px; }
.model-meta { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.source-chip { color: #2e7550; background: var(--green-soft); padding: 4px 7px; font-size: 10px; font-weight: 900; border-radius: 6px; }
.source-chip.eto { color: #6552d5; background: var(--purple-soft); }
.role-chip { color: #173247; background: #dcecf8; padding: 4px 7px; font-size: 10px; font-weight: 900; border-radius: 6px; }
.score-chip { color: #087f88; background: var(--cyan-soft); padding: 4px 7px; font-size: 10px; font-weight: 900; border-radius: 6px; }
.relaxed-chip { color: #78550e; background: var(--amber-soft); padding: 4px 7px; font-size: 10px; font-weight: 900; border-radius: 6px; }
.dimension-row { display: flex; gap: 24px; margin-top: 15px; flex-wrap: wrap; }
.dimension-row div { min-width: 74px; }
.dimension-row span, .dimension-row strong { display: block; }
.dimension-row span { color: #8a97a4; font-size: 10px; }
.dimension-row strong { margin-top: 3px; font-size: 14px; }
.result-side { min-width: 180px; display: flex; flex-direction: column; align-items: flex-end; justify-content: space-between; gap: 14px; }
.result-side small { color: var(--muted); text-align: right; }
.result-buttons { display: grid; gap: 8px; justify-items: end; }
.add-bom, .link-button { border: 1px solid var(--cyan); background: transparent; color: #087f88; padding: 9px 12px; font-weight: 800; border-radius: 8px; }
.link-button { border-color: #c8d5dd; color: #475f73; }
.add-bom:hover, .link-button:hover { background: var(--cyan-soft); }

.page-intro { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 20px; }
.page-intro h2 { margin: 7px 0 4px; font-size: 26px; }
.page-intro p { color: var(--muted); margin: 0; }
.bom-grid { display: grid; grid-template-columns: minmax(0,1fr) 360px; gap: 20px; align-items: start; }
.bom-table-panel { padding: 0; overflow: hidden; }
.table-wrap { overflow: auto; }
table { width: 100%; border-collapse: collapse; font-size: 12px; }
th { color: #718090; text-align: left; background: #f6f8fa; padding: 14px 13px; border-bottom: 1px solid var(--line); white-space: nowrap; }
td { padding: 15px 13px; border-bottom: 1px solid var(--line); vertical-align: top; }
td small { color: #7a8998; }
.remove-row { border: 0; background: var(--red-soft); color: #a44447; width: 27px; height: 27px; border-radius: 50%; }
.empty-state { text-align: center; padding: 70px 20px; color: var(--muted); }
.empty-state div { margin: auto; width: 42px; height: 42px; border: 1px solid var(--line); display: grid; place-items: center; color: var(--cyan); font-size: 22px; border-radius: 12px; }
.empty-state strong { display: block; margin-top: 13px; color: var(--ink); }
.empty-state p { margin: 5px 0; font-size: 12px; }
.assembly-panel { position: sticky; top: 18px; }
.assembly-panel h3 { margin: 6px 0 8px; }
.assembly-panel > p { margin: 0 0 14px; color: var(--muted); line-height: 1.55; font-size: 12px; }
#assembly-canvas { width: 100%; height: 300px; border: 1px solid var(--line); border-radius: 14px; display: block; touch-action: none; cursor: grab; }
#assembly-canvas:active { cursor: grabbing; }
.assembly-legend { display: grid; gap: 7px; margin: 12px 0 16px; }
.assembly-legend span { display: flex; align-items: center; gap: 7px; color: #526273; font-size: 12px; }
.assembly-legend i { width: 9px; height: 9px; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 4px rgba(105,208,146,.16); }
.summary-number { margin: 18px 0; padding: 18px; background: var(--navy); color: white; border-radius: 14px; }
.summary-number strong, .summary-number span { display: block; }
.summary-number strong { font-size: 35px; }
.summary-number span { color: #8fa5b8; font-size: 11px; }
.summary-lines { display: grid; gap: 12px; }
.summary-lines div { display: flex; justify-content: space-between; padding-bottom: 10px; border-bottom: 1px solid var(--line); }
.summary-lines span { color: var(--muted); font-size: 12px; }

.sales-layout { display: grid; grid-template-columns: 300px 1fr; gap: 20px; align-items: start; }
.sales-form { display: grid; gap: 15px; position: sticky; top: 18px; }
.sales-output { display: grid; gap: 18px; }
.sales-hero { min-height: 250px; background: var(--navy); color: white; padding: 34px; position: relative; overflow: hidden; }
.sales-hero:after { content: "GO TO MARKET"; position: absolute; right: -12px; bottom: -17px; color: rgba(255,255,255,.035); font-size: 62px; font-weight: 900; }
.sales-hero h2 { max-width: 56%; font-size: 29px; margin: 20px 0 10px; }
.sales-hero > p { color: #9fb1c1; max-width: 58%; line-height: 1.7; }
.revenue-card { position: absolute; right: 34px; top: 34px; text-align: right; }
.revenue-card span, .revenue-card strong, .revenue-card small { display: block; }
.revenue-card span, .revenue-card small { color: #7e95aa; font-size: 10px; }
.revenue-card strong { color: var(--green); font-size: 24px; margin: 5px 0; }
.sales-cards { display: grid; grid-template-columns: repeat(2,1fr); gap: 18px; }
.sales-cards h3 { margin: 7px 0 15px; }
.bullet-list { margin: 0; padding: 0; list-style: none; display: grid; gap: 10px; }
.bullet-list li { color: #526273; font-size: 13px; line-height: 1.5; padding-left: 18px; position: relative; }
.bullet-list li:before { content: ""; position: absolute; left: 0; top: 7px; width: 6px; height: 6px; background: var(--cyan); border-radius: 50%; }
.lock-panel { text-align: center; padding: 70px 30px; }
.lock-panel div { font-size: 38px; }
.lock-panel h3 { margin: 16px 0 8px; }
.lock-panel p { color: var(--muted); max-width: 560px; margin: 0 auto 22px; line-height: 1.7; }

.modal { position: fixed; inset: 0; z-index: 50; display: none; }
.modal.show { display: block; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(12,23,38,.56); }
.modal-card { position: relative; z-index: 1; width: min(1050px, calc(100vw - 70px)); max-height: calc(100vh - 70px); overflow: auto; margin: 35px auto; background: white; padding: 28px; border-radius: 18px; box-shadow: 0 28px 80px rgba(0,0,0,.22); }
.modal-close { position: absolute; right: 18px; top: 16px; border: 0; background: #f1f5f7; color: #607080; width: 34px; height: 34px; border-radius: 50%; font-size: 22px; }
.detail-head { display: flex; justify-content: space-between; gap: 20px; align-items: flex-start; margin-bottom: 20px; padding-right: 44px; }
.detail-head h2 { margin: 8px 0 4px; font-size: 26px; }
.detail-head p { margin: 0; color: var(--muted); }
.detail-grid { display: grid; grid-template-columns: 1.15fr .85fr; gap: 18px; margin-bottom: 18px; }
.bearing-drawing { background: #fbfdfe; border: 1px solid var(--line); border-radius: 14px; padding: 12px; }
.bearing-drawing svg { width: 100%; height: auto; display: block; }
.spec-sheet { border: 1px solid var(--line); border-radius: 14px; padding: 18px; }
.spec-sheet h3 { margin: 0 0 14px; }
.spec-lines { display: grid; gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.spec-lines div { display: grid; grid-template-columns: 1.3fr .7fr; gap: 10px; padding: 11px; background: white; align-items: center; }
.spec-lines span { color: #617181; font-size: 12px; }
.spec-lines strong { text-align: right; font-size: 12px; }
.compare-table { margin-top: 12px; border: 1px solid var(--line); border-radius: 12px; overflow: hidden; }
.compare-table th, .compare-table td { font-size: 12px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 18px; }

.toast { position: fixed; right: 28px; bottom: 28px; background: var(--navy); color: white; padding: 13px 17px; box-shadow: var(--shadow); transform: translateY(30px); opacity: 0; pointer-events: none; transition: .2s ease; z-index: 80; border-radius: 10px; }
.toast.show { opacity: 1; transform: none; }

@media (max-width: 1360px) {
  .main { padding-left: 24px; padding-right: 24px; }
  .hero-card { grid-template-columns: 1fr .62fr; }
  .hero-copy h2 { font-size: 28px; }
  .fact-grid { grid-template-columns: repeat(2,1fr); }
  .industry-grid { grid-template-columns: repeat(3, 1fr); }
}
