@import url("https://cdn.jsdelivr.net/npm/@chinese-fonts/cubic@3.0.0/dist/Cubic/result.css");
@import url("https://cdn.jsdelivr.net/npm/@chinese-fonts/qxs@3.0.0/dist/quan/result.css");

:root {
  --pixel-paper: #f6f4e8;
  --pixel-paper-deep: #edebd6;
  --pixel-cream: #faf8ee;
  --pixel-desk: #c8c5a8;
  --pixel-desk-deep: #b0ad90;
  --pixel-ink: #2a2d1e;
  --pixel-ink-soft: #4a4d3a;
  --pixel-muted: #6b6e56;
  --pixel-faint: #c0c3a8;
  --pixel-line: #9a9d82;
  --pixel-line-soft: rgba(106, 112, 80, 0.24);
  --pixel-line-strong: #6b6e56;
  --pixel-sage: #6a7e52;
  --pixel-sage-2: #84996c;
  --pixel-sage-dark: #4a5c38;
  --pixel-sage-pale: rgba(106, 126, 82, 0.1);
  --pixel-shadow: 0 24px 52px rgba(42, 45, 30, 0.22);
  --pixel-sans: "Cubic 11", "Noto Sans SC", "Microsoft YaHei", sans-serif;
  --pixel-mono: "QuanPixel 8px", "Cubic 11", "Noto Sans SC", monospace;
  --pixel-display: "Jersey 20", "QuanPixel 8px", "Cubic 11", sans-serif;
  --pixel-standard-width: 46rem;
  --pixel-standard-height: 19.8rem;
  --pixel-train-width: 54rem;
  --pixel-train-height: 22.2rem;
  --pixel-ship-width: 39rem;
  --pixel-ship-height: 29.4rem;
  --pixel-flight-width: 58rem;
  --pixel-flight-height: 23.2rem;
  --pixel-bus-width: 40rem;
  --pixel-bus-height: 29.4rem;
  --pixel-plan-width: 30rem;
  --pixel-packing-width: 30rem;
}

.pixel-suite-shell [lang="en"],
.pixel-suite-shell [lang="zh-CN"],
.pixel-render-host [data-export-artifact],
.pixel-render-host [lang="en"],
.pixel-render-host [lang="zh-CN"] {
  font-family: var(--pixel-sans);
}

.pixel-suite-shell {
  position: relative;
  padding: clamp(1rem, 2vw, 1.4rem);
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.06);
  background:
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.05) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.04) 0 1px, transparent 1px 16px),
    linear-gradient(180deg, var(--pixel-desk), var(--pixel-desk-deep));
  box-shadow: 0 30px 60px rgba(8, 10, 14, 0.24);
  overflow: hidden;
}

.pixel-suite-shell::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.018) 0 1px, transparent 1px 28px),
    repeating-linear-gradient(180deg, rgba(255, 255, 255, 0.016) 0 1px, transparent 1px 24px);
  opacity: 0.18;
  pointer-events: none;
}

.pixel-suite-grid {
  position: relative;
  z-index: 1;
  display: grid;
  justify-content: center;
  gap: 1.25rem;
}

.pixel-preview-panel {
  width: 100%;
  min-width: 0;
  padding: 1rem;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background:
    linear-gradient(180deg, rgba(255, 255, 255, 0.045), rgba(255, 255, 255, 0)),
    linear-gradient(180deg, rgba(52, 50, 39, 0.96), rgba(28, 27, 21, 0.96));
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.04);
}

.pixel-standard-preview {
  justify-self: center;
  max-width: calc(var(--pixel-standard-width) + 2rem);
}

.pixel-train-preview {
  justify-self: center;
  max-width: calc(var(--pixel-train-width) + 2rem);
}

.pixel-ship-preview {
  justify-self: center;
  max-width: calc(var(--pixel-ship-width) + 2rem);
}

.pixel-flight-preview {
  justify-self: center;
  max-width: calc(var(--pixel-flight-width) + 2rem);
}

.pixel-bus-preview {
  justify-self: center;
  max-width: calc(var(--pixel-bus-width) + 2rem);
}

.pixel-plan-preview,
.pixel-packing-preview {
  justify-self: center;
  max-width: calc(var(--pixel-plan-width) + 2rem);
}

.pixel-preview-topline {
  display: flex;
  align-items: center;
  gap: 0.42rem;
  font-family: var(--pixel-mono);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(250, 248, 238, 0.8);
}

.pixel-preview-topline span[aria-hidden] {
  color: rgba(132, 153, 108, 0.82);
}

.pixel-render-host {
  margin-top: 0.9rem;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  width: 100%;
  min-width: 0;
  overflow: hidden;
}

.pixel-preview-frame {
  width: max-content;
  max-width: none;
  flex: 0 0 auto;
}

.pixel-render-host.is-scaled {
  overflow: hidden;
}

.pixel-render-host.is-scaled > .pixel-preview-frame > [data-export-artifact] {
  transform-origin: top left;
}

.pixel-render-host.is-scrollable {
  justify-content: flex-start;
  overflow-x: auto;
  overflow-y: hidden;
  padding-bottom: 0.35rem;
  overscroll-behavior-x: contain;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: rgba(106, 126, 82, 0.84) rgba(255, 255, 255, 0.06);
}

.pixel-render-host.is-scrollable::-webkit-scrollbar {
  height: 10px;
}

.pixel-render-host.is-scrollable::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.04);
}

