.snack-page .service-hero__title {
  color: #f2eadf;
  text-shadow:
    0 0 18px rgba(240, 214, 177, 0.08),
    0.03em 0 0 rgba(255, 188, 118, 0.2),
    -0.03em 0 0 rgba(134, 224, 255, 0.14);
}

.snack-page .service-hero__subtitle {
  color: #f4e6c7;
}

.counter-flow {
  width: var(--section-width);
  margin: 0 auto;
  display: grid;
  gap: 22px;
}

.counter-stepbar,
.counter-menu-panel,
.counter-custom-panel,
.counter-checkout-panel,
.receipt-stage {
  display: grid;
  gap: 20px;
}

.counter-stepbar__copy,
.counter-panel__intro {
  display: grid;
  gap: 10px;
}

.counter-stepbar__copy h2,
.counter-panel__intro h2 {
  margin: 0;
  font-family: var(--cn-title-font);
  font-size: clamp(1.48rem, 2.5vw, 2.08rem);
  font-weight: 400;
  letter-spacing: 0.06em;
  line-height: 1.34;
}

.counter-stepbar__copy p,
.counter-panel__intro p {
  margin: 0;
  color: var(--muted-strong);
  line-height: 1.78;
}

.step-indicators {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.step-pill {
  padding: 14px 16px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(7, 13, 21, 0.58);
  color: var(--muted);
  font-family: var(--mono-font);
  font-size: 0.76rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  clip-path: polygon(0 12px, 12px 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 12px));
}

.step-pill.is-active {
  border-color: rgba(255, 190, 115, 0.34);
  background:
    linear-gradient(135deg, rgba(255, 190, 115, 0.16), rgba(255, 190, 115, 0.08)),
    rgba(8, 13, 21, 0.82);
  color: #fff4de;
  box-shadow: 0 0 24px rgba(255, 190, 115, 0.12);
}

.counter-step {
  display: grid;
  gap: 22px;
}

.counter-step[hidden] {
  display: none;
}

.category-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.category-tab,
.theme-chip {
  min-height: 44px;
  padding: 0 14px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(7, 13, 21, 0.72);
  color: var(--muted-strong);
  font: inherit;
  font-family: var(--mono-font);
  font-size: 0.76rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease, color 0.22s ease;
  clip-path: polygon(0 10px, 10px 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 12px 100%, 0 calc(100% - 10px));
}

.category-tab:hover,
.category-tab:focus-visible,
.theme-chip:hover,
.theme-chip:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(255, 255, 255, 0.18);
}

.category-tab.is-active {
  border-color: color-mix(in srgb, var(--tab-accent, rgba(255, 190, 115, 0.22)) 82%, rgba(255, 255, 255, 0.12));
  box-shadow: 0 0 24px color-mix(in srgb, var(--tab-accent, rgba(255, 190, 115, 0.22)) 28%, transparent);
  color: #fff7eb;
}

.menu-items {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}

.menu-item-card {
  --item-accent: #ffbe73;
  display: grid;
  align-content: start;
  gap: 10px;
  padding: 13px;
  border: 1px solid color-mix(in srgb, var(--item-accent) 24%, rgba(255, 255, 255, 0.08));
  background:
    radial-gradient(circle at 100% 0, color-mix(in srgb, var(--item-accent) 14%, transparent), transparent 34%),
    linear-gradient(165deg, rgba(8, 13, 21, 0.96), rgba(11, 18, 29, 0.74));
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.02) inset,
    0 16px 34px rgba(0, 0, 0, 0.24);
  clip-path: polygon(0 14px, 14px 0, calc(100% - 18px) 0, 100% 18px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
}

.menu-item-card[data-category="Snack"] {
  --item-accent: #ffbb72;
}

.menu-item-card[data-category="Drink"] {
  --item-accent: #79dfff;
}

.menu-item-card[data-category="Dessert"] {
  --item-accent: #f79bc9;
}

.menu-item-card[data-category="Other"] {
  --item-accent: #d3c6a5;
}

