/* cms 主题 · Figma 1:1 华军/ZOL 式蓝色门户 · 骨架 C 轮播+横滑榜 */
:root {
  --cms-primary: #1565c0;
  --cms-primary-dark: #0d47a1;
  --cms-primary-light: #e3f2fd;
  --cms-red: #e53935;
  --cms-orange: #ff6d00;
  --cms-amber: #ffa000;
  --cms-green: #43a047;
  --cms-green-dark: #2e7d32;
  --cms-bg: #f0f2f5;
  --cms-topbar: #0d1b2a;
  --cms-footer: #1a2332;
  --cms-text: #1f2937;
  --cms-muted: #6b7280;
  --cms-border: #f3f4f6;
  --cms-white: #fff;
  --cms-radius: 8px;
  --cms-radius-lg: 12px;
  --cms-shadow: 0 1px 3px rgba(21,101,192,.08);
  --cms-wrap: 1280px;
  --cms-font: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "Microsoft YaHei", sans-serif;
}

*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font: 14px/1.6 var(--cms-font);
  color: var(--cms-text);
  background: var(--cms-bg);
  overflow-x: hidden;
}
img { max-width: 100%; height: auto; vertical-align: middle; }
a { color: var(--cms-primary); text-decoration: none; }
a:hover { color: var(--cms-primary-dark); }
ul, ol { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, h4, p { margin: 0; }

.cms-wrap { max-width: var(--cms-wrap); margin: 0 auto; padding: 0 12px; }
@media (min-width:640px) { .cms-wrap { padding: 0 16px; } }
@media (min-width:1024px) { .cms-wrap { padding: 0 24px; } }

.cms-clamp1 { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cms-clamp2 {
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
  overflow: hidden;
}

/* 顶栏 */
.cms-topbar {
  background: var(--cms-topbar);
  color: #9ca3af;
  font-size: 11px;
}
.cms-topbar .cms-wrap {
  display: flex; align-items: center; justify-content: space-between;
  height: 28px; gap: 8px;
}
.cms-topbar a { color: #9ca3af; margin-left: 12px; }
.cms-topbar a:hover { color: #fff; }

/* 头部 */
.cms-head { background: var(--cms-white); border-bottom: 1px solid var(--cms-border); }
.cms-head .cms-wrap {
  display: flex; align-items: center; gap: 10px 12px;
  padding-top: 10px; padding-bottom: 10px; flex-wrap: wrap;
}
.cms-logo {
  display: flex; align-items: center; gap: 8px;
  color: inherit; flex-shrink: 0;
}
.cms-logo-mark {
  width: 36px; height: 36px;
  background: var(--cms-primary);
  border-radius: var(--cms-radius);
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 16px; flex-shrink: 0;
}
.cms-logo b { font-size: 18px; font-weight: 900; color: var(--cms-primary); line-height: 1.1; }
.cms-logo small { display: block; font-size: 11px; color: var(--cms-muted); font-weight: 400; }

/* 搜索（form 直接带 .cms-search 类，容器为 .cms-search-wrap） */
.cms-search-wrap { flex: 1 1 240px; min-width: 0; max-width: 560px; }
.cms-search,
.cms-search-wrap .cms-search { display: flex; width: 100%; }
.cms-search input {
  flex: 1 1 auto; min-width: 0; width: 100%;
  border: 1px solid #d1d5db; border-right: 0;
  border-radius: 6px 0 0 6px;
  padding: 0 12px; height: 38px; font-size: 13px; outline: none;
  background: #fff;
}
.cms-search input:focus { border-color: var(--cms-primary); }
.cms-search button {
  flex: 0 0 auto;
  border: 0; background: var(--cms-primary); color: #fff;
  padding: 0 18px; height: 38px; border-radius: 0 6px 6px 0;
  font-size: 13px; font-weight: 500; cursor: pointer;
  white-space: nowrap;
}
.cms-search button:hover { background: var(--cms-primary-dark); }

.cms-search-hot {
  display: flex; align-items: center; flex-wrap: wrap; gap: 4px 8px;
  margin-top: 6px; font-size: 11px; line-height: 1.4; overflow: hidden; max-height: 1.6em;
}
.cms-search-hot-label { color: var(--cms-muted); flex-shrink: 0; }
.cms-search-hot a {
  color: #4b5563; max-width: 84px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.cms-search-hot a:first-of-type { color: var(--cms-red); }
.cms-search-hot a:hover { color: var(--cms-primary); }

.cms-head-extra { display: none; gap: 8px; flex-shrink: 0; }
@media (min-width:1024px) { .cms-head-extra { display: flex; } }
.cms-btn-ghost {
  border: 1px solid #d1d5db; color: var(--cms-muted);
  padding: 8px 12px; border-radius: 6px; font-size: 12px; white-space: nowrap;
}
.cms-btn-ghost:hover { border-color: var(--cms-primary); color: var(--cms-primary); }

.cms-nav-toggle {
  display: flex; align-items: center; justify-content: center;
  border: 1px solid #d1d5db; background: #fff;
  width: 38px; height: 38px; border-radius: 6px;
  font-size: 18px; cursor: pointer; flex-shrink: 0;
}
@media (min-width:768px) { .cms-nav-toggle { display: none; } }

/* 移动端头部：logo 占首行左、汉堡靠右，搜索整行换到第二行 */
@media (max-width:767px) {
  .cms-logo { flex: 1 1 auto; }
  .cms-search-wrap { order: 3; flex: 1 1 100%; max-width: none; }
}

/* 主导航 */
.cms-nav { background: var(--cms-primary); }
.cms-nav .cms-wrap { display: flex; align-items: stretch; }
.cms-nav a, .cms-nav .cms-nav-cat-btn {
  color: rgba(255,255,255,.92);
  padding: 12px 18px; font-size: 14px; font-weight: 500; line-height: 1;
  transition: background .15s; display: flex; align-items: center;
}
.cms-nav a:hover, .cms-nav a.current { background: var(--cms-primary-dark); color: #fff; }

/* 软件分类（巨型菜单触发器）—— 独立深色块 + 右分隔，避免与"首页"贴死 */
.cms-nav-cat { position: relative; margin-right: 4px; }
.cms-nav-cat-btn {
  gap: 8px; background: var(--cms-primary-dark); border: 0; cursor: pointer; color: #fff;
  font-weight: 700; white-space: nowrap;
}
.cms-nav-cat-btn svg { flex-shrink: 0; }
.cms-nav-drop {
  display: none; position: absolute; top: 100%; left: 0;
  min-width: 200px; background: #fff; box-shadow: 0 10px 28px rgba(0,0,0,.16);
  border-radius: 0 0 var(--cms-radius) var(--cms-radius);
  border-top: 3px solid var(--cms-primary); z-index: 50; padding: 6px 0; overflow: hidden;
}
.cms-nav-cat:hover .cms-nav-drop,
.cms-nav-cat.cms-open .cms-nav-drop { display: block; }
.cms-nav-cat-btn::after {
  content: ""; width: 8px; height: 8px; margin-left: 2px; flex-shrink: 0;
  border-right: 2px solid currentColor; border-bottom: 2px solid currentColor;
  transform: rotate(45deg) translateY(-2px); transition: transform .2s;
}
.cms-nav-cat.cms-open .cms-nav-cat-btn::after { transform: rotate(-135deg) translateY(0); }
.cms-nav-drop a {
  display: block; color: var(--cms-text); padding: 10px 18px; font-size: 13px;
}
.cms-nav-drop a:hover { background: var(--cms-primary-light); color: var(--cms-primary); padding-left: 22px; }
.cms-nav-badge {
  margin-left: auto; align-self: center; font-size: 10px;
  background: var(--cms-red); color: #fff;
  padding: 3px 8px; border-radius: 4px; flex-shrink: 0;
}

/* 桌面端：横向单行，溢出可横滑兜底；中屏隐藏右侧徽标 */
@media (min-width:768px) {
  .cms-nav .cms-wrap { flex-wrap: nowrap; overflow-x: auto; scrollbar-width: none; }
  .cms-nav .cms-wrap::-webkit-scrollbar { display: none; }
  .cms-nav > .cms-wrap > a { white-space: nowrap; }
}
@media (min-width:768px) and (max-width:1023px) {
  .cms-nav-badge { display: none; }
  .cms-nav a, .cms-nav .cms-nav-cat-btn { padding: 12px 14px; }
}

/* 移动端：汉堡折叠为竖向堆叠；隐藏巨型菜单触发器（分类已在下方平铺） */
@media (max-width:767px) {
  .cms-nav { display: none; }
  .cms-nav.open { display: block; }
  .cms-nav .cms-wrap { display: block; padding-top: 4px; padding-bottom: 8px; }
  .cms-nav > .cms-wrap > a {
    display: block; padding: 12px 4px; border-bottom: 1px solid rgba(255,255,255,.12);
  }
  .cms-nav > .cms-wrap > a:last-of-type { border-bottom: 0; }
  .cms-nav-badge { display: none; }
  /* 移动端：软件分类做成手风琴（静态内联下拉，点击展开） */
  .cms-nav .cms-nav-cat { display: block; position: static; margin-right: 0; }
  .cms-nav .cms-nav-cat-btn {
    width: 100%; justify-content: flex-start; padding: 12px 4px;
    background: transparent; border-bottom: 1px solid rgba(255,255,255,.12);
  }
  .cms-nav .cms-nav-drop {
    position: static; width: 100%; box-shadow: none; border-radius: 0;
    border-top: 0; padding: 0; background: rgba(0,0,0,.14); margin-bottom: 4px;
  }
  .cms-nav .cms-nav-drop a { color: rgba(255,255,255,.85); padding-left: 20px; }
  .cms-nav .cms-nav-drop a:hover { background: rgba(0,0,0,.2); color: #fff; }
}

/* 面包屑（统一卡片式，带首页图标） */
.cms-crumb {
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px;
  font-size: 12px; color: var(--cms-muted);
  background: #fff; border: 1px solid var(--cms-border); border-radius: var(--cms-radius);
  padding: 9px 14px; margin-bottom: 12px; line-height: 1.5;
}
.cms-crumb::before {
  content: ""; width: 14px; height: 14px; flex-shrink: 0; margin-right: 2px;
  background: var(--cms-primary);
  -webkit-mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 9l9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/><polyline points='9 22 9 12 15 12 15 22'/></svg>") center/contain no-repeat;
          mask: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M3 9l9-7 9 7v11a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2z'/><polyline points='9 22 9 12 15 12 15 22'/></svg>") center/contain no-repeat;
}
.cms-crumb a { color: var(--cms-muted); }
.cms-crumb a:hover { color: var(--cms-primary); }
.cms-crumb strong { color: var(--cms-text); font-weight: 600; max-width: 60vw; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.cms-crumb-sep { color: #d1d5db; }

/* 区块标题 */
.cms-sec-hd {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 12px;
}
.cms-sec-hd-left { display: flex; align-items: center; gap: 8px; }
.cms-sec-bar {
  width: 4px; height: 20px; border-radius: 2px;
  background: var(--cms-primary); flex-shrink: 0;
}
.cms-sec-hd h2 { font-size: 14px; font-weight: 700; color: #1f2937; }
.cms-sec-sub { font-size: 12px; color: var(--cms-muted); display: none; }
@media (min-width:640px) { .cms-sec-sub { display: inline; margin-left: 4px; } }
.cms-more { font-size: 12px; color: var(--cms-muted); }
.cms-more:hover { color: var(--cms-primary); }

/* 卡片容器 */
.cms-card {
  background: #fff; border: 1px solid var(--cms-border);
  border-radius: var(--cms-radius); overflow: hidden;
}
.cms-card-hd { padding: 10px 16px; border-bottom: 1px solid var(--cms-border); }
.cms-card-bd { padding: 12px; }
.cms-card-hd-blue { background: var(--cms-primary); }
.cms-card-hd-blue span { color: #fff; font-size: 12px; font-weight: 700; }

/* 软件卡片 grid —— minmax(0,1fr) 防止 nowrap 标题撑大轨道导致溢出 */
.cms-soft-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
@media (min-width:640px) { .cms-soft-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }
@media (min-width:1024px) { .cms-soft-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }

.cms-soft-card {
  display: flex; flex-direction: column; min-width: 0;
  background: #fff; border: 1px solid var(--cms-border);
  border-radius: var(--cms-radius); padding: 12px;
  color: inherit; transition: box-shadow .2s, border-color .2s;
}
.cms-soft-card:hover {
  box-shadow: 0 4px 12px rgba(21,101,192,.12);
  border-color: rgba(21,101,192,.3);
}
.cms-soft-card-top { display: flex; gap: 10px; align-items: flex-start; }
.cms-soft-card img, .cms-ico {
  width: 44px; height: 44px; border-radius: var(--cms-radius-lg);
  object-fit: cover; flex-shrink: 0;
}
.cms-soft-card-name {
  font-size: 12px; font-weight: 600; color: #1f2937;
  line-height: 1.3;
}
.cms-soft-card:hover .cms-soft-card-name { color: var(--cms-primary); }
.cms-soft-card-desc { font-size: 10px; color: var(--cms-muted); margin-top: 4px; line-height: 1.5; }
.cms-soft-card-foot {
  margin-top: 8px; padding-top: 8px; border-top: 1px solid #f9fafb;
  display: flex; align-items: center; justify-content: space-between;
  font-size: 10px;
}
.cms-tag-hot, .cms-tag-new {
  font-size: 9px; color: #fff; padding: 1px 4px; border-radius: 3px;
  margin-left: 4px; vertical-align: middle;
}
.cms-tag-hot { background: var(--cms-red); }
.cms-tag-new { background: var(--cms-green); }
.cms-star { color: var(--cms-amber); font-weight: 700; }
.cms-dl-count { color: var(--cms-primary); font-size: 10px; }

/* 横滑 */
.cms-scroll-x {
  display: flex; gap: 8px; overflow-x: auto;
  padding-bottom: 4px; -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.cms-scroll-x::-webkit-scrollbar { display: none; }
.cms-scroll-x .cms-soft-card { width: 128px; min-width: 128px; flex-shrink: 0; overflow: hidden; }
.cms-scroll-x .cms-soft-card-top img { width: 36px; height: 36px; }
.cms-scroll-x .cms-soft-card-name { font-size: 11px; }
.cms-scroll-x .cms-soft-card-desc { font-size: 9px; -webkit-line-clamp: 2; }
.cms-scroll-x .cms-soft-card-foot { font-size: 9px; gap: 4px; }
@media (min-width:640px) {
  .cms-scroll-x { display: none; }
  .cms-scroll-x + .cms-soft-grid { display: grid; }
}
.cms-mobile-only { display: block; }
@media (min-width:640px) { .cms-mobile-only { display: none; } }

/* 列表项 */
.cms-soft-list { display: flex; flex-direction: column; gap: 8px; }
.cms-soft-list li {
  display: flex; gap: 12px; align-items: center;
  background: #fff; border: 1px solid var(--cms-border);
  border-radius: var(--cms-radius); padding: 12px;
  transition: box-shadow .2s, border-color .2s;
}
.cms-soft-list li:hover {
  box-shadow: 0 4px 12px rgba(21,101,192,.1);
  border-color: rgba(21,101,192,.2);
}
.cms-soft-list .cms-cover { width: 52px; height: 52px; border-radius: var(--cms-radius-lg); }
.cms-soft-list-bd { flex: 1; min-width: 0; }
.cms-soft-list-bd h2 { font-size: 14px; font-weight: 600; margin-bottom: 4px; }
.cms-soft-list-bd h2 a { color: inherit; }
.cms-soft-list-bd h2 a:hover { color: var(--cms-primary); }
.cms-soft-meta { font-size: 10px; color: var(--cms-muted); display: flex; flex-wrap: wrap; gap: 8px; }
.cms-soft-meta em { color: var(--cms-text); font-style: normal; }
.cms-soft-desc { font-size: 12px; color: var(--cms-muted); margin-top: 4px; }
.cms-soft-side { text-align: right; flex-shrink: 0; display: none; }
@media (min-width:640px) { .cms-soft-side { display: block; } }
.cms-dl {
  display: inline-block; background: var(--cms-primary); color: #fff !important;
  padding: 6px 14px; border-radius: 6px; font-size: 11px; font-weight: 700;
}
.cms-dl:hover { background: var(--cms-primary-dark); color: #fff !important; }
.cms-dl-lg { padding: 10px 24px; font-size: 14px; }

/* 排行 */
.cms-rank li {
  display: flex; align-items: center; gap: 8px;
  padding: 6px 4px; border-radius: 4px;
}
.cms-rank li:hover { background: #f9fafb; }
.cms-rank-num {
  width: 20px; height: 20px; border-radius: 4px;
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.cms-rank-num.top { background: var(--cms-primary); color: #fff; }
.cms-rank-num.normal { background: var(--cms-bg); color: #9ca3af; }
.cms-rank-ico {
  width: 24px; height: 24px; border-radius: 4px;
  display: flex; align-items: center; justify-content: center;
  font-size: 9px; font-weight: 700; color: #fff; flex-shrink: 0;
}
.cms-rank a { color: var(--cms-text); font-size: 12px; flex: 1; min-width: 0; }
.cms-rank a:hover { color: var(--cms-primary); }

/* 侧栏 */
.cms-side-card { background: #fff; border: 1px solid var(--cms-border); border-radius: var(--cms-radius); overflow: hidden; margin-bottom: 12px; }
.cms-side-hd { padding: 8px 12px; font-size: 12px; font-weight: 700; }
.cms-side-hd-red { background: var(--cms-red); color: #fff; }
.cms-side-hd-orange { background: var(--cms-orange); color: #fff; }
.cms-side-hd-blue { background: var(--cms-primary); color: #fff; }
.cms-side-bd { padding: 8px; }

/* 分页 */
.cms-pager {
  display: flex; align-items: center; justify-content: center;
  flex-wrap: wrap; gap: 6px; margin-top: 20px;
}
.cms-pager span, .cms-pager a {
  min-width: 34px; height: 34px; line-height: 32px;
  text-align: center; font-size: 12px; box-sizing: border-box;
  border: 1px solid #e5e7eb; border-radius: 6px;
  padding: 0 10px; color: var(--cms-muted); background: #fff;
}
.cms-pager a:hover { border-color: var(--cms-primary); color: var(--cms-primary); }
.cms-pager .on { background: var(--cms-primary); border-color: var(--cms-primary); color: #fff; }
.cms-pager .disable { border: 0; background: transparent; color: var(--cms-muted); }
/* 移动端：隐藏"共N页"信息，仅保留可点按的页码，居中不溢出 */
@media (max-width:639px) {
  .cms-pager { gap: 5px; }
  .cms-pager .disable { width: 100%; min-width: 0; height: auto; line-height: 1.6; padding: 0; margin-bottom: 2px; font-size: 11px; }
  .cms-pager span:not(.disable), .cms-pager a { min-width: 32px; height: 32px; line-height: 30px; padding: 0 8px; }
}

/* 选项卡 */
[data-tabs] [data-tab] { cursor: pointer; }
[data-tabs] [data-panel] { display: none; }
[data-tabs] [data-panel].on { display: block; }
[data-tabs] .cms-tab-hd { display: flex; border-bottom: 1px solid var(--cms-border); }
[data-tabs] [data-tab] {
  padding: 12px 16px; font-size: 12px; font-weight: 600;
  color: var(--cms-muted); border-bottom: 2px solid transparent; cursor: pointer;
}
[data-tabs] [data-tab].on { color: var(--cms-primary); border-bottom-color: var(--cms-primary); }

/* 页脚 */
.cms-foot {
  background: var(--cms-footer); color: #9ca3af;
  margin-top: 24px; font-size: 11px;
}
.cms-foot .cms-wrap { padding-top: 24px; padding-bottom: 24px; }
.cms-foot-grid {
  display: grid; grid-template-columns: 1fr;
  gap: 20px; margin-bottom: 20px;
}
@media (min-width:640px) { .cms-foot-grid { grid-template-columns: repeat(3, 1fr); } }
.cms-foot-col h4 { color: #90caf9; font-size: 12px; margin-bottom: 8px; }
.cms-foot-col a { display: block; color: #6b7280; margin-bottom: 6px; font-size: 11px; }
.cms-foot-col a:hover { color: #90caf9; }
.cms-foot-nav { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 12px; }
.cms-foot-nav a { color: #9ca3af; }
.cms-foot-nav a:hover { color: #fff; }
.cms-foot p { line-height: 1.8; }
.cms-foot b { color: #e5e7eb; }

.cms-top {
  position: fixed; right: 16px; bottom: 16px;
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--cms-primary); color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; cursor: pointer; opacity: 0; visibility: hidden;
  transition: opacity .2s; z-index: 99; box-shadow: 0 4px 12px rgba(21,101,192,.3);
}
.cms-top.show { opacity: 1; visibility: visible; }

/* 布局 */
.cms-layout { display: flex; gap: 12px; align-items: flex-start; }
.cms-main-col { flex: 1; min-width: 0; }
.cms-side-col { width: 224px; flex-shrink: 0; display: none; }
@media (min-width:1024px) { .cms-side-col { display: block; } }
.cms-detail-wrap { display: flex; gap: 16px; align-items: flex-start; }
.cms-detail-main { flex: 1; min-width: 0; }
.cms-detail-side { width: 240px; flex-shrink: 0; display: none; }
@media (min-width:1024px) { .cms-detail-side { display: block; } }

/* ========== 排行 · 软件图标 ========== */
.cms-rank li { min-height: 32px; }
.cms-rank a { display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; line-height: 32px; }
.cms-rank-img {
  width: 24px; height: 24px; border-radius: 6px; object-fit: cover; flex-shrink: 0;
}
.cms-rank-txt { flex: 1; min-width: 0; overflow: hidden; }
.cms-rank-txt a { line-height: 1.35; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; display: block; font-size: 12px; }
.cms-rank-txt em { display: block; font-size: 10px; color: var(--cms-muted); font-style: normal; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* 侧栏单行列表 */
.cms-side-line li a {
  display: block; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  font-size: 12px; padding: 6px 4px; color: var(--cms-text);
}
.cms-side-line li a:hover { color: var(--cms-primary); background: #f9fafb; border-radius: 4px; }

/* ========== 分类宫格 SVG 图标 ========== */
.cms-cat-ico {
  width: 36px; height: 36px; border-radius: var(--cms-radius-lg);
  display: flex; align-items: center; justify-content: center;
}
.cms-cat-ico svg { width: 18px; height: 18px; color: #fff; stroke: #fff; fill: none; }

/* ========== 用户评价（Figma 1:1） ========== */
.cms-reviews-summary {
  display: flex; gap: 24px; align-items: stretch;
  padding: 16px; background: var(--cms-bg); border-radius: var(--cms-radius);
  margin-bottom: 16px; flex-wrap: wrap;
}
.cms-reviews-score-box { text-align: center; min-width: 80px; }
.cms-reviews-big { display: block; font-size: 36px; font-weight: 900; color: var(--cms-amber); line-height: 1; }
.cms-stars-display { color: var(--cms-amber); font-size: 14px; letter-spacing: 1px; margin: 6px 0; }
.cms-stars-display .on { color: var(--cms-amber); }
.cms-stars-display span:not(.on) { color: #e5e7eb; }
.cms-reviews-label { font-size: 11px; color: var(--cms-muted); }
.cms-reviews-bars { flex: 1; min-width: 180px; display: flex; flex-direction: column; justify-content: center; gap: 4px; }
.cms-bar-row { display: flex; align-items: center; gap: 8px; font-size: 10px; color: var(--cms-muted); }
.cms-bar-star { width: 24px; flex-shrink: 0; text-align: right; }
.cms-bar-track { flex: 1; height: 6px; background: #e5e7eb; border-radius: 3px; overflow: hidden; }
.cms-bar-track i { display: block; height: 100%; background: var(--cms-amber); border-radius: 3px; }
.cms-bar-row em { width: 28px; text-align: right; flex-shrink: 0; }

.cms-reviews-form {
  border: 1px solid var(--cms-border); border-radius: var(--cms-radius);
  padding: 12px; margin-bottom: 16px; background: #fafafa;
}
.cms-reviews-input {
  width: 100%; border: 1px solid #e5e7eb; border-radius: 6px;
  padding: 10px 12px; font-size: 13px; font-family: inherit; resize: vertical;
  outline: none; background: #fff;
}
.cms-reviews-input:focus { border-color: var(--cms-primary); }
.cms-reviews-form-ft {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 8px; margin-top: 10px;
}
.cms-rate-pick { display: flex; align-items: center; gap: 2px; }
.cms-rate-label { font-size: 12px; color: var(--cms-muted); margin-right: 4px; }
.cms-rate-star {
  border: 0; background: none; font-size: 18px; color: #e5e7eb; cursor: pointer; padding: 0 1px;
}
.cms-rate-star.on { color: var(--cms-amber); }
.cms-btn-post {
  border: 0; background: var(--cms-primary); color: #fff;
  padding: 8px 20px; border-radius: 6px; font-size: 13px; font-weight: 600; cursor: pointer;
}
.cms-btn-post:hover { background: var(--cms-primary-dark); }
.cms-reviews-tip { font-size: 10px; color: var(--cms-muted); margin-top: 8px; margin-bottom: 0; }

.cms-reviews-list { list-style: none; margin: 0; padding: 0; }
.cms-review-item {
  display: flex; gap: 12px; padding: 14px 0;
  border-top: 1px solid #f3f4f6;
}
.cms-review-item:first-child { border-top: 0; }
.cms-avatar { width: 32px; height: 32px; border-radius: 50%; object-fit: cover; flex-shrink: 0; }
.cms-review-body { flex: 1; min-width: 0; }
.cms-review-hd {
  display: flex; align-items: center; flex-wrap: wrap; gap: 6px 10px; margin-bottom: 6px;
}
.cms-review-user { font-size: 13px; font-weight: 600; color: #374151; }
.cms-review-stars { font-size: 11px; color: var(--cms-amber); letter-spacing: -1px; }
.cms-review-date { font-size: 11px; color: var(--cms-muted); font-style: normal; margin-left: auto; }
.cms-review-text { font-size: 13px; color: #4b5563; line-height: 1.65; margin: 0 0 8px; }
.cms-review-like {
  border: 0; background: none; font-size: 11px; color: var(--cms-muted); cursor: pointer; padding: 0;
}
.cms-review-like:hover { color: var(--cms-primary); }
.cms-review-like.on { color: var(--cms-primary); }