.pixel-render-host.is-scrollable::-webkit-scrollbar-thumb {
  background: linear-gradient(90deg, rgba(106, 126, 82, 0.9), rgba(74, 92, 56, 0.92));
}

.pixel-locale-stack,
.pixel-locale-inline {
  min-width: 0;
}

.pixel-locale-stack {
  display: grid;
  gap: 0.08rem;
}

.pixel-locale-stack [lang="en"],
.pixel-locale-stack [lang="zh-CN"] {
  display: block;
}

.pixel-locale-stack .voyager-field-main,
.pixel-locale-stack .voyager-field-secondary {
  display: block;
}

.pixel-locale-inline {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.24rem;
  align-items: baseline;
}

.pixel-standard-ticket {
  width: var(--pixel-standard-width);
  min-width: var(--pixel-standard-width);
  height: var(--pixel-standard-height);
  padding: 0.82rem;
  background:
    repeating-linear-gradient(90deg, rgba(255, 255, 255, 0.03) 0 1px, transparent 1px 18px),
    repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.025) 0 1px, transparent 1px 18px),
    linear-gradient(180deg, #b9b594, #a7a182);
  box-shadow: var(--pixel-shadow);
  overflow: hidden;
}

.pixel-standard-paper {
  position: relative;
  display: grid;
  grid-template-rows: 2.52rem minmax(0, 1fr) 1.94rem;
  height: 100%;
  background: linear-gradient(180deg, #f7f5ea, #f1efde);
  overflow: hidden;
}

.pixel-standard-paper::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(0deg, rgba(164, 179, 119, 0.1) 0 1px, transparent 1px 18px),
    repeating-linear-gradient(90deg, rgba(169, 185, 124, 0.06) 0 1px, transparent 1px 18px),
    linear-gradient(180deg, rgba(195, 212, 153, 0.18), transparent 22%, transparent 78%, rgba(195, 212, 153, 0.12));
  opacity: 0.8;
  pointer-events: none;
}

.pixel-standard-paper::after {
  content: "";
  position: absolute;
  inset: 0.62rem;
  border: 2px solid rgba(176, 57, 37, 0.18);
  pointer-events: none;
}

.pixel-standard-paper > * {
  position: relative;
  z-index: 1;
}

.pixel-standard-topbar,
.pixel-standard-footer {
  display: grid;
  align-items: center;
  padding-inline: 0.86rem;
  background: linear-gradient(180deg, #e64d33, #cf3d24);
  color: #fbf8ee;
}

.pixel-standard-topbar {
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.82rem;
}

.pixel-standard-title-stack {
  gap: 0.04rem;
}

.pixel-standard-title-stack [lang="en"] {
  font-family: var(--pixel-display);
  font-size: 1.72rem;
  line-height: 0.88;
  letter-spacing: 0.08em;
  color: #fff6ec;
}

.pixel-standard-title-stack [lang="zh-CN"] {
  font-size: 0.56rem;
  line-height: 1.12;
  color: rgba(255, 246, 236, 0.9);
}

.pixel-standard-topbar-meta {
  display: grid;
  gap: 0.12rem;
  justify-items: end;
  text-align: right;
}

.pixel-standard-topbar-meta > div {
  display: grid;
  gap: 0.04rem;
}

.pixel-standard-topbar-label {
  font-family: var(--pixel-mono);
  font-size: 0.4rem;
  line-height: 1.14;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: rgba(255, 246, 236, 0.86);
}

.pixel-standard-topbar-meta strong {
  font-family: var(--pixel-mono);
  font-size: 0.58rem;
  line-height: 1.1;
  color: #fff9f1;
}

.pixel-standard-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 10rem;
  min-height: 0;
}

.pixel-standard-main,
.pixel-standard-stub {
  min-height: 0;
}

.pixel-standard-main {
  display: grid;
  grid-template-rows: auto auto 1fr;
  padding: 0.7rem 0.84rem 0.58rem;
}

.pixel-standard-stub {
  display: grid;
  grid-template-rows: auto auto 1fr auto auto;
  gap: 0.16rem;
  padding: 0.6rem 0.64rem 0.46rem;
  border-left: 2px dashed rgba(179, 78, 51, 0.44);
  background: linear-gradient(180deg, rgba(255, 250, 239, 0.78), rgba(247, 244, 229, 0.72));
}

.pixel-standard-routeband,
.pixel-standard-product {
  border-bottom: 1px solid rgba(165, 177, 123, 0.46);
}

.pixel-standard-routeband {
  display: grid;
  gap: 0.24rem;
  padding-bottom: 0.4rem;
}

.pixel-standard-caption,
.pixel-standard-label {
  font-family: var(--pixel-mono);
  font-size: 0.42rem;
  line-height: 1.18;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #7d7d62;
}

.pixel-standard-route-line {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr);
  gap: 0.34rem;
  align-items: center;
}

.pixel-standard-station {
  font-family: var(--pixel-display);
  font-size: 1.3rem;
  line-height: 0.92;
  letter-spacing: 0.04em;
  color: #27301d;
  text-transform: uppercase;
  text-wrap: balance;
}

.pixel-standard-station.is-destination {
  text-align: right;
}

.pixel-standard-arrow {
  font-family: var(--pixel-mono);
  font-size: 0.84rem;
  line-height: 1;
  color: #5d7b3f;
}

.pixel-standard-route-zh {
  font-family: var(--pixel-mono);
  font-size: 0.5rem;
  line-height: 1.2;
  color: #7a7d5e;
}