.menu-item-card__top,
.cart-item__head,
.cart-item__footer,
.receipt-stage__head,
.receipt-paper__meta-row,
.receipt-paper__summary-row,
.receipt-paper__item-head,
.receipt-paper__item-meta {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}

.menu-item-card__badge,
.cart-item__badge {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  max-width: 100%;
  padding: 5px 8px;
  border: 1px solid color-mix(in srgb, var(--item-accent) 28%, rgba(255, 255, 255, 0.08));
  background: color-mix(in srgb, var(--item-accent) 12%, rgba(8, 12, 19, 0.7));
  color: color-mix(in srgb, var(--item-accent) 82%, white 18%);
  font-family: var(--mono-font);
  font-size: 0.64rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.menu-item-card__price,
.cart-item__unit {
  margin: 0;
  font-family: var(--mono-font);
  font-size: 0.82rem;
  letter-spacing: 0.12em;
  color: color-mix(in srgb, var(--item-accent) 84%, white 16%);
}

.menu-item-card__copy,
.cart-item__title,
.custom-form,
.custom-form__head,
.receipt-panel__copy {
  display: grid;
  gap: 6px;
}

.menu-item-card__name,
.cart-item__name {
  margin: 0;
  font-family: var(--message-cn-font);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.34;
}

.menu-item-card__name span,
.cart-item__name span {
  display: block;
  margin-top: 3px;
  font-family: var(--mono-font);
  font-size: 0.64rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted);
}

.menu-item-card__description,
.custom-form__head p {
  margin: 0;
  color: var(--muted);
  font-size: 0.84rem;
  line-height: 1.56;
}

.menu-item-card__description {
  display: -webkit-box;
  overflow: hidden;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
}

.menu-item-card__add,
.custom-form__submit,
.receipt-stage__actions .primary-button,
.receipt-stage__actions .ghost-button,
.receipt-stage__back {
  width: 100%;
}

.menu-item-card__add.is-added {
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow: 0 0 28px color-mix(in srgb, var(--item-accent) 28%, transparent);
}

.menu-item-card__add {
  min-height: 38px;
  padding: 0 10px;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
}

.custom-form {
  gap: 16px;
}

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

.field--wide {
  grid-column: 1 / -1;
}

.field select,
.field textarea {
  min-height: 54px;
  padding: 14px 16px;
  border: 1px solid rgba(115, 242, 255, 0.18);
  background: rgba(5, 10, 18, 0.72);
  color: var(--text);
  clip-path: polygon(0 12px, 12px 0, calc(100% - 12px) 0, 100% 12px, 100% 100%, 0 100%);
  transition: border-color 0.22s ease, box-shadow 0.22s ease;
}

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

.field select:focus-visible,
.field textarea:focus-visible {
  outline: none;
  border-color: rgba(115, 242, 255, 0.46);
  box-shadow: 0 0 0 1px rgba(115, 242, 255, 0.16);
}

.cart-shell {
  display: grid;
  gap: 12px;
  min-height: 180px;
  padding: 14px;
  border: 1px solid rgba(115, 242, 255, 0.14);
  background:
    linear-gradient(180deg, rgba(7, 13, 21, 0.76), rgba(5, 10, 18, 0.92)),
    linear-gradient(90deg, rgba(115, 242, 255, 0.06), transparent 56%);
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.02);
}

.cart-list {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 12px;
}

.cart-empty {
  margin: 0;
  align-self: center;
  color: var(--muted);
  text-align: center;
  line-height: 1.8;
}

.cart-item {
  --item-accent: #ffbe73;
  display: grid;
  gap: 12px;
  padding: 14px;
  border: 1px solid color-mix(in srgb, var(--item-accent) 14%, rgba(255, 255, 255, 0.08));
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.03), transparent 22%),
    rgba(6, 11, 18, 0.72);
}

.cart-item[data-category="Snack"] {
  --item-accent: #ffbb72;
}

.cart-item[data-category="Drink"] {
  --item-accent: #79dfff;
}

.cart-item[data-category="Dessert"] {
  --item-accent: #f79bc9;
}

