/* zxmyj — 移动端模板共享样式（升级版：营销冲击力强）
 * 完整布局都在这里；每个 skin (tpl1/2/3-skin.css) 只覆盖颜色变量。
 */

:root {
  --zx-primary: #dc143c;
  --zx-primary-dark: #b91030;
  --zx-primary-light: #fff0f0;
  --zx-accent: #ff6e26;
  --zx-gold: #ffd700;
  --zx-bg: #f5f5f5;
  --zx-card: #fff;
  --zx-text: #333;
  --zx-text-light: #999;
  --zx-border: #e8e8e8;
  --zx-price-bg: linear-gradient(135deg, #ff4500 0%, #dc143c 50%, #b91030 100%);
  --zx-cta-bg: linear-gradient(135deg, #ff7a00 0%, #ff4500 50%, #dc143c 100%);
  --zx-countdown-bg: #1a0000;
  --zx-countdown-num-bg: #ff4d2e;
}

* { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }
html, body {
  margin: 0; padding: 0; background: var(--zx-bg);
  font: 14px/1.5 -apple-system, BlinkMacSystemFont, "PingFang SC", "Microsoft YaHei", "Noto Sans SC", sans-serif;
  color: var(--zx-text);
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}
img { display: block; max-width: 100%; height: auto; }
a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }
[v-cloak] { display: none; }

.zx-root { min-height: 100vh; }
.zx-skel { padding: 30vh 14px; text-align: center; color: #aaa; }
/* Round 33: 分类型 toast —— 不同色 / 不同图标圈 */
.zx-toast {
  position: fixed; top: 40%; left: 50%; transform: translate(-50%, -50%);
  background: rgba(0, 0, 0, 0.88); color: #fff;
  padding: 12px 22px; border-radius: 10px; font-size: 15px; z-index: 1000;
  box-shadow: 0 6px 24px rgba(0,0,0,.32);
  display: flex; align-items: center; gap: 10px;
  max-width: 86vw;
  animation: zx-toast-in 0.18s ease-out;
}
@keyframes zx-toast-in {
  from { opacity: 0; transform: translate(-50%, -45%) scale(0.92); }
  to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}
.zx-toast-icon {
  flex-shrink: 0; width: 24px; height: 24px;
  border-radius: 50%; background: rgba(255,255,255,.22);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 800; line-height: 1;
}
.zx-toast-msg { flex: 1; line-height: 1.4; }
/* 类型色：成功绿 / 错误红 / 警告橙 / 加载蓝 */
.zx-toast-success { background: rgba(76, 175, 80, 0.95); }
.zx-toast-error   { background: rgba(244, 67, 54, 0.95); }
.zx-toast-warning { background: rgba(255, 152, 0, 0.95); }
.zx-toast-loading { background: rgba(33, 150, 243, 0.95); }
.zx-toast-info    { background: rgba(0, 0, 0, 0.85); }
.zx-toast-success .zx-toast-icon,
.zx-toast-error .zx-toast-icon,
.zx-toast-warning .zx-toast-icon,
.zx-toast-loading .zx-toast-icon {
  background: rgba(255,255,255,.28);
}
.zx-toast-spin { display: inline-block; animation: zx-spin-icon 0.8s linear infinite; }
@keyframes zx-spin-icon { to { transform: rotate(360deg); } }

.zx-page {
  max-width: 540px; margin: 0 auto;
  background: var(--zx-bg);
  padding-bottom: 80px;
  position: relative;
}

/* === Round 46: banner 顶部浮动胶囊消息流（仿 tpl6 bubble-list） === */
.zx-bubble-pill {
  position: absolute; top: 8px; left: 8px; z-index: 9;
  display: inline-flex; align-items: center; gap: 6px;
  max-width: calc(100% - 16px);
  padding: 5px 10px 5px 6px;
  background: rgba(0, 0, 0, .55); color: #fff;
  border-radius: 999px;
  font-size: 11px; line-height: 1.2;
  white-space: nowrap; overflow: hidden;
  pointer-events: none;
  box-shadow: 0 2px 6px rgba(0,0,0,.15);
}
.zx-bubble-pill::before {
  content: ''; flex: 0 0 auto;
  width: 14px; height: 14px; border-radius: 50%;
  background: linear-gradient(135deg, #ffb84d 0%, #ff7043 100%);
}
.zx-bubble-place { color: #ffd596; font-weight: 600; }
.zx-bubble-phone { color: #fff; opacity: .9; }
.zx-bubble-name { color: #fff; opacity: .9; }
.zx-bubble-action { color: #ffd596; font-weight: 600; margin-left: 2px; }
.zx-bubble-fade-enter-active,
.zx-bubble-fade-leave-active {
  transition: opacity .35s ease, transform .35s ease;
}
.zx-bubble-fade-enter-from { opacity: 0; transform: translateY(-6px); }
.zx-bubble-fade-leave-to { opacity: 0; transform: translateY(6px); }
.zx-bubble-fade-leave-active { position: absolute; top: 8px; left: 8px; }

/* === Banner 轮播（含手势滑动） === */
.zx-banner {
  position: relative; overflow: hidden; background: var(--zx-card);
  touch-action: pan-y;            /* 允许垂直滚动；水平由 JS 接管 */
  user-select: none; -webkit-user-select: none;
  cursor: grab;
}
.zx-banner-track { display: flex; transition: transform .35s ease; }
.zx-banner-track.dragging {
  transition: none;               /* 拖动跟手 */
  cursor: grabbing;
}
.zx-banner-item { flex: 0 0 100%; }
.zx-banner-item img {
  width: 100%; display: block;
  /* 加载中给浅色占位避免白闪一下；图片自身 aspect ratio 不强制改 */
  background: linear-gradient(135deg, #f5f5f5 0%, #ececec 100%);
  min-height: 200px;
  pointer-events: none;           /* 防 img 拖拽 ghost 干扰手势 */
  -webkit-user-drag: none;
}
.zx-banner-dots {
  position: absolute; bottom: 10px; left: 50%; transform: translateX(-50%);
  display: flex; gap: 5px; z-index: 5;
}
.zx-banner-dots span {
  width: 6px; height: 6px; border-radius: 50%; background: rgba(255,255,255,.5);
  transition: all .3s; cursor: pointer;
}
.zx-banner-dots span.on {
  width: 18px; border-radius: 3px; background: #fff;
}

/* === 价格区（升级版） === */
.zx-price {
  background: var(--zx-price-bg); color: #fff;
  padding: 16px 14px 12px;
  position: relative; overflow: hidden;
}
.zx-price::before {
  content: ''; position: absolute; top: -50%; right: -20%;
  width: 200px; height: 200px;
  background: radial-gradient(circle, rgba(255,255,255,.18) 0%, transparent 60%);
  pointer-events: none;
}
.zx-price-savings-bubble {
  position: absolute; top: 12px; right: 12px;
  background: var(--zx-gold);
  color: #b91030; font-weight: 800; font-size: 14px;
  padding: 6px 14px;
  border-radius: 20px 20px 20px 4px;
  box-shadow: 0 2px 8px rgba(0,0,0,.2);
  transform: rotate(8deg);
  z-index: 2;
}
.zx-price-savings-bubble::after {
  content: ''; position: absolute; left: 8px; bottom: -6px;
  width: 0; height: 0;
  border: 4px solid transparent;
  border-top-color: var(--zx-gold);
  border-bottom: 0;
}
.zx-price-row {
  display: flex; align-items: flex-end; gap: 10px;
  position: relative; z-index: 1;
}
.zx-price-now { display: flex; align-items: baseline; gap: 4px; }
.zx-price-tag {
  display: inline-block; background: #fff; color: var(--zx-primary);
  font-size: 11px; padding: 3px 7px; border-radius: 3px;
  font-weight: 800; align-self: center; margin-right: 6px;
  letter-spacing: 1px;
}
.zx-price-rmb { font-size: 18px; font-weight: 700; }
.zx-price-num {
  font-size: 44px; font-weight: 900; line-height: .9;
  letter-spacing: -1px;
  text-shadow: 0 2px 4px rgba(0,0,0,.2);
}
.zx-price-old-wrap { display: flex; flex-direction: column; gap: 2px; padding-bottom: 4px; }
.zx-price-old {
  font-size: 13px; opacity: .75; text-decoration: line-through;
}
.zx-price-discount {
  display: inline-block; align-self: flex-start;
  background: rgba(255,255,255,.2); color: #fff;
  font-size: 11px; padding: 1px 6px; border-radius: 3px;
  font-weight: 600;
}
.zx-price-meta { margin-top: 8px; font-size: 13px; opacity: .95; position: relative; z-index: 1; }

/* 已抢进度条 */
.zx-stock-bar {
  position: relative;
  margin-top: 10px;
  height: 16px; border-radius: 10px;
  background: rgba(0,0,0,.2);
  overflow: hidden;
  box-shadow: inset 0 1px 2px rgba(0,0,0,.3);
}
.zx-stock-bar-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--zx-gold) 0%, #ff8c00 50%, #ffd700 100%);
  background-size: 200% 100%;
  animation: zx-shimmer 2s linear infinite;
  transition: width .8s ease;
  box-shadow: 0 0 8px rgba(255, 215, 0, .6);
}
.zx-stock-bar-label {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700; color: #fff;
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}
@keyframes zx-shimmer {
  0%   { background-position: 0% 0%; }
  100% { background-position: 200% 0%; }
}

/* === 倒计时 === */
.zx-countdown {
  background: var(--zx-countdown-bg); color: #fff;
  padding: 12px 14px; text-align: center; font-size: 14px;
  position: relative;
}
.zx-countdown::before, .zx-countdown::after {
  content: '';
  position: absolute; top: 50%; transform: translateY(-50%);
  width: 30px; height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.3), transparent);
}
.zx-countdown::before { left: 16px; }
.zx-countdown::after { right: 16px; }
.zx-countdown-label { margin-right: 8px; font-size: 13px; }
.zx-cd-num {
  display: inline-block; background: var(--zx-countdown-num-bg); color: #fff;
  padding: 4px 8px; border-radius: 4px; min-width: 28px;
  font-style: normal; font-weight: 800; font-family: 'DIN Alternate', monospace;
  font-size: 16px;
  box-shadow: 0 2px 4px rgba(0,0,0,.3);
}
.zx-cd-sep { display: inline-block; margin: 0 5px; font-style: normal; }

/* === 标题 === */
.zx-title {
  background: var(--zx-card); padding: 14px;
  border-bottom: 1px solid var(--zx-border);
}
.zx-title-main { font-size: 17px; font-weight: 700; line-height: 1.45; color: var(--zx-text); }
.zx-title-meta { margin-top: 6px; font-size: 13px; color: var(--zx-text-light); line-height: 1.5; }

/* === 优惠提示 === */
.zx-yh {
  padding: 10px 14px; background: linear-gradient(90deg, #fff7e6, #fffaf0);
  color: #d46b08; font-size: 13px;
  border-left: 4px solid #faad14;
  display: flex; align-items: center; gap: 8px;
  font-weight: 600;
}
.zx-yh img { max-height: 24px; }
.zx-yh::before {
  content: '🎁'; font-size: 18px;
}

/* === 信任徽章（升级版：4 个彩色方块） === */
.zx-trust {
  margin-top: 8px; background: var(--zx-card);
  padding: 14px;
  display: grid; grid-template-columns: 1fr 1fr 1fr 1fr; gap: 8px;
  border-bottom: 1px solid var(--zx-border);
}
.zx-badge {
  text-align: center; padding: 10px 4px;
  border-radius: 8px;
  position: relative;
  background: linear-gradient(135deg, #fff5e6, #fff);
  border: 1px solid #ffe0b2;
}
.zx-badge-1 { background: linear-gradient(135deg, #fff0f0, #fff); border-color: #ffcdd2; }
.zx-badge-2 { background: linear-gradient(135deg, #e8f5e9, #fff); border-color: #c8e6c9; }
.zx-badge-3 { background: linear-gradient(135deg, #e3f2fd, #fff); border-color: #bbdefb; }
.zx-badge-4 { background: linear-gradient(135deg, #fff3e0, #fff); border-color: #ffe0b2; }
.zx-badge-ic { font-size: 22px; line-height: 1; margin-bottom: 4px; }
.zx-badge-t { font-size: 12px; font-weight: 700; color: #333; }
.zx-badge-s { font-size: 10px; color: #999; margin-top: 2px; }

/* === 实时下单消息流 === */
.zx-marquee-block {
  margin-top: 8px; background: var(--zx-card); padding: 10px 14px;
  border-bottom: 1px solid var(--zx-border);
}
.zx-marquee-head {
  display: flex; align-items: center; justify-content: space-between;
  font-size: 13px; color: #666; margin-bottom: 8px; font-weight: 600;
}
.zx-marquee-head b {
  color: #fff; background: var(--zx-primary); font-size: 11px;
  padding: 2px 8px; border-radius: 12px; font-weight: 600;
  animation: zx-flash 1.5s ease-in-out infinite;
}
@keyframes zx-flash {
  0%, 100% { opacity: 1; }
  50% { opacity: .65; }
}
.zx-marquee-window { height: 42px; overflow: hidden; }
.zx-marquee-list { transition: transform .5s linear; list-style: none; margin: 0; padding: 0; }
.zx-marquee-list > li { height: 42px; }
.zx-marquee-name { color: var(--zx-primary); font-size: 13px; font-weight: 700; margin: 0 0 2px; }
.zx-marquee-text { color: #999; font-size: 11px; line-height: 1.4; display: block;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

/* === Section === */
.zx-section { margin-top: 8px; background: var(--zx-card); }
.zx-section-title {
  padding: 14px 14px 6px; font-size: 16px; font-weight: 700; color: var(--zx-text);
  display: flex; align-items: center;
}
.zx-section-title::before {
  content: ''; display: inline-block; width: 4px; height: 16px;
  background: var(--zx-primary); margin-right: 8px; border-radius: 2px;
}
.zx-fullwidth { width: 100%; display: block; }

/* === 富文本详情 === */
.zx-detail { padding: 0; font-size: 14px; color: var(--zx-text); line-height: 1.7; }
/* 文字段正常缩进；只有图的段去掉 padding/margin，避免连排图缝隙 */
.zx-detail > p,
.zx-detail > h1, .zx-detail > h2, .zx-detail > h3,
.zx-detail > ul, .zx-detail > ol, .zx-detail > blockquote { padding: 0 14px; }
.zx-detail img { max-width: 100%; width: 100%; height: auto; display: block; margin: 0; border-radius: 0; }
/* 包了图的 <p>（来自 wangEditor 默认的 <p><img></p>）去掉所有间距 */
.zx-detail p { margin: 8px 0; line-height: 1.7; }
.zx-detail p:has(> img) { margin: 0; padding: 0; line-height: 0; }
.zx-detail p:has(> img:only-child) + p:has(> img:only-child) { margin-top: 0; }
/* fallback for browsers without :has() — 兜底用普通图直接相邻没缝 */
.zx-detail p > img:only-child { margin: 0; }
.zx-detail h1, .zx-detail h2, .zx-detail h3 { margin: 14px 0 8px; font-weight: 700; color: var(--zx-primary-dark); }
.zx-detail h1 { font-size: 20px; } .zx-detail h2 { font-size: 18px; } .zx-detail h3 { font-size: 16px; }
.zx-detail ul, .zx-detail ol { padding-left: 24px; margin: 8px 0; }
.zx-detail li { margin: 4px 0; }
.zx-detail blockquote {
  padding: 10px 14px; border-left: 4px solid var(--zx-primary);
  background: var(--zx-primary-light);
  color: var(--zx-primary-dark); margin: 8px 0; font-weight: 600;
}
.zx-detail table { border-collapse: collapse; width: 100%; margin: 8px 0; }
.zx-detail th, .zx-detail td { border: 1px solid var(--zx-border); padding: 6px 10px; }
.zx-detail th { background: #f5f5f5; }
.zx-detail a { color: #2563eb; text-decoration: underline; }

.zx-gallery img { margin: 0; display: block; }

/* === 中部促销条（"前 100 名"） === */
.zx-promo-strip {
  margin: 12px 14px;
  background: linear-gradient(135deg, #fff8e1 0%, #ffe0b2 100%);
  border: 2px dashed var(--zx-primary);
  border-radius: 10px;
  padding: 14px;
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  position: relative; overflow: hidden;
}
.zx-promo-strip::before {
  content: '🎉';
  position: absolute; left: -8px; top: -10px;
  font-size: 32px; opacity: .25; transform: rotate(-15deg);
}
.zx-promo-left { flex: 1; min-width: 0; }
.zx-promo-head { font-size: 16px; font-weight: 800; color: var(--zx-primary-dark); }
.zx-promo-sub { font-size: 12px; color: #8a6d3b; margin-top: 2px; }
.zx-promo-btn {
  background: var(--zx-cta-bg);
  color: #fff; border: 0; font-size: 14px; font-weight: 700;
  padding: 10px 18px; border-radius: 22px;
  box-shadow: 0 2px 8px rgba(220, 20, 60, .35);
  animation: zx-pulse 1.5s ease-in-out infinite;
  white-space: nowrap;
  flex-shrink: 0;
}
@keyframes zx-pulse {
  0%, 100% { transform: scale(1);   box-shadow: 0 2px 8px rgba(220, 20, 60, .35); }
  50%      { transform: scale(1.05); box-shadow: 0 4px 14px rgba(220, 20, 60, .55); }
}

/* === 表单 === */
.zx-form {
  margin-top: 8px; background: var(--zx-card);
  border-top: 1px solid var(--zx-border);
}
.zx-form-title {
  padding: 16px 14px; font-size: 18px; font-weight: 800;
  color: #fff; background: var(--zx-price-bg);
  text-align: center;
  position: relative;
}
.zx-form-title::after {
  content: ''; position: absolute; bottom: -6px; left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 12px; height: 12px;
  background: var(--zx-primary);
}

/* SKU */
.zx-sku { padding: 14px; border-bottom: 1px solid var(--zx-border); }
.zx-sku-label { font-size: 14px; color: #666; margin-bottom: 10px; font-weight: 600; }
.zx-sku-list { display: flex; flex-wrap: wrap; gap: 10px; }
.zx-sku-list button {
  position: relative; flex: 0 0 auto; min-width: 100px; padding: 10px 14px;
  background: #fafafa; border: 1px solid var(--zx-border); border-radius: 8px;
  font-size: 14px; color: var(--zx-text);
  display: flex; flex-direction: column; align-items: flex-start; gap: 4px;
}
.zx-sku-list button.on {
  border-color: var(--zx-primary); background: var(--zx-primary-light);
  color: var(--zx-primary-dark); border-width: 2px; padding: 9px 13px;
  box-shadow: 0 2px 8px rgba(220,20,60,.15);
}
.zx-sku-list button.sold { opacity: 0.45; cursor: not-allowed; }
.zx-sku-list .zx-sku-name { font-weight: 700; }
.zx-sku-list .zx-sku-price { font-size: 13px; font-weight: 600; }
.zx-sku-list .zx-sku-tag {
  position: absolute; top: -6px; right: -6px;
  font-size: 10px; background: #999; color: #fff;
  border-radius: 3px; padding: 1px 4px;
}
.zx-sku-list .zx-sku-tag.low { background: #f59e0b; }

.zx-row {
  display: flex; padding: 14px; align-items: center;
  border-bottom: 1px solid #f0f0f0;
}
.zx-row:last-child { border-bottom: 0; }
.zx-row-label {
  width: 80px; flex-shrink: 0; color: #666; font-size: 14px; font-weight: 600;
}
.zx-row-input {
  flex: 1; border: 0; outline: none; background: transparent;
  font-size: 15px; color: var(--zx-text); font-family: inherit;
}
.zx-area {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));   /* 关键：1fr 改 minmax(0,1fr)
     防止 select 的 min-content (最长省份文字) 撑爆单元格 */
  gap: 6px;
  flex: 1; min-width: 0;
}
.zx-area select {
  width: 100%; min-width: 0;
  padding: 8px 6px; border: 1px solid var(--zx-border); border-radius: 4px;
  background: #fafafa; font-size: 14px; color: var(--zx-text); font-family: inherit;
  /* iOS Safari 选择框不支持 text-overflow，但 min-width:0 + width:100% 已能裁出去 */
  appearance: menulist;
  box-sizing: border-box;
}
/* 兜底：保证 .zx-row 内的所有 flex 子项可以收缩 */
.zx-row { min-width: 0; }
.zx-row > * { min-width: 0; }
.zx-qty { display: flex; align-items: center; gap: 8px; }
.zx-qty button {
  width: 32px; height: 32px; border: 1px solid var(--zx-border);
  background: #fff; border-radius: 4px; font-size: 18px; color: #666;
}
.zx-qty button:disabled { opacity: 0.5; cursor: not-allowed; }
.zx-qty input {
  width: 60px; height: 32px; text-align: center;
  border: 1px solid var(--zx-border); background: #fff;
  border-radius: 4px; font-size: 14px;
}
.zx-row-pay {
  background: var(--zx-primary-light);
  border-bottom: 0;
}
.zx-pay-cod { color: var(--zx-primary); font-weight: 700; }

/* === 猜你喜欢 === */
.zx-like-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 8px;
  padding: 8px 14px 14px;
}
.zx-like-item {
  background: #fff; border: 1px solid #f0f0f0; border-radius: 8px;
  overflow: hidden; color: inherit;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}
.zx-like-item img { width: 100%; height: 140px; object-fit: cover; }
.zx-like-name {
  padding: 6px 8px; font-size: 13px; line-height: 1.3; height: 50px;
  overflow: hidden; color: var(--zx-text);
}
.zx-like-price { padding: 0 8px 8px; color: var(--zx-primary); font-weight: 700; font-size: 15px; }

.zx-copyright {
  padding: 14px 14px 6px; text-align: center; color: var(--zx-text-light); font-size: 12px;
}
.zx-icp {
  padding: 0 14px 16px; text-align: center; color: var(--zx-text-light);
  font-size: 11px; opacity: 0.75; letter-spacing: 0.5px;
}

/* === 顶部紧迫提示条 / 中部抽奖卡 — 默认隐藏，tpl4 启用 === */
.zx-top-notice { display: none; }
.zx-mid-cta { display: none; }

/* === 固定底部 CTA（升级版：金边发光呼吸） === */
.zx-submit {
  position: fixed; bottom: 0; left: 50%; transform: translateX(-50%);
  width: 100%; max-width: 540px; height: 60px;
  background: var(--zx-cta-bg);
  background-size: 200% 100%;
  color: #fff; border: 0;
  font-size: 19px; font-weight: 800; z-index: 100;
  padding-bottom: env(safe-area-inset-bottom);
  display: flex; align-items: center; justify-content: center; gap: 6px;
  animation: zx-shimmer 3s linear infinite;
  box-shadow: 0 -4px 16px rgba(220, 20, 60, .35);
  letter-spacing: 1px;
}
.zx-submit:active { filter: brightness(0.9); }
.zx-submit:disabled { filter: brightness(0.7); opacity: 0.7; }
/* Round 33: 字段验证错误时短暂红边脉冲 */
.zx-row-error,
.zx-sku-list.zx-row-error,
.zx-area.zx-row-error {
  animation: zx-row-shake 0.5s ease-in-out;
  outline: 2px solid #f44336;
  outline-offset: 2px;
  border-radius: 6px;
}
@keyframes zx-row-shake {
  0%, 100% { transform: translateX(0); }
  20% { transform: translateX(-6px); }
  40% { transform: translateX(6px); }
  60% { transform: translateX(-3px); }
  80% { transform: translateX(3px); }
}
/* 提交中：圆环 spinner + 文案 */
.zx-submit-loading {
  display: inline-flex; align-items: center; gap: 8px;
}
.zx-submit-spinner {
  width: 18px; height: 18px;
  border: 2.5px solid rgba(255,255,255,.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: zx-spin-icon 0.7s linear infinite;
}
.zx-submit::before {
  content: '🔥'; font-size: 18px;
}