.pixel-standard-product {
  padding: 0.34rem 0 0.38rem;
}

.pixel-standard-product-line {
  display: flex;
  flex-wrap: wrap;
  gap: 0.34rem 0.66rem;
  align-items: center;
}

.pixel-standard-product-line strong,
.pixel-standard-product-line span {
  font-family: var(--pixel-mono);
  font-size: 0.56rem;
  line-height: 1.18;
}

.pixel-standard-product-line strong {
  color: #2d341f;
}

.pixel-standard-product-line span {
  color: #71745a;
}

.pixel-standard-grid {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 0;
  align-content: start;
  padding-top: 0.24rem;
}

.pixel-standard-cell {
  display: grid;
  gap: 0.1rem;
  min-height: 2.56rem;
  padding: 0.24rem 0.28rem 0.22rem 0;
}

.pixel-standard-cell strong,
.pixel-standard-stub-grid strong {
  font-family: var(--pixel-mono);
  font-size: 0.68rem;
  line-height: 1.16;
  color: #28301e;
}

.pixel-standard-cell.is-fare strong {
  font-size: 0.84rem;
  color: #344626;
}

.pixel-standard-cell.is-route-note {
  grid-column: 1 / -1;
  min-height: auto;
  padding-top: 0.1rem;
}

.pixel-standard-value-stack {
  gap: 0.1rem;
}

.pixel-standard-value-stack [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.66rem;
  line-height: 1.16;
  color: #28301e;
}

.pixel-standard-value-stack [lang="zh-CN"] {
  font-size: 0.48rem;
  line-height: 1.16;
  color: #73755d;
}

.pixel-standard-value-stack.is-compact [lang="en"] {
  font-size: 0.6rem;
}

.pixel-standard-value-stack.is-compact [lang="zh-CN"] {
  font-size: 0.46rem;
}

.pixel-standard-stub-title {
  font-family: var(--pixel-mono);
  font-size: 0.54rem;
  line-height: 1.18;
  color: #303920;
  text-transform: uppercase;
}

.pixel-standard-stub-route {
  padding-bottom: 0.22rem;
  border-bottom: 1px solid rgba(165, 177, 123, 0.42);
}

.pixel-standard-stub-route .pixel-standard-value-stack {
  gap: 0.06rem;
}

.pixel-standard-stub-route .pixel-standard-value-stack [lang="en"] {
  font-size: 0.56rem;
}

.pixel-standard-stub-route .pixel-standard-value-stack [lang="zh-CN"] {
  font-size: 0.42rem;
}

.pixel-standard-stub-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.16rem 0.28rem;
}

.pixel-standard-stub-grid > div:last-child {
  grid-column: 1 / -1;
}

.pixel-standard-barcode {
  height: 1.72rem;
  background:
    repeating-linear-gradient(
      90deg,
      #2d311f 0 3px,
      transparent 3px 6px,
      #2d311f 6px 10px,
      transparent 10px 13px
    );
}

.pixel-standard-barcode-text {
  font-family: var(--pixel-mono);
  font-size: 0.36rem;
  line-height: 1.1;
  color: #787a60;
}

.pixel-standard-footer {
  grid-template-columns: 1.2rem 1.4fr 1fr 1fr;
  gap: 0.56rem;
}

.pixel-standard-footer-mark {
  font-family: var(--pixel-display);
  font-size: 1.1rem;
  line-height: 1;
  color: #fff5e8;
}

.pixel-standard-footer-ledger,
.pixel-standard-footer-traveler,
.pixel-standard-footer-print {
  font-family: var(--pixel-mono);
  font-size: 0.4rem;
  line-height: 1.14;
  color: rgba(255, 246, 236, 0.92);
}

.pixel-train-ticket {
  width: var(--pixel-train-width);
  min-width: var(--pixel-train-width);
  height: var(--pixel-train-height);
  padding: 0.82rem;
  background:
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.05) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.04) 0 1px, transparent 1px 16px),
    linear-gradient(180deg, var(--pixel-desk), var(--pixel-desk-deep));
  box-shadow: var(--pixel-shadow);
  overflow: hidden;
}

.pixel-ticket-paper {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 12.8rem;
  height: 100%;
  background: var(--pixel-paper);
  overflow: hidden;
}

.pixel-ship-paper,
.pixel-flight-paper,
.pixel-bus-paper {
  position: relative;
  height: 100%;
  background: var(--pixel-paper);
  overflow: hidden;
}

.pixel-ship-paper::before,
.pixel-flight-paper::before,
.pixel-bus-paper::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.06) 0 1px, transparent 1px 12px),
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.06) 0 1px, transparent 1px 12px),
    radial-gradient(circle at 70% 18%, rgba(132, 153, 108, 0.08), transparent 16%);
  opacity: 0.72;
  pointer-events: none;
}

.pixel-ship-paper::after,
.pixel-flight-paper::after,
.pixel-bus-paper::after {
  content: "";
  position: absolute;
  inset: 0.56rem;
  border: 2px solid rgba(106, 112, 80, 0.18);
  pointer-events: none;
}

.pixel-ticket-paper::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.06) 0 1px, transparent 1px 12px),
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.06) 0 1px, transparent 1px 12px),
    radial-gradient(circle at 70% 18%, rgba(132, 153, 108, 0.08), transparent 16%);
  opacity: 0.72;
  pointer-events: none;
}