.cart-item[data-category="Other"] {
  --item-accent: #d4c7a9;
}

.cart-item__note {
  margin: 0;
  padding-top: 10px;
  border-top: 1px dashed rgba(255, 255, 255, 0.08);
  color: var(--muted-strong);
  line-height: 1.68;
}

.qty-control {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 10px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  background: rgba(7, 12, 20, 0.62);
}

.qty-button,
.remove-button {
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(10, 15, 24, 0.9);
  color: inherit;
  font: inherit;
  cursor: pointer;
  transition: transform 0.22s ease, border-color 0.22s ease, box-shadow 0.22s ease;
}

.qty-button {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  font-family: var(--mono-font);
  font-size: 1rem;
}

.qty-button:hover,
.qty-button:focus-visible,
.remove-button:hover,
.remove-button:focus-visible {
  transform: translateY(-1px);
  border-color: rgba(255, 255, 255, 0.22);
  box-shadow: 0 0 20px rgba(115, 242, 255, 0.1);
}

.qty-value {
  min-width: 24px;
  text-align: center;
  font-family: var(--mono-font);
  letter-spacing: 0.12em;
}

.cart-item__subtotal-wrap {
  display: flex;
  align-items: center;
  gap: 10px;
}

.cart-item__subtotal {
  font-family: var(--mono-font);
  font-size: 0.92rem;
  letter-spacing: 0.14em;
  color: #fff3d8;
}

.remove-button {
  min-height: 34px;
  padding: 0 12px;
  font-family: var(--mono-font);
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
}

.order-summary-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
}

.order-summary-card {
  display: grid;
  gap: 8px;
  padding: 14px;
  border: 1px solid rgba(115, 242, 255, 0.12);
  background:
    linear-gradient(160deg, rgba(255, 255, 255, 0.03), transparent 22%),
    rgba(5, 10, 17, 0.7);
}

.order-summary-card span {
  font-family: var(--mono-font);
  font-size: 0.72rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--muted);
}

.order-summary-card strong {
  font-size: 1.34rem;
  color: #fff7eb;
}

.checkout-actions,
.receipt-stage__actions,
.receipt-theme-toggle {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.receipt-stage {
  justify-items: center;
}

.receipt-stage__head,
.receipt-stage__actions,
.receipt-theme-toggle,
.receipt-stage .result-status {
  width: min(100%, 820px);
}

.receipt-stage__head {
  align-items: stretch;
}

.receipt-stage__head .counter-panel__intro {
  flex: 1 1 auto;
}

.receipt-stage__back {
  max-width: 220px;
}

.theme-chip.is-active {
  border-color: rgba(255, 190, 115, 0.34);
  background:
    linear-gradient(135deg, rgba(255, 190, 115, 0.16), rgba(255, 190, 115, 0.08)),
    rgba(8, 13, 21, 0.82);
  color: #fff6e2;
  box-shadow: 0 0 24px rgba(255, 190, 115, 0.14);
}

.receipt-frame {
  width: 100%;
  display: grid;
  justify-items: center;
  padding: 18px 0 6px;
  overflow-x: auto;
  transition: transform 0.28s ease, filter 0.28s ease;
}

.receipt-frame.is-ready {
  filter: drop-shadow(0 16px 32px rgba(0, 0, 0, 0.24));
}

.receipt-frame.is-highlight {
  transform: translateY(-4px);
}

.receipt-paper {
  --paper-width: 392px;
  --paper-bg: linear-gradient(180deg, #fffefc, #f6f4ef 54%, #ece8df 100%);
  --paper-noise: repeating-linear-gradient(180deg, rgba(17, 17, 17, 0.04) 0, rgba(17, 17, 17, 0.04) 1px, transparent 1px, transparent 5px);
  --paper-border: rgba(18, 18, 18, 0.08);
  --paper-divider: rgba(18, 18, 18, 0.2);
  --paper-text: #111111;
  --paper-muted: rgba(17, 17, 17, 0.74);
  --paper-soft: rgba(17, 17, 17, 0.66);
  position: relative;
  width: var(--paper-width);
  min-width: var(--paper-width);
  padding: 24px 20px 28px;
  color: var(--paper-text);
  background:
    radial-gradient(circle at top right, rgba(255, 247, 232, 0.36), transparent 28%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.32), transparent 14%),
    var(--paper-bg);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.02) inset,
    0 18px 38px rgba(0, 0, 0, 0.2);
  font-family: var(--mono-font);
  clip-path: polygon(0 6px, 6px 0, calc(100% - 6px) 0, 100% 6px, 100% calc(100% - 8px), calc(100% - 8px) 100%, 8px 100%, 0 calc(100% - 8px));
}

