/* ============================================================
   渝快采 · 阳光直采采购商城  —  全局设计系统
   重庆市政府采购直采服务平台 (示例 / Demo)
   ============================================================ */

:root {
  /* 品牌主色 */
  --brand: #2b6cf6;
  --brand-dark: #1c5be0;
  --brand-deep: #0c44b4;
  --brand-light: #e8f1ff;
  --brand-lighter: #f2f7ff;
  --brand-50: #f4f8ff;

  /* 辅助色 */
  --accent: #ff8a1e;
  --accent-dark: #f5750a;
  --price: #fa3534;
  --price-2: #ff6a00;

  /* 语义色 */
  --success: #19be6b;
  --success-bg: #e8f9f0;
  --warning: #ff9900;
  --warning-bg: #fff7e8;
  --danger: #ed3f3f;
  --danger-bg: #fef0f0;
  --info: #909399;

  /* 文本 */
  --text-1: #1f2329;
  --text-2: #4e5969;
  --text-3: #86909c;
  --text-4: #c9cdd4;

  /* 线条 / 背景 */
  --border: #e5e6eb;
  --border-2: #ebeef5;
  --border-3: #f0f2f5;
  --bg: #f4f6fa;
  --bg-2: #f7f9fc;
  --bg-3: #fafbfd;
  --card: #ffffff;

  --radius: 4px;
  --radius-lg: 8px;
  --shadow: 0 2px 12px rgba(0, 21, 41, 0.06);
  --shadow-hover: 0 6px 20px rgba(43, 108, 246, 0.16);
  --container: 1200px;

  /* Element Plus 主题对齐 */
  --el-color-primary: #2b6cf6;
  --el-color-success: #19be6b;
  --el-color-warning: #ff9900;
  --el-color-danger: #ed3f3f;
  --el-border-radius-base: 4px;
  --el-font-size-base: 13px;
}

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--text-1);
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC",
    "Hiragino Sans GB", "Microsoft YaHei", "微软雅黑", Arial, sans-serif;
  font-size: 13px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}