.pixel-ticket-paper::after {
  content: "";
  position: absolute;
  inset: 0.56rem;
  border: 2px solid rgba(106, 112, 80, 0.18);
  pointer-events: none;
}

.pixel-ticket-inner,
.pixel-ticket-stub {
  position: relative;
  z-index: 1;
}

.pixel-ticket-inner {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  min-height: 0;
  padding: 0.78rem 0.84rem 0.74rem;
}

.pixel-ticket-stub {
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  gap: 0.34rem;
  min-height: 0;
  padding: 0.76rem 0.68rem 0.72rem 0.62rem;
  border-left: 2px dashed rgba(107, 110, 86, 0.84);
  background: linear-gradient(180deg, rgba(250, 248, 238, 0.72), rgba(237, 235, 214, 0.68));
}

.pixel-ticket-header,
.pixel-ticket-routeband,
.pixel-ticket-summary {
  border-bottom: 1px solid rgba(106, 112, 80, 0.24);
}

.pixel-ticket-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 0.8rem;
  padding-bottom: 0.44rem;
}

.pixel-ticket-ledger {
  display: grid;
  gap: 0.18rem;
}

.pixel-ledger-mark,
.pixel-ticket-label {
  font-family: var(--pixel-mono);
  font-size: 0.5rem;
  line-height: 1.18;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pixel-muted);
}

.pixel-ledger-copy .pixel-locale-inline [lang="en"],
.pixel-ledger-copy .pixel-locale-inline [lang="zh-CN"] {
  font-size: 0.52rem;
  color: var(--pixel-ink-soft);
}

.pixel-ticket-serial {
  display: grid;
  gap: 0.14rem;
  justify-items: end;
}

.pixel-ticket-serial strong,
.pixel-stub-head strong {
  font-family: var(--pixel-mono);
  font-size: 1rem;
  line-height: 1;
  color: var(--pixel-sage-dark);
}

.pixel-ticket-routeband {
  display: grid;
  gap: 0.44rem;
  padding: 0.56rem 0 0.58rem;
}

.pixel-ticket-route-meta {
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  font-family: var(--pixel-mono);
  font-size: 0.56rem;
  line-height: 1.18;
  color: var(--pixel-muted);
}

.pixel-ticket-route-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 5.9rem minmax(0, 1fr);
  gap: 0.46rem;
  align-items: center;
}

.pixel-ticket-station {
  display: grid;
  gap: 0.18rem;
}

.pixel-ticket-station.is-destination {
  text-align: right;
}

.pixel-ticket-title {
  font-family: var(--pixel-sans);
  font-size: 1.72rem;
  line-height: 0.92;
  color: var(--pixel-ink);
}

.pixel-ticket-subtitle [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.54rem;
  line-height: 1.16;
  color: var(--pixel-ink-soft);
}

.pixel-ticket-subtitle [lang="zh-CN"] {
  font-size: 0.64rem;
  line-height: 1.18;
  color: var(--pixel-muted);
}

.pixel-ticket-route-axis {
  display: grid;
  justify-items: center;
  gap: 0.32rem;
}

.pixel-axis-track {
  position: relative;
  width: 100%;
  height: 2px;
  background:
    repeating-linear-gradient(90deg, var(--pixel-sage-2) 0 8px, transparent 8px 12px);
}

.pixel-axis-dot {
  width: 0.56rem;
  height: 0.56rem;
  background: var(--pixel-sage-dark);
  box-shadow: 0 0 0 2px var(--pixel-paper), 0 0 0 3px rgba(106, 112, 80, 0.28);
}

.pixel-ticket-summary {
  display: flex;
  justify-content: space-between;
  gap: 0.82rem;
  align-items: start;
  padding: 0.56rem 0 0.58rem;
}

.pixel-ticket-summary-copy {
  display: grid;
  gap: 0.18rem;
}

.pixel-ticket-summary-copy p,
.pixel-ticket-summary-meta {
  margin: 0;
}

.pixel-ticket-purpose [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.72rem;
  line-height: 1.16;
  color: var(--pixel-sage-dark);
}

.pixel-ticket-purpose [lang="zh-CN"] {
  font-size: 0.64rem;
  line-height: 1.16;
  color: var(--pixel-ink);
}

.pixel-ticket-copy [lang="en"] {
  font-size: 0.5rem;
  line-height: 1.3;
  color: var(--pixel-ink-soft);
}

.pixel-ticket-copy [lang="zh-CN"] {
  font-size: 0.58rem;
  line-height: 1.42;
  color: var(--pixel-muted);
}

.pixel-ticket-summary-meta {
  display: grid;
  justify-items: end;
  gap: 0.14rem;
  min-width: 8.4rem;
  font-family: var(--pixel-mono);
  font-size: 0.5rem;
  line-height: 1.22;
  color: var(--pixel-muted);
}

.pixel-ticket-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 0.42rem 0.66rem;
  align-content: start;
  min-height: 0;
  padding-top: 0.56rem;
}

.pixel-ticket-cell {
  display: grid;
  gap: 0.1rem;
  min-width: 0;
}

.pixel-ticket-value [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.74rem;
  line-height: 1.12;
  color: var(--pixel-ink);
}

.pixel-ticket-value [lang="zh-CN"] {
  font-size: 0.58rem;
  line-height: 1.18;
  color: var(--pixel-ink-soft);
}

.pixel-ticket-fare {
  font-family: var(--pixel-mono);
  font-size: 0.92rem;
  line-height: 1;
  color: var(--pixel-sage-dark);
}