.receipt-paper::before {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  background:
    radial-gradient(circle at 10% 12%, rgba(255, 255, 255, 0.48), transparent 18%),
    radial-gradient(circle at 88% 22%, rgba(0, 0, 0, 0.04), transparent 24%),
    var(--paper-noise);
  opacity: 0.52;
}

.receipt-paper::after {
  content: "";
  position: absolute;
  inset: 12px;
  border: 1px solid var(--paper-border);
  pointer-events: none;
}

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

.receipt-paper--light {
  --paper-bg: linear-gradient(180deg, #fffefc, #f7f6f2 56%, #efebe3 100%);
  --paper-noise:
    repeating-linear-gradient(180deg, rgba(12, 12, 12, 0.035) 0, rgba(12, 12, 12, 0.035) 1px, transparent 1px, transparent 5px),
    repeating-linear-gradient(90deg, rgba(0, 0, 0, 0.012) 0, rgba(0, 0, 0, 0.012) 1px, transparent 1px, transparent 6px);
  --paper-border: rgba(20, 20, 20, 0.08);
  --paper-divider: rgba(17, 17, 17, 0.22);
  --paper-text: #111111;
  --paper-muted: rgba(17, 17, 17, 0.72);
  --paper-soft: rgba(17, 17, 17, 0.62);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.42) inset,
    0 18px 38px rgba(0, 0, 0, 0.18);
}

.receipt-paper--dark {
  --paper-bg:
    radial-gradient(circle at top right, rgba(255, 191, 118, 0.14), transparent 34%),
    radial-gradient(circle at 0 18%, rgba(122, 223, 255, 0.18), transparent 28%),
    linear-gradient(180deg, rgba(18, 29, 42, 0.98), rgba(10, 17, 27, 0.98) 38%, rgba(6, 10, 18, 0.99));
  --paper-noise:
    repeating-linear-gradient(180deg, rgba(122, 223, 255, 0.06) 0, rgba(122, 223, 255, 0.06) 1px, transparent 1px, transparent 5px),
    linear-gradient(90deg, rgba(122, 223, 255, 0.04), transparent 28%, rgba(255, 191, 118, 0.04) 72%, transparent);
  --paper-border: rgba(122, 223, 255, 0.34);
  --paper-divider: rgba(122, 223, 255, 0.18);
  --paper-text: #f4f8fd;
  --paper-muted: rgba(179, 198, 214, 0.82);
  --paper-soft: #86e3ff;
  box-shadow:
    0 0 0 1px rgba(122, 223, 255, 0.12) inset,
    0 0 36px rgba(122, 223, 255, 0.14),
    0 28px 52px rgba(0, 0, 0, 0.42);
}

.receipt-paper--dark::before {
  background:
    linear-gradient(180deg, rgba(122, 223, 255, 0.08), transparent 16%),
    radial-gradient(circle at 86% 16%, rgba(255, 191, 118, 0.16), transparent 22%),
    radial-gradient(circle at 12% 10%, rgba(122, 223, 255, 0.2), transparent 24%),
    var(--paper-noise);
  opacity: 0.86;
}

.receipt-paper--dark::after {
  inset: 10px;
  border: 1px solid rgba(122, 223, 255, 0.24);
  box-shadow:
    inset 0 0 0 1px rgba(255, 255, 255, 0.02),
    0 0 0 1px rgba(255, 191, 118, 0.06);
}