a { color: inherit; text-decoration: none; }
a:hover { color: var(--brand); }
img { display: block; max-width: 100%; }
ul, li { list-style: none; margin: 0; padding: 0; }
p { margin: 0; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: #d4d7de; border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: #c0c4cc; }

/* 通用布局 */
.ykc-container { width: var(--container); margin: 0 auto; }
.flex { display: flex; }
.flex-c { display: flex; align-items: center; }
.flex-b { display: flex; align-items: center; justify-content: space-between; }
.flex-1 { flex: 1; min-width: 0; }
.gap-4 { gap: 4px; } .gap-8 { gap: 8px; } .gap-12 { gap: 12px; }
.gap-16 { gap: 16px; } .gap-20 { gap: 20px; } .gap-24 { gap: 24px; }
.muted { color: var(--text-3); }
.muted-2 { color: var(--text-2); }
.strong { font-weight: 600; }
.nowrap { white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.clamp-2 { display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.clamp-1 { display: -webkit-box; -webkit-line-clamp: 1; -webkit-box-orient: vertical; overflow: hidden; }
.pointer { cursor: pointer; }
.text-brand { color: var(--brand); }
.text-price { color: var(--price); }
.text-success { color: var(--success); }
.text-warning { color: var(--warning); }
.text-danger { color: var(--danger); }

.price { color: var(--price); font-weight: 700; font-family: Arial, sans-serif; }
.price .sym { font-size: 0.72em; }
.price-old { color: var(--text-4); text-decoration: line-through; font-weight: 400; }

/* 卡片 */
.card { background: var(--card); border-radius: var(--radius-lg); border: 1px solid var(--border-2); }
.card-pad { padding: 16px 18px; }
.panel { background: var(--card); border-radius: var(--radius-lg); box-shadow: var(--shadow); }

.sec-title { display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.sec-title .t { font-size: 19px; font-weight: 700; color: var(--text-1); position: relative; padding-left: 12px; }
.sec-title .t::before { content: ""; position: absolute; left: 0; top: 3px; bottom: 3px; width: 4px; border-radius: 2px; background: var(--brand); }
.sec-title .sub { color: var(--text-3); font-size: 12px; margin-left: 10px; font-weight: 400; }
.sec-title .more { color: var(--text-3); font-size: 13px; cursor: pointer; }
.sec-title .more:hover { color: var(--brand); }

.panel-head { display: flex; align-items: center; justify-content: space-between; padding: 12px 16px; border-bottom: 1px solid var(--border-2); }
.panel-head .ph-t { font-size: 15px; font-weight: 600; position: relative; padding-left: 10px; }
.panel-head .ph-t::before { content: ""; position: absolute; left: 0; top: 2px; bottom: 2px; width: 3px; border-radius: 2px; background: var(--brand); }
.panel-head .ph-more { font-size: 12px; color: var(--text-3); cursor: pointer; }
.panel-head .ph-more:hover { color: var(--brand); }

/* 标签 / 徽章 */
.tag { display: inline-flex; align-items: center; height: 20px; padding: 0 7px; border-radius: 2px; font-size: 12px; line-height: 1; }
.tag-blue { background: var(--brand-light); color: var(--brand); }
.tag-orange { background: #fff3e6; color: var(--accent-dark); }
.tag-green { background: var(--success-bg); color: var(--success); }
.tag-red { background: var(--danger-bg); color: var(--danger); }
.tag-gray { background: #f2f3f5; color: var(--text-3); }
.tag-line-blue { border: 1px solid var(--brand); color: var(--brand); background: #fff; }
.tag-line-red { border: 1px solid #f7b2b2; color: var(--danger); background: #fff; }

/* 已缴保证金 · 高亮金黄色诚信标识（金属质感 + 流光闪烁动画） */
.tag-deposit {
  position: relative; overflow: hidden; padding: 0 9px; border-radius: 10px;
  color: #6b3d00; font-weight: 700; border: 1px solid #f3c552;
  background: linear-gradient(135deg, #ffe9a8 0%, #ffd25e 42%, #f7ab1f 100%);
  box-shadow: 0 1px 5px rgba(240, 165, 25, .5);
  animation: depositGlow 2.4s ease-in-out infinite;
}
.tag-deposit .el-icon { color: #b9700a; }
.tag-deposit::after {
  content: ""; position: absolute; top: 0; left: -75%; width: 45%; height: 100%;
  background: linear-gradient(100deg, transparent 0%, rgba(255, 255, 255, .9) 50%, transparent 100%);
  transform: skewX(-20deg); animation: depositShine 2.8s ease-in-out infinite;
}
@keyframes depositShine { 0% { left: -75%; } 50% { left: 135%; } 100% { left: 135%; } }
@keyframes depositGlow {
  0%, 100% { box-shadow: 0 1px 5px rgba(240, 165, 25, .45); }
  50% { box-shadow: 0 1px 11px rgba(247, 171, 31, .85); }
}
/* 列表/卡片里的金色奖章小图标：轻微金光呼吸 */
.deposit-medal { color: #f5a623 !important; animation: depositMedal 2.4s ease-in-out infinite; transform-origin: center; }
@keyframes depositMedal {
  0%, 100% { filter: drop-shadow(0 0 0 rgba(245, 166, 35, 0)); transform: scale(1); }
  50% { filter: drop-shadow(0 0 3px rgba(245, 166, 35, .9)); transform: scale(1.14); }
}
@media (prefers-reduced-motion: reduce) {
  .tag-deposit, .tag-deposit::after, .deposit-medal { animation: none; }
}

/* 保证金弹窗 · 缴纳前后「展示位置变化」对比动画 */
.dep-demo { display: flex; align-items: stretch; gap: 8px; }
.dep-card { flex: 1; min-width: 0; border-radius: 8px; padding: 10px 12px; border: 1px solid var(--border-2); background: #fff; }
.dep-card.before { opacity: .9; }
.dep-card.after { border-color: #f3c552; background: linear-gradient(135deg, #fffdf6, #fff6e3); animation: depAfterGlow 2.4s ease-in-out infinite; }
.dep-logo { width: 22px; height: 22px; border-radius: 6px; color: #fff; display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; flex-shrink: 0; }
.dep-arrow { display: flex; align-items: center; color: #f5a623; flex-shrink: 0; animation: depArrow 1.2s ease-in-out infinite; }
.dep-rankup { display: inline-flex; align-items: center; color: #19be6b; font-weight: 700; animation: depRankUp 1.4s ease-in-out infinite; }
@keyframes depAfterGlow { 0%, 100% { box-shadow: 0 2px 6px rgba(240, 165, 25, .18); } 50% { box-shadow: 0 4px 16px rgba(247, 171, 31, .48); } }
@keyframes depArrow { 0%, 100% { transform: translateX(0); } 50% { transform: translateX(5px); } }
@keyframes depRankUp { 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-3px); } }
@media (prefers-reduced-motion: reduce) { .dep-card.after, .dep-arrow, .dep-rankup { animation: none; } }

.dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--brand); }
.badge-dot { position: relative; }
.badge-dot::after { content: ""; position: absolute; top: -2px; right: -8px; width: 7px; height: 7px; background: var(--danger); border-radius: 50%; }

/* ============================ 顶部页头 ============================ */
.app-header { background: #fff; box-shadow: 0 1px 0 rgba(0,0,0,0.04); position: relative; z-index: 20; }
.app-header-top { width: var(--container); margin: 0 auto; display: flex; align-items: center; height: 88px; gap: 22px; flex-wrap: nowrap; }

.app-logo { display: flex; align-items: center; gap: 12px; cursor: pointer; flex-shrink: 0; }
.app-logo .name, .app-logo .slogan, .app-logo .platform { white-space: nowrap; }
.app-logo > div { white-space: nowrap; }
.app-logo .badge { width: 46px; height: 46px; border-radius: 9px; background: linear-gradient(135deg, var(--brand) 0%, var(--brand-deep) 100%);
  color: #fff; font-size: 22px; font-weight: 700; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 10px rgba(28,91,224,0.3); }
.app-logo .name { font-size: 27px; font-weight: 800; color: var(--brand); letter-spacing: 1px; line-height: 1.1; }
.app-logo .slogan { font-size: 15px; color: var(--text-2); font-weight: 600; margin-left: 8px; }
.app-logo .platform { font-size: 11px; color: var(--text-3); margin-top: 2px; }

.app-search { flex: 1 1 auto; min-width: 240px; max-width: 540px; }
.search-box { display: flex; align-items: center; height: 40px; border: 2px solid var(--brand); border-radius: 3px; overflow: hidden; background: #fff; }
.search-cat { display: flex; align-items: center; gap: 3px; padding: 0 12px; height: 100%; color: var(--text-2); font-size: 13px; border-right: 1px solid var(--border); cursor: pointer; white-space: nowrap; }
.search-input { flex: 1; border: 0; outline: 0; height: 100%; padding: 0 12px; font-size: 13px; color: var(--text-1); }
.search-btn { display: flex; align-items: center; gap: 4px; height: 100%; padding: 0 22px; background: var(--brand); color: #fff; font-size: 14px; border: 0; cursor: pointer; font-weight: 500; }
.search-btn:hover { background: var(--brand-dark); }
.search-hot { margin-top: 6px; font-size: 12px; color: var(--text-3); display: flex; gap: 12px; }
.search-hot a:hover { color: var(--brand); }

.header-right { display: flex; align-items: center; gap: 16px; margin-left: auto; flex-shrink: 0; }
.header-links { display: flex; align-items: center; gap: 13px; font-size: 13px; color: var(--text-2); flex-shrink: 0; white-space: nowrap; }
.header-links a { display: flex; align-items: center; gap: 3px; }
.header-links .sep { color: var(--border); }
.header-auth { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.header-user { display: flex; align-items: center; gap: 8px; cursor: pointer; flex-shrink: 0; max-width: 230px; }
.header-user .hu-name { line-height: 1.2; overflow: hidden; }
.header-user .hu-company { font-size: 13px; color: var(--text-1); max-width: 150px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.header-user .hu-sub { font-size: 11px; color: var(--text-3); white-space: nowrap; }
.header-user .avatar { width: 30px; height: 30px; border-radius: 50%; background: var(--brand-light); color: var(--brand); display: flex; align-items: center; justify-content: center; font-size: 14px; }

/* ============================ 主导航 ============================ */
.main-nav { background: #fff; border-bottom: 2px solid var(--brand); }
.main-nav-inner { width: var(--container); margin: 0 auto; display: flex; align-items: stretch; height: 46px; }
.nav-all { width: 200px; background: var(--brand); color: #fff; display: flex; align-items: center; justify-content: center; gap: 8px; font-size: 16px; font-weight: 600; cursor: pointer; }
.nav-items { display: flex; align-items: stretch; flex: 1; }
.nav-item { display: flex; align-items: center; padding: 0 22px; font-size: 16px; color: var(--text-1); cursor: pointer; position: relative; font-weight: 500; }
.nav-item:hover { color: var(--brand); }
.nav-item.active { color: var(--brand); font-weight: 700; }
.nav-item.active::after { content: ""; position: absolute; left: 22px; right: 22px; bottom: -2px; height: 3px; background: var(--brand); border-radius: 2px; }

/* ============================ 页脚 ============================ */
.app-footer { background: #fff; margin-top: 36px; border-top: 1px solid var(--border-2); }
.footer-features { width: var(--container); margin: 0 auto; display: flex; justify-content: space-around; padding: 26px 0; border-bottom: 1px solid var(--border-2); }
.footer-feature { display: flex; align-items: center; gap: 12px; }
.footer-feature .fi { width: 40px; height: 40px; border-radius: 50%; background: var(--brand-light); color: var(--brand); display: flex; align-items: center; justify-content: center; font-size: 22px; }
.footer-feature .ft { font-size: 15px; font-weight: 600; color: var(--text-1); }
.footer-feature .fs { font-size: 12px; color: var(--text-3); }
.footer-links { width: var(--container); margin: 0 auto; padding: 24px 0; display: flex; gap: 60px; border-bottom: 1px solid var(--border-2); }
.footer-col h4 { font-size: 14px; color: var(--text-1); margin: 0 0 12px; }
.footer-col a { display: block; font-size: 13px; color: var(--text-3); line-height: 2; }
.footer-bottom { background: #f7f9fc; }
.footer-bottom-inner { width: var(--container); margin: 0 auto; padding: 18px 0; text-align: center; color: var(--text-3); font-size: 12px; line-height: 1.9; }
.footer-bottom-inner .org { color: var(--text-2); }
.gov-badges { display: flex; justify-content: center; gap: 14px; margin-top: 8px; }
.gov-badge { display: flex; align-items: center; gap: 5px; padding: 4px 10px; border: 1px solid var(--border); border-radius: 3px; font-size: 12px; color: var(--text-3); }
.gov-badge.red { color: var(--danger); }

/* ============================ 控制台布局 (左侧菜单) ============================ */
.console { width: var(--container); margin: 16px auto; display: flex; gap: 16px; align-items: flex-start; }
.console-side { width: 168px; flex-shrink: 0; background: #fff; border-radius: var(--radius-lg); box-shadow: var(--shadow); overflow: hidden; }
.console-menu-item { display: flex; align-items: center; gap: 10px; height: 48px; padding: 0 20px; font-size: 14px; color: var(--text-2); cursor: pointer; position: relative; border-left: 3px solid transparent; }
.console-menu-item .el-icon { font-size: 17px; }
.console-menu-item:hover { background: var(--brand-50); color: var(--brand); }
.console-menu-item.active { background: var(--brand-light); color: var(--brand); border-left-color: var(--brand); font-weight: 600; }
.console-menu-item .m-dot { position: absolute; top: 13px; left: 30px; width: 6px; height: 6px; background: var(--danger); border-radius: 50%; }
.console-body { flex: 1; min-width: 0; }
.console-contact { margin-top: 14px; padding: 16px; background: linear-gradient(135deg,#3a78ff,#2b6cf6); border-radius: var(--radius-lg); color: #fff; text-align: center; }
.console-contact .ct-label { font-size: 12px; opacity: .9; }
.console-contact .ct-phone { font-size: 19px; font-weight: 700; margin: 4px 0; }

/* 控制台页头条 */
.console-pagehead { background: #fff; border-radius: var(--radius-lg); padding: 14px 20px; box-shadow: var(--shadow); display: flex; align-items: center; justify-content: space-between; margin-bottom: 14px; }
.console-pagehead .cph-t { font-size: 17px; font-weight: 700; }
.console-pagehead .cph-sub { font-size: 12px; color: var(--text-3); margin-top: 2px; }

/* 统计小卡 */
.stat-mini { display: flex; flex-direction: column; align-items: center; justify-content: center; padding: 14px 6px; border-radius: var(--radius); }
.stat-mini .num { font-size: 22px; font-weight: 700; font-family: Arial; }
.stat-mini .lbl { font-size: 12px; color: var(--text-3); margin-top: 4px; }

.stat-card { background: #fff; border-radius: var(--radius-lg); padding: 18px 20px; box-shadow: var(--shadow); display: flex; align-items: center; gap: 14px; }
.stat-card .sc-icon { width: 46px; height: 46px; border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 24px; }
.stat-card .sc-num { font-size: 24px; font-weight: 700; font-family: Arial; line-height: 1.1; }
.stat-card .sc-lbl { font-size: 13px; color: var(--text-3); margin-top: 2px; }

/* 商品卡片 */
.prod-card { background: #fff; border: 1px solid var(--border-2); border-radius: var(--radius-lg); overflow: hidden; cursor: pointer; transition: all .2s; display: flex; flex-direction: column; }
.prod-card:hover { border-color: var(--brand); box-shadow: var(--shadow-hover); transform: translateY(-2px); }
.prod-card .pc-img { height: 172px; background: #fff; display: flex; align-items: center; justify-content: center; overflow: hidden; }
.prod-card .pc-img img { width: 100%; height: 100%; object-fit: contain; }
.proj-card { transition: all .2s; }
.proj-card:hover { border-color: var(--brand); box-shadow: var(--shadow-hover); transform: translateY(-2px); }
.prod-card .pc-img img { max-height: 100%; object-fit: contain; }
.prod-card .pc-body { padding: 10px 12px 14px; display: flex; flex-direction: column; gap: 7px; }
.prod-card .pc-price { display: flex; align-items: baseline; gap: 8px; }
.prod-card .pc-price .price { font-size: 19px; }
.prod-card .pc-title { font-size: 13px; color: var(--text-1); line-height: 1.45; height: 38px; }
.prod-card .pc-title:hover { color: var(--brand); }
.prod-card .pc-meta { display: flex; align-items: center; justify-content: space-between; font-size: 12px; color: var(--text-3); }
.prod-card .pc-tags { display: flex; gap: 5px; flex-wrap: wrap; }
.prod-card .pc-shop { font-size: 12px; color: var(--text-3); display: flex; align-items: center; gap: 4px; }

/* 通用图标块 */
.icon-tile { display: flex; flex-direction: column; align-items: center; gap: 8px; cursor: pointer; }
.icon-tile .it-icon { width: 50px; height: 50px; border-radius: 12px; background: var(--brand-light); color: var(--brand); display: flex; align-items: center; justify-content: center; font-size: 26px; }
.icon-tile .it-label { font-size: 13px; color: var(--text-2); }
.icon-tile:hover .it-label { color: var(--brand); }

/* 列表行 */
.list-row { display: flex; align-items: center; padding: 9px 0; font-size: 13px; border-bottom: 1px dashed var(--border-2); }
.list-row:last-child { border-bottom: 0; }
.list-row .lr-rank { width: 18px; height: 18px; border-radius: 3px; background: #f2f3f5; color: var(--text-3); font-size: 12px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; margin-right: 8px; }
.list-row .lr-rank.top { background: var(--price); color: #fff; }
.list-row .lr-title { flex: 1; color: var(--text-2); }
.list-row:hover .lr-title { color: var(--brand); cursor: pointer; }

/* 筛选条 */
.filter-bar { background: #fff; border-radius: var(--radius-lg); box-shadow: var(--shadow); padding: 4px 0; margin-bottom: 14px; }
.filter-row { display: flex; align-items: flex-start; padding: 11px 18px; border-bottom: 1px dashed var(--border-2); font-size: 13px; }
.filter-row:last-child { border-bottom: 0; }
.filter-row .fr-label { width: 84px; color: var(--text-3); flex-shrink: 0; padding-top: 2px; }
.filter-row .fr-opts { display: flex; flex-wrap: wrap; gap: 6px 18px; flex: 1; }
.filter-row .fr-opt { color: var(--text-2); cursor: pointer; padding: 1px 8px; border-radius: 3px; }
.filter-row .fr-opt:hover { color: var(--brand); }
.filter-row .fr-opt.active { background: var(--brand); color: #fff; }

/* 面包屑 */
.crumb { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-3); padding: 12px 0; }
.crumb a:hover { color: var(--brand); }

/* 分类侧栏 (商城) */
.cat-side { width: 200px; flex-shrink: 0; background: #fff; border: 1px solid var(--border-2); border-radius: var(--radius); }
.cat-side-item { display: flex; align-items: center; justify-content: space-between; padding: 9px 16px; font-size: 13px; color: var(--text-2); cursor: pointer; }
.cat-side-item:hover { background: var(--brand-light); color: var(--brand); }
.cat-side-item .cs-name { display: flex; align-items: center; gap: 8px; }
.cat-side-item.active { color: var(--brand); background: var(--brand-50); }

/* 进度时间线小圆点 */
.steps-flow { display: flex; align-items: flex-start; justify-content: space-between; }
.step-node { flex: 1; display: flex; flex-direction: column; align-items: center; text-align: center; position: relative; }
.step-node .sn-ico { width: 48px; height: 48px; border-radius: 50%; background: var(--brand-light); color: var(--brand); display: flex; align-items: center; justify-content: center; font-size: 24px; margin-bottom: 8px; z-index: 1; }
.step-node .sn-t { font-size: 14px; font-weight: 600; color: var(--text-1); }
.step-node .sn-d { font-size: 12px; color: var(--text-3); margin-top: 2px; }
.step-node::after { content: ""; position: absolute; top: 24px; left: 50%; width: 100%; height: 2px; background: var(--border); z-index: 0; }
.step-node:last-child::after { display: none; }

/* 工具：网格 */
.grid { display: grid; gap: 14px; }
.grid-2 { grid-template-columns: repeat(2, 1fr); }
.grid-3 { grid-template-columns: repeat(3, 1fr); }
.grid-4 { grid-template-columns: repeat(4, 1fr); }
.grid-5 { grid-template-columns: repeat(5, 1fr); }
.grid-6 { grid-template-columns: repeat(6, 1fr); }

/* 空状态占位图（无图片时的占位） */
.ph-img { width: 100%; height: 100%; display: flex; align-items: center; justify-content: center; color: var(--text-4); font-size: 30px; background: linear-gradient(135deg,#f5f7fa,#eef1f6); }

/* 主内容区背景包裹 */
.page { min-height: 60vh; }
.page-mall { background: var(--bg); padding-bottom: 30px; }

/* Element Plus 局部微调 */
.el-button--primary { --el-button-bg-color: var(--brand); --el-button-border-color: var(--brand);
  --el-button-hover-bg-color: var(--brand-dark); --el-button-hover-border-color: var(--brand-dark); }
.el-table th.el-table__cell { background: var(--bg-2) !important; color: var(--text-2); font-weight: 600; }
.el-tabs__item.is-active { color: var(--brand); }
.el-tabs__active-bar { background: var(--brand); }

/* 价格条幅 */
.price-banner { background: linear-gradient(90deg,#fff6f0,#fff); border: 1px solid #ffe0c7; border-radius: var(--radius); padding: 14px 18px; display: flex; align-items: center; gap: 16px; }

/* 倒计时块 */
.countdown { display: flex; gap: 6px; align-items: center; }
.countdown .cd-num { background: var(--text-1); color: #fff; border-radius: 3px; padding: 3px 7px; font-size: 16px; font-family: Arial; font-weight: 700; min-width: 30px; text-align: center; }
.countdown .cd-sep { color: var(--text-1); font-weight: 700; }

/* 通用按钮（非EP） */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 5px; height: 34px; padding: 0 18px; border-radius: var(--radius); font-size: 14px; cursor: pointer; border: 1px solid var(--border); background: #fff; color: var(--text-2); }
.btn:hover { color: var(--brand); border-color: var(--brand); }
.btn-primary { background: var(--brand); border-color: var(--brand); color: #fff; }
.btn-primary:hover { background: var(--brand-dark); color: #fff; }
.btn-accent { background: var(--accent); border-color: var(--accent); color: #fff; }
.btn-accent:hover { background: var(--accent-dark); color: #fff; }
.btn-lg { height: 44px; padding: 0 30px; font-size: 16px; }
.btn-block { width: 100%; }