.pixel-stub-head {
  display: grid;
  gap: 0.12rem;
}

.pixel-stub-route {
  display: grid;
  gap: 0.18rem;
  padding-top: 0.08rem;
}

.pixel-stub-codes {
  font-family: var(--pixel-mono);
  font-size: 0.68rem;
  line-height: 1.16;
  color: var(--pixel-sage-dark);
}

.pixel-stub-copy.is-stub [lang="en"] {
  font-size: 0.48rem;
}

.pixel-stub-copy.is-stub [lang="zh-CN"] {
  font-size: 0.54rem;
}

.pixel-stub-meta {
  display: grid;
  gap: 0.26rem;
  padding-top: 0.32rem;
  border-top: 1px solid rgba(106, 112, 80, 0.24);
}

.pixel-ticket-barcode {
  align-self: end;
  min-height: 1.78rem;
  background:
    repeating-linear-gradient(
      90deg,
      var(--pixel-ink) 0 2px,
      transparent 2px 5px,
      var(--pixel-ink) 5px 9px,
      transparent 9px 12px,
      var(--pixel-ink) 12px 14px,
      transparent 14px 18px
    );
  opacity: 0.82;
}

.pixel-ticket-barcode-text {
  display: block;
  font-family: var(--pixel-mono);
  font-size: 0.38rem;
  line-height: 1.12;
  letter-spacing: 0.08em;
  color: var(--pixel-muted);
}

.pixel-ship-ticket {
  width: var(--pixel-ship-width);
  min-width: var(--pixel-ship-width);
  height: var(--pixel-ship-height);
  padding: 0.82rem;
  background:
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.05) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.04) 0 1px, transparent 1px 16px),
    linear-gradient(180deg, var(--pixel-desk), var(--pixel-desk-deep));
  box-shadow: var(--pixel-shadow);
  overflow: hidden;
}

.pixel-ship-paper {
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  min-height: 0;
  padding: 0.84rem 0.92rem 0.84rem;
}

.pixel-ship-header,
.pixel-ship-routeband,
.pixel-ship-summary {
  position: relative;
  z-index: 1;
  border-bottom: 1px solid rgba(106, 112, 80, 0.24);
}

.pixel-ship-header {
  display: flex;
  justify-content: space-between;
  align-items: start;
  gap: 0.8rem;
  padding-bottom: 0.46rem;
}

.pixel-ship-routeband {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 5.4rem minmax(0, 1fr);
  gap: 0.56rem;
  align-items: center;
  padding: 0.58rem 0 0.6rem;
}

.pixel-ship-port {
  position: relative;
  z-index: 1;
  display: grid;
  gap: 0.16rem;
}

.pixel-ship-port.is-destination {
  text-align: right;
}

.pixel-ship-axis {
  position: relative;
  z-index: 1;
  display: grid;
  justify-items: center;
  gap: 0.28rem;
}

.pixel-ship-wave {
  font-family: var(--pixel-mono);
  font-size: 0.76rem;
  line-height: 1;
  color: var(--pixel-sage-dark);
}

.pixel-ship-summary {
  display: flex;
  justify-content: space-between;
  gap: 0.82rem;
  align-items: start;
  padding: 0.56rem 0 0.58rem;
}

.pixel-ship-grid {
  position: relative;
  z-index: 1;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.56rem 0.84rem;
  align-content: start;
  min-height: 0;
  padding: 0.72rem 0 0.74rem;
}

.pixel-ship-footer {
  position: relative;
  z-index: 1;
  display: flex;
  justify-content: space-between;
  gap: 0.8rem;
  align-items: end;
}

.pixel-ship-barcode-wrap {
  display: grid;
  gap: 0.16rem;
  width: min(11rem, 42%);
  justify-items: end;
}

.pixel-flight-ticket {
  width: var(--pixel-flight-width);
  min-width: var(--pixel-flight-width);
  height: var(--pixel-flight-height);
  padding: 0.82rem;
  background:
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.05) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.04) 0 1px, transparent 1px 16px),
    linear-gradient(180deg, var(--pixel-desk), var(--pixel-desk-deep));
  box-shadow: var(--pixel-shadow);
  overflow: hidden;
}

.pixel-flight-paper {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 11.2rem;
}

.pixel-flight-main,
.pixel-flight-stub {
  position: relative;
  z-index: 1;
}

.pixel-flight-main {
  display: grid;
  grid-template-rows: auto auto 1fr;
  min-height: 0;
  padding: 0.76rem 0.92rem 0.74rem;
}

.pixel-flight-header,
.pixel-flight-routeband {
  border-bottom: 1px solid rgba(106, 112, 80, 0.24);
}

.pixel-flight-header {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: start;
  gap: 0.8rem;
  padding-bottom: 0.5rem;
}

.pixel-flight-ledger-wrap {
  display: grid;
  gap: 0.18rem;
}

.pixel-flight-ledger {
  gap: 0.14rem;
}

.pixel-flight-ledger-top {
  display: inline-flex;
  align-items: baseline;
  flex-wrap: wrap;
  gap: 0.2rem;
}

.pixel-flight-corner-mark {
  font-size: 0.44rem;
  line-height: 1.1;
  letter-spacing: 0.05em;
}

.pixel-flight-header-side {
  display: grid;
  justify-items: end;
  gap: 0.26rem;
}