.receipt-paper--dark .receipt-paper__brand,
.receipt-paper--dark .receipt-paper__brand-zh,
.receipt-paper--dark .receipt-paper__title {
  text-shadow: 0 0 18px rgba(122, 223, 255, 0.12);
}

.receipt-paper--dark .receipt-paper__items {
  padding: 16px 14px 8px;
  border: 1px solid rgba(122, 223, 255, 0.14);
  background: linear-gradient(180deg, rgba(122, 223, 255, 0.06), rgba(255, 255, 255, 0.02));
}

.receipt-paper--dark .receipt-paper__item {
  padding: 12px 10px 14px;
  border: 1px solid rgba(122, 223, 255, 0.1);
  background: linear-gradient(180deg, rgba(8, 14, 22, 0.82), rgba(10, 17, 27, 0.56));
}

.receipt-paper--dark .receipt-paper__summary {
  padding: 16px 14px 0;
  border: 1px solid rgba(122, 223, 255, 0.14);
  background: linear-gradient(180deg, rgba(122, 223, 255, 0.07), rgba(255, 191, 118, 0.04));
}

.receipt-paper--dark .receipt-paper__footer {
  padding: 16px 14px 0;
  border: 1px solid rgba(122, 223, 255, 0.12);
  background: linear-gradient(180deg, rgba(8, 14, 22, 0.82), rgba(255, 255, 255, 0.02));
}

.receipt-paper.is-exporting {
  clip-path: none;
  border-radius: 8px;
}

.receipt-paper__system,
.receipt-paper__meta-label,
.receipt-paper__summary-label,
.receipt-paper__items-head {
  margin: 0;
  font-size: 0.7rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--paper-soft);
}

.receipt-paper__brand {
  margin: 14px 0 0;
  font-family: var(--title-font);
  font-size: 1.42rem;
  line-height: 1.08;
  letter-spacing: 0.06em;
  text-transform: uppercase;
}

.receipt-paper__brand-zh {
  margin: 6px 0 0;
  font-family: var(--cn-title-font);
  font-size: 1.18rem;
  letter-spacing: 0.08em;
}

.receipt-paper__title,
.receipt-paper__placeholder-title {
  margin: 20px 0 0;
  padding-top: 14px;
  border-top: 1px dashed var(--paper-divider);
  font-size: 1.02rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.receipt-paper__meta,
.receipt-paper__summary {
  display: grid;
  gap: 10px;
  margin-top: 18px;
}

.receipt-paper__items {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px dashed var(--paper-divider);
}

.receipt-paper__items-head {
  display: block;
  margin-bottom: 12px;
}

.receipt-paper__items-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.receipt-paper__meta-row strong,
.receipt-paper__summary-row strong {
  text-align: right;
  font-size: 0.82rem;
  line-height: 1.7;
  color: var(--paper-text);
}

.receipt-paper__item {
  display: grid;
  gap: 7px;
  padding: 10px 0;
  border-bottom: 1px dashed var(--paper-divider);
}

.receipt-paper__item-name {
  margin: 0;
  font-family: var(--message-cn-font);
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.04em;
  line-height: 1.36;
}

.receipt-paper__item-name span {
  display: block;
  margin-top: 3px;
  font-family: var(--mono-font);
  font-size: 0.66rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--paper-muted);
}

.receipt-paper__item-total,
.receipt-paper__item-meta,
.receipt-paper__item-note,
.receipt-paper__footer-note {
  color: var(--paper-text);
}

