@font-face {
  font-family: "Alimama ShuHeiTi";
  src: url("./assets/fonts/AlimamaShuHeiTi-Bold.otf") format("opentype"),
       url("./assets/fonts/AlimamaShuHeiTi-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

:root {
  --paper: #fbf8ef;
  --ink: #050504;
  --orange: #ff4b0b;
  --lime: #aaff00;
  --blue: #0755ff;
  --cyan: #06dce8;
  --stroke: 12px;
  --shadow: 22px 22px 0 var(--ink);
  --display: "Alimama ShuHeiTi", Impact, Haettenschweiler, "Arial Black", sans-serif;
  --cn-display: "Alimama ShuHeiTi", "PingFang SC", "Source Han Sans SC", "Microsoft YaHei", sans-serif;
  --body: "Alimama ShuHeiTi", "PingFang SC", "Source Han Sans SC", "Microsoft YaHei", sans-serif;
  --fit: 1;
}

* { box-sizing: border-box; }
html, body { margin: 0; min-height: 100%; background: var(--paper); color: var(--ink); }
body { font-family: var(--body); overflow: hidden; }
a { color: inherit; text-decoration: none; }

.viewport {
  position: relative;
  width: 100vw;
  height: 100vh;
  overflow: hidden;
  background: var(--paper);
}
.poster {
  position: absolute;
  left: 50%;
  top: 50%;
  width: 2048px;
  height: 1152px;
  overflow: hidden;
  background: radial-gradient(circle at 50% 48%, #fffdf7 0, var(--paper) 72%);
  transform: translate(-50%, -50%) scale(var(--fit));
  transform-origin: center center;
}

.topbar {
  position: absolute;
  z-index: 20;
  left: 72px;
  right: 72px;
  top: 44px;
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
}
.logo {
  font-family: var(--display);
  font-size: 116px;
  line-height: .78;
  letter-spacing: -.064em;
  transform: scaleX(1.16);
  transform-origin: left top;
}
.lang {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-top: 18px;
  font-family: var(--cn-display);
  font-weight: 700;
  font-size: 38px;
}

.headline {
  position: absolute;
  z-index: 8;
  left: 100px;
  top: 338px;
  width: 850px;
}
.tagline { display: none; }
h1 {
  margin: 0;
  font-family: var(--cn-display);
  font-weight: 700;
}
.title-top,
.title-bottom {
  display: block;
  white-space: nowrap;
}
.title-top {
  font-size: 172px;
  line-height: .94;
  letter-spacing: -.04em;
  transform: scaleX(1.04);
  transform-origin: left center;
}
.title-bottom {
  display: flex;
  align-items: flex-start;
  gap: 32px;
  margin-top: 16px;
  line-height: .82;
}
.title-bottom i,
.title-bottom b,
.title-bottom em {
  display: block;
  font: inherit;
  font-style: normal;
  line-height: .82;
  letter-spacing: -.078em;
  transform-origin: left center;
}
.title-bottom i {
  color: var(--orange);
  font-size: 172px;
  font-weight: 700;
  letter-spacing: -.055em;
  transform: skew(-8deg) scaleX(.62);
}
.title-bottom b {
  font-size: 172px;
  font-weight: 700;
  transform: scaleX(.94);
}
.title-bottom em {
  font-size: 172px;
  font-weight: 700;
  margin-left: 0;
  transform: scaleX(.98);
}
.primary-route {
  position: absolute;
  left: 0;
  top: 500px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 626px;
  height: 150px;
  padding: 0 72px 0 92px;
  border: var(--stroke) solid var(--ink);
  background: var(--orange);
  box-shadow: var(--shadow);
  clip-path: polygon(0 0, calc(100% - 54px) 0, 100% 50%, calc(100% - 54px) 100%, 0 100%);
  font-family: var(--cn-display);
  font-weight: 700;
  font-size: 52px;
  letter-spacing: -.05em;
}
.primary-route b { font-size: 1.15em; }

.map { position: absolute; inset: 0; z-index: 4; }
.node {
  position: absolute;
  z-index: 9;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 14px;
  border: var(--stroke) solid var(--ink);
  box-shadow: var(--shadow);
  clip-path: polygon(13% 0, 87% 0, 100% 16%, 100% 80%, 86% 100%, 12% 100%, 0 84%, 0 18%);
  font-family: var(--cn-display);
  text-align: center;
}
.node strong { font-size: 30px; line-height: 1.05; font-weight: 700; letter-spacing: -.012em; }
.node small { max-width: 82%; font-family: var(--body); font-size: 17px; line-height: 1.22; font-weight: 700; letter-spacing: 0; }
.node:hover, .node:focus-visible, .primary-route:hover, .primary-route:focus-visible { outline: none; transform: translate(-3px, -3px); }

.node-setup { left: 1178px; top: 92px; width: 420px; height: 270px; background: var(--orange); }
.node-tax { left: 936px; top: 454px; width: 330px; height: 330px; background: var(--lime); }
.node-permit { left: 1616px; top: 344px; width: 378px; height: 300px; background: var(--blue); }
.node-hiring { left: 1214px; top: 720px; width: 310px; height: 310px; background: var(--cyan); }
.node-ai { left: 1628px; top: 734px; width: 340px; height: 286px; background: #fffdf7; }

.icon { position: relative; display: block; width: 112px; height: 86px; }
.icon-building::before { content: ""; position: absolute; left: 18px; right: 18px; bottom: 4px; height: 18px; background: var(--ink); }
.icon-building::after { content: ""; position: absolute; left: 24px; top: 8px; width: 66px; height: 78px; background: var(--ink); clip-path: polygon(50% 0,100% 34%,86% 42%,86% 76%,100% 76%,100% 100%,0 100%,0 76%,14% 76%,14% 42%,0 34%); }
.icon-grid { width: 98px; height: 126px; border: 12px solid var(--ink); border-radius: 6px; background: repeating-linear-gradient(90deg, transparent 0 22px, var(--ink) 22px 32px), repeating-linear-gradient(0deg, transparent 0 22px, var(--ink) 22px 32px); }
.icon-shield::before { content: ""; position: absolute; inset: 0 12px; background: var(--ink); clip-path: polygon(50% 0,100% 24%,92% 76%,50% 100%,8% 76%,0 24%); }
.icon-shield::after { content: ""; position: absolute; left: 36px; top: 32px; width: 56px; height: 28px; border-left: 13px solid var(--blue); border-bottom: 13px solid var(--blue); transform: rotate(-45deg); }
.icon-people::before { content: ""; position: absolute; left: 4px; top: 0; width: 118px; height: 106px; background: var(--ink); clip-path: polygon(18% 0,38% 0,50% 23%,64% 2%,82% 2%,96% 24%,84% 46%,100% 76%,100% 100%,48% 100%,48% 78%,38% 56%,26% 78%,26% 100%,0 100%,0 76%,12% 48%,2% 24%); }
.icon-chip { display: grid; place-items: center; width: 96px; height: 96px; background: var(--ink); color: #fffdf7; font-family: var(--display); font-size: 54px; line-height: 1; }
.icon-chip::before, .icon-chip::after { content: ""; position: absolute; inset: -16px; z-index: -1; background: repeating-linear-gradient(90deg, transparent 0 11px, var(--ink) 11px 19px, transparent 19px 28px); }
.icon-chip::after { transform: rotate(90deg); }

.wire { position: absolute; z-index: 3; border-color: var(--ink); border-style: solid; pointer-events: none; }
.wire::after { content: ""; position: absolute; width: 0; height: 0; border-top: 34px solid transparent; border-bottom: 34px solid transparent; border-left: 54px solid var(--ink); }
.wire-a { left: 1000px; top: 246px; width: 188px; height: 160px; border-width: var(--stroke) 0 0 var(--stroke); border-radius: 28px 0 0 0; }
.wire-a::after { right: -28px; top: -39px; }
.wire-b { left: 1594px; top: 174px; width: 248px; height: 146px; border-width: var(--stroke) var(--stroke) 0 0; }
.wire-b::after { right: -44px; top: 112px; transform: rotate(90deg); }
.wire-c { left: 1448px; top: 360px; width: 228px; height: 98px; border-width: 0 0 var(--stroke) var(--stroke); border-radius: 0 0 0 28px; }
.wire-c::after { right: -44px; bottom: -39px; }
.wire-d { left: 1264px; top: 604px; width: 354px; height: 82px; border-width: var(--stroke) 0 var(--stroke) 0; }
.wire-d::after { right: -44px; bottom: -39px; }
.wire-e { left: 1048px; top: 780px; width: 180px; height: 128px; border-width: 0 0 var(--stroke) var(--stroke); border-radius: 0 0 0 28px; }
.wire-e::after { display: none; }
.wire-f { left: 1520px; top: 846px; width: 162px; border-width: var(--stroke) 0 0; }
.wire-f::after { left: -50px; top: -39px; transform: rotate(180deg); }
.dash { position: absolute; z-index: 3; width: 14px; height: 86px; background: repeating-linear-gradient(0deg, var(--ink) 0 20px, transparent 20px 34px); }
.dash-a { left: 1000px; top: 370px; }
.dash-b { left: 1754px; top: 644px; }

.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0 0 0 0); white-space: nowrap; }