.pixel-flight-ledger-divider {
  font-family: var(--pixel-mono);
  font-size: 0.48rem;
  line-height: 1;
  color: var(--pixel-faint);
}

.pixel-flight-ledger-title .pixel-locale-inline {
  gap: 0.16rem;
}

.pixel-flight-ledger-title [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.68rem;
  line-height: 1.12;
  color: var(--pixel-sage-dark);
}

.pixel-flight-ledger-title [lang="zh-CN"] {
  font-size: 0.6rem;
  line-height: 1.12;
  color: var(--pixel-ink);
}

.pixel-flight-routeband {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 5.1rem minmax(0, 1fr);
  gap: 0.58rem;
  align-items: end;
  padding: 0.8rem 0 0.76rem;
}

.pixel-flight-port {
  display: grid;
  gap: 0.16rem;
}

.pixel-flight-port.is-destination {
  text-align: right;
}

.pixel-flight-code {
  font-family: var(--pixel-display);
  font-size: 2.18rem;
  line-height: 0.88;
  letter-spacing: 0.08em;
  color: var(--pixel-sage-dark);
}

.pixel-flight-port .pixel-ticket-subtitle [lang="en"] {
  font-size: 0.62rem;
  line-height: 1.12;
  color: var(--pixel-ink-soft);
}

.pixel-flight-port .pixel-ticket-subtitle [lang="zh-CN"] {
  font-size: 0.68rem;
  line-height: 1.16;
  color: var(--pixel-muted);
}

.pixel-flight-axis {
  display: grid;
  justify-items: center;
  gap: 0.28rem;
}

.pixel-flight-corner-ornament {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 0.22rem 0.28rem;
  max-width: 16rem;
}

.pixel-flight-corner-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.16rem;
  min-height: 1.06rem;
  padding: 0.12rem 0.28rem;
  border: 1px solid rgba(106, 112, 80, 0.18);
  background: rgba(132, 153, 108, 0.06);
}

.pixel-flight-corner-chip.is-district {
  background: rgba(255, 255, 255, 0.42);
}

.pixel-flight-corner-chip .pixel-locale-inline {
  gap: 0.14rem;
}

.pixel-flight-corner-chip [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.46rem;
  line-height: 1.14;
  color: var(--pixel-sage-dark);
}

.pixel-flight-corner-chip [lang="zh-CN"] {
  font-size: 0.5rem;
  line-height: 1.16;
  color: var(--pixel-ink-soft);
}

.pixel-flight-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr) minmax(0, 0.9fr);
  gap: 0.46rem 0.66rem;
  align-content: start;
  min-height: 0;
  padding-top: 0.62rem;
}

.pixel-flight-grid .pixel-ticket-cell {
  gap: 0.12rem;
  padding-top: 0.34rem;
  border-top: 1px solid rgba(106, 112, 80, 0.18);
}

.pixel-flight-grid .pixel-ticket-cell.is-service strong {
  font-family: var(--pixel-mono);
  font-size: 0.92rem;
  line-height: 1;
  color: var(--pixel-sage-dark);
}

.pixel-flight-grid .pixel-ticket-cell.is-gate,
.pixel-flight-grid .pixel-ticket-cell.is-seat,
.pixel-flight-grid .pixel-ticket-cell.is-fare {
  align-content: start;
}

.pixel-flight-stub {
  display: grid;
  grid-template-rows: auto auto auto 1fr auto;
  align-content: start;
  gap: 0.24rem;
  min-height: 0;
  padding: 0.76rem 0.6rem 0.66rem 0.58rem;
  border-left: 2px dashed rgba(107, 110, 86, 0.84);
  background: linear-gradient(180deg, rgba(250, 248, 238, 0.72), rgba(237, 235, 214, 0.68));
}

.pixel-flight-stub-head {
  gap: 0.14rem;
}

.pixel-flight-stub-route {
  gap: 0.16rem;
  padding-top: 0.08rem;
  padding-bottom: 0.18rem;
  border-bottom: 1px solid rgba(106, 112, 80, 0.18);
}

.pixel-flight-stub-traveler {
  display: grid;
  gap: 0.12rem;
  padding-bottom: 0.18rem;
  border-bottom: 1px solid rgba(106, 112, 80, 0.18);
}

.pixel-flight-stub-traveler strong {
  display: block;
}

.pixel-flight-stub-meta {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.24rem 0.42rem;
  padding-top: 0.08rem;
}

.pixel-flight-stub-meta > :nth-child(3) {
  grid-column: 1 / -1;
}

.pixel-flight-stub .pixel-ticket-barcode {
  min-height: 1.52rem;
}

.pixel-flight-stub .pixel-ticket-barcode-text {
  font-size: 0.34rem;
}

.pixel-bus-ticket {
  width: var(--pixel-bus-width);
  min-width: var(--pixel-bus-width);
  height: var(--pixel-bus-height);
  padding: 0.82rem;
  background:
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.05) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.04) 0 1px, transparent 1px 16px),
    linear-gradient(180deg, var(--pixel-desk), var(--pixel-desk-deep));
  box-shadow: var(--pixel-shadow);
  overflow: hidden;
}

.pixel-bus-paper {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 10.4rem;
}

.pixel-bus-main,
.pixel-bus-stub {
  position: relative;
  z-index: 1;
}

.pixel-bus-main {
  display: grid;
  grid-template-rows: auto auto auto 1fr;
  min-height: 0;
  padding: 0.82rem 0.86rem 0.78rem;
}