.receipt-paper__item-total {
  font-size: 0.8rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.receipt-paper__item-meta {
  font-size: 0.72rem;
}

.receipt-paper__item-note {
  margin: 0;
  font-size: 0.72rem;
  line-height: 1.68;
  color: var(--paper-muted);
}

.receipt-paper__summary {
  padding-top: 16px;
  border-top: 1px dashed var(--paper-divider);
}

.receipt-paper__summary-row--total {
  padding-top: 8px;
  border-top: 1px solid var(--paper-divider);
}

.receipt-paper__summary-row--total strong {
  font-size: 0.98rem;
  letter-spacing: 0.14em;
}

.receipt-paper__footer {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px dashed var(--paper-divider);
}

.receipt-paper__footer-note {
  margin: 10px 0 0;
  line-height: 1.7;
  color: var(--paper-muted);
}

.receipt-paper--placeholder {
  min-height: 320px;
  display: grid;
  align-content: center;
  gap: 12px;
  text-align: center;
}

.receipt-paper__placeholder-copy {
  margin: 0;
  line-height: 1.82;
  color: var(--paper-muted);
}

.export-canvas {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
}

@keyframes receipt-ping {
  0% {
    transform: translateY(0);
    filter: drop-shadow(0 14px 28px rgba(0, 0, 0, 0.14));
  }

  40% {
    transform: translateY(-4px);
    filter: drop-shadow(0 18px 34px rgba(255, 200, 117, 0.16));
  }

  100% {
    transform: translateY(0);
    filter: drop-shadow(0 14px 28px rgba(0, 0, 0, 0.14));
  }
}

@media (prefers-reduced-motion: no-preference) {
  .receipt-frame.is-highlight .receipt-paper {
    animation: receipt-ping 0.82s ease;
  }
}

@media (max-width: 980px) {
  .menu-items,
  .custom-form__grid,
  .order-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 760px) {
  .step-indicators,
  .menu-items,
  .custom-form__grid,
  .order-summary-grid,
  .checkout-actions,
  .receipt-stage__actions,
  .receipt-theme-toggle {
    grid-template-columns: 1fr;
  }

  .menu-item-card__top,
  .cart-item__head,
  .cart-item__footer,
  .receipt-stage__head,
  .receipt-paper__meta-row,
  .receipt-paper__summary-row,
  .receipt-paper__item-head,
  .receipt-paper__item-meta {
    flex-direction: column;
    align-items: flex-start;
  }

  .receipt-stage__back {
    max-width: none;
  }

  .receipt-paper {
    width: min(100%, 392px);
    max-width: 100%;
    min-width: 0;
  }

  .receipt-paper__meta-row strong,
  .receipt-paper__summary-row strong {
    text-align: left;
  }
}

@media (max-width: 399px) {
  .counter-flow {
    gap: 16px;
    width: min(100%, calc(100% - 16px));
  }

  .counter-stepbar,
  .counter-menu-panel,
  .counter-custom-panel,
  .counter-checkout-panel,
  .receipt-stage,
  .counter-step {
    gap: 16px;
  }

  .menu-item-card,
  .cart-shell,
  .cart-item,
  .custom-form {
    padding: 12px;
  }

  .menu-item-card__name,
  .cart-item__name {
    font-size: 0.92rem;
  }

  .menu-item-card__description,
  .custom-form__head p {
    font-size: 0.78rem;
  }

  .receipt-frame {
    padding-top: 10px;
    overflow-x: hidden;
  }

  .receipt-paper {
    --paper-width: min(100%, 352px);
    width: var(--paper-width);
    min-width: 0;
    padding: 18px 14px 22px;
  }

  .receipt-paper::after {
    inset: 8px;
  }

  .receipt-paper__brand {
    font-size: 1.2rem;
  }

  .receipt-paper__brand-zh {
    font-size: 1rem;
  }

  .receipt-paper__title,
  .receipt-paper__placeholder-title {
    font-size: 0.86rem;
    letter-spacing: 0.12em;
  }

  .receipt-paper__meta,
  .receipt-paper__items,
  .receipt-paper__summary,
  .receipt-paper__footer {
    margin-top: 14px;
  }

  .receipt-paper__items,
  .receipt-paper__summary,
  .receipt-paper__footer {
    padding-top: 12px;
  }

  .receipt-paper__item-name {
    font-size: 0.9rem;
  }

  .receipt-paper__item-name span,
  .receipt-paper__item-meta,
  .receipt-paper__item-note,
  .receipt-paper__footer-note,
  .receipt-paper__meta-row strong,
  .receipt-paper__summary-row strong {
    font-size: 0.68rem;
  }

  .receipt-paper__summary-row--total strong {
    font-size: 0.88rem;
  }
}