.pixel-bus-stub {
  display: grid;
  grid-template-rows: auto auto 1fr auto;
  gap: 0.34rem;
  min-height: 0;
  padding: 0.82rem 0.66rem 0.74rem 0.6rem;
  border-left: 2px dashed rgba(107, 110, 86, 0.84);
  background: linear-gradient(180deg, rgba(250, 248, 238, 0.72), rgba(237, 235, 214, 0.68));
}

.pixel-bus-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 0.56rem 0.74rem;
  align-content: start;
  min-height: 0;
  padding-top: 0.58rem;
}

.pixel-plan-sheet,
.pixel-packing-sheet {
  width: var(--pixel-plan-width);
  min-width: var(--pixel-plan-width);
  padding: 0.82rem;
  background:
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.05) 0 1px, transparent 1px 16px),
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.04) 0 1px, transparent 1px 16px),
    linear-gradient(180deg, var(--pixel-desk), var(--pixel-desk-deep));
  box-shadow: var(--pixel-shadow);
  overflow: hidden;
}

.pixel-plan-paper,
.pixel-packing-paper {
  position: relative;
  min-height: 100%;
  padding: 1.28rem;
  background: var(--pixel-paper);
  overflow: hidden;
}

.pixel-plan-paper::before,
.pixel-packing-paper::before {
  content: "";
  position: absolute;
  inset: 0;
  background:
    repeating-linear-gradient(0deg, rgba(106, 126, 82, 0.06) 0 1px, transparent 1px 12px),
    repeating-linear-gradient(90deg, rgba(106, 126, 82, 0.06) 0 1px, transparent 1px 12px),
    radial-gradient(circle at top left, rgba(132, 153, 108, 0.12), transparent 26%);
  opacity: 0.82;
  pointer-events: none;
}

.pixel-plan-paper::after,
.pixel-packing-paper::after {
  content: "";
  position: absolute;
  inset: 0.7rem;
  border: 2px solid rgba(106, 112, 80, 0.18);
  pointer-events: none;
}

.pixel-plan-paper > *,
.pixel-packing-paper > * {
  position: relative;
  z-index: 1;
}

.pixel-doc-header {
  display: grid;
  gap: 1.08rem;
  padding-bottom: 1.3rem;
  border-bottom: 1px solid rgba(106, 112, 80, 0.24);
}

.pixel-doc-header-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.82rem;
}

.pixel-doc-kicker {
  font-family: var(--pixel-mono);
  font-size: 0.62rem;
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pixel-sage-dark);
}

.pixel-doc-duration {
  display: inline-flex;
  align-items: center;
  min-height: 1.62rem;
  padding: 0 0.74rem;
  border: 1px solid rgba(106, 112, 80, 0.2);
  background: rgba(132, 153, 108, 0.08);
  font-family: var(--pixel-mono);
  font-size: 0.54rem;
  line-height: 1.2;
  color: var(--pixel-sage-dark);
}

.pixel-doc-heading {
  display: grid;
  gap: 0.72rem;
}

.pixel-doc-overline {
  margin: 0 0 0.34rem;
  font-family: var(--pixel-mono);
  font-size: 0.58rem;
  line-height: 1.18;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pixel-muted);
}

.pixel-doc-route-note {
  font-family: var(--pixel-mono);
  font-size: 0.62rem;
  line-height: 1.2;
  color: var(--pixel-sage-dark);
}

.pixel-doc-title {
  margin: 0;
}

.pixel-doc-title-stack {
  display: grid;
  gap: 0.3rem;
}

.pixel-doc-title-stack [lang="en"] {
  font-family: var(--pixel-display);
  font-size: 1.16rem;
  line-height: 0.94;
  letter-spacing: 0.08em;
  color: var(--pixel-sage-dark);
}

.pixel-doc-title-stack [lang="zh-CN"] {
  font-size: 0.82rem;
  line-height: 1.38;
  color: var(--pixel-ink);
}

.pixel-doc-title-stack.is-hero [lang="en"] {
  font-size: 1.56rem;
}

.pixel-doc-title-stack.is-hero [lang="zh-CN"] {
  font-size: 0.96rem;
}

.pixel-doc-title-stack.is-hero .voyager-field-main {
  font-family: var(--pixel-display);
  font-size: 1.56rem;
  line-height: 0.94;
  letter-spacing: 0.08em;
  color: var(--pixel-sage-dark);
}

.pixel-doc-title-stack.is-hero .voyager-field-secondary {
  font-size: 0.92rem;
  line-height: 1.34;
  color: rgba(60, 67, 51, 0.82);
}

.pixel-doc-summary,
.pixel-plan-copy,
.pixel-plan-note {
  margin: 0;
}

.pixel-doc-copy-stack {
  display: grid;
  gap: 0.3rem;
}

.pixel-doc-copy-stack [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.58rem;
  line-height: 1.54;
  color: var(--pixel-ink-soft);
}

.pixel-doc-copy-stack [lang="zh-CN"] {
  font-size: 0.8rem;
  line-height: 1.82;
  color: var(--pixel-ink);
}

.pixel-doc-copy-stack .voyager-field-main {
  font-size: 0.8rem;
  line-height: 1.82;
  color: var(--pixel-ink);
}

.pixel-doc-copy-stack .voyager-field-secondary {
  font-family: var(--pixel-mono);
  font-size: 0.62rem;
  line-height: 1.56;
  color: var(--pixel-ink-soft);
}

.pixel-doc-copy-stack.is-muted [lang="en"],
.pixel-doc-copy-stack.is-muted [lang="zh-CN"] {
  color: var(--pixel-muted);
}

.pixel-doc-chip-row {
  margin: 0;
  padding: 0;
  list-style: none;
  display: flex;
  flex-wrap: wrap;
  gap: 0.72rem;
}

.pixel-doc-chip-row li {
  min-height: 1.82rem;
  padding: 0.42rem 0.74rem;
  border: 1px solid rgba(106, 112, 80, 0.18);
  background: rgba(132, 153, 108, 0.08);
}

.pixel-doc-chip-row.is-header {
  gap: 0.48rem;
}

.pixel-doc-chip-row.is-footer li {
  background: rgba(255, 255, 255, 0.52);
}

.pixel-doc-chip-stack {
  display: grid;
  gap: 0.08rem;
}

.pixel-doc-chip-stack [lang="en"] {
  font-family: var(--pixel-mono);
  font-size: 0.5rem;
  line-height: 1.18;
  color: var(--pixel-sage-dark);
}

.pixel-doc-chip-stack [lang="zh-CN"] {
  font-size: 0.58rem;
  line-height: 1.24;
  color: var(--pixel-ink-soft);
}

.pixel-plan-module-list {
  margin: 0;
  padding: 1.38rem 0 0;
  list-style: none;
  display: grid;
  gap: 1.34rem;
}

.pixel-plan-module {
  display: grid;
  gap: 0.82rem;
  padding-bottom: 1.24rem;
  border-bottom: 1px solid rgba(106, 112, 80, 0.18);
}

.pixel-plan-module:last-child {
  padding-bottom: 0;
  border-bottom: 0;
}

.pixel-plan-module-head {
  display: grid;
  grid-template-columns: 2.3rem minmax(0, 1fr);
  gap: 0.72rem;
  align-items: start;
}

.pixel-plan-module-index {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 1.94rem;
  border: 1px solid rgba(106, 112, 80, 0.18);
  background: rgba(132, 153, 108, 0.08);
  font-family: var(--pixel-mono);
  font-size: 0.64rem;
  color: var(--pixel-sage-dark);
}

.pixel-plan-module-heading {
  display: grid;
  gap: 0.34rem;
}

.pixel-plan-module-heading h4 {
  margin: 0;
}

.pixel-plan-module-type {
  font-family: var(--pixel-mono);
  font-size: 0.56rem;
  line-height: 1.2;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pixel-muted);
}

.pixel-plan-module-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.48rem;
  align-items: center;
  font-family: var(--pixel-mono);
  font-size: 0.54rem;
  line-height: 1.3;
  color: var(--pixel-muted);
}

.pixel-plan-task-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.74rem;
}

.pixel-plan-task {
  display: grid;
  grid-template-columns: 1rem minmax(0, 1fr);
  gap: 0.7rem;
  align-items: start;
}

.pixel-plan-task-mark {
  width: 0.8rem;
  height: 0.8rem;
  margin-top: 0.18rem;
  border: 1px solid rgba(106, 112, 80, 0.24);
  background: rgba(132, 153, 108, 0.1);
}

.pixel-pack-grid {
  padding-top: 1.34rem;
  display: grid;
  gap: 1.14rem;
}

.pixel-pack-category {
  display: grid;
  gap: 0.84rem;
  padding: 1.06rem;
  border: 1px solid rgba(106, 112, 80, 0.18);
  background: rgba(255, 255, 255, 0.42);
}

.pixel-pack-category-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 0.78rem;
}

.pixel-pack-category-title {
  font-family: var(--pixel-mono);
  font-size: 0.6rem;
  line-height: 1.18;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pixel-sage-dark);
}

.pixel-pack-category-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 1.68rem;
  min-height: 1.68rem;
  border: 1px solid rgba(106, 112, 80, 0.18);
  background: rgba(132, 153, 108, 0.08);
  font-family: var(--pixel-mono);
  font-size: 0.6rem;
  color: var(--pixel-sage-dark);
}

.pixel-pack-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 0.8rem;
}

.pixel-pack-item {
  display: grid;
  grid-template-columns: 0.9rem minmax(0, 1fr) auto;
  gap: 0.68rem;
  align-items: start;
}

.pixel-pack-check {
  width: 0.76rem;
  height: 0.76rem;
  margin-top: 0.18rem;
  border: 1px solid rgba(106, 112, 80, 0.24);
  background: rgba(132, 153, 108, 0.1);
}

.pixel-pack-copy {
  display: grid;
  gap: 0.24rem;
}

.pixel-pack-note {
  color: var(--pixel-muted);
}

.pixel-pack-qty {
  font-family: var(--pixel-mono);
  font-size: 0.66rem;
  line-height: 1.2;
  color: var(--pixel-sage-dark);
}

.pixel-pack-footer {
  display: grid;
  gap: 0.9rem;
  padding-top: 1.3rem;
  border-top: 1px solid rgba(106, 112, 80, 0.24);
}

.pixel-pack-footer-title {
  display: inline-block;
  margin-bottom: 0.56rem;
  font-family: var(--pixel-mono);
  font-size: 0.58rem;
  line-height: 1.18;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--pixel-sage-dark);
}

@media (max-width: 720px) {
  .pixel-preview-panel {
    padding: 0.9rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .pixel-render-host,
  .pixel-preview-frame,
  .pixel-train-ticket {
    scroll-behavior: auto;
  }
}
