/* ============================================
   Cases · 米色像素风
   依赖：mulerun.css 的设计 token（.mr-page scope）
   仅在 .mr-page.cs-page 范围生效
   ============================================ */

/* ---------- 列表页 HERO ---------- */
.cs-hero{
  padding: 140px 0 60px;
  background:
    linear-gradient(var(--grid) 1px, transparent 1px) 0 0 / 24px 24px,
    linear-gradient(90deg, var(--grid) 1px, transparent 1px) 0 0 / 24px 24px,
    var(--cream);
  border-bottom: 2px solid var(--ink);
}
.cs-hero__chip{
  display:inline-block;
  font-family: var(--font-mono);
  font-size: 17px; letter-spacing:.12em;
  color: var(--orange-2);
  padding: 4px 12px;
  background: rgba(255,138,77,.12);
  border: 2px solid var(--orange-2);
  margin-bottom: 18px;
}
.cs-hero__title{
  font-size: clamp(40px, 6vw, 76px);
  font-weight: 900;
  line-height: 1.05;
  color: var(--ink);
  letter-spacing: -.02em;
  margin: 0 0 18px;
}
.cs-hero__title .hl{
  color: var(--ink);
  background: linear-gradient(transparent 62%, var(--orange-1) 62% 92%, transparent 92%);
  padding: 0 .15em;
}
.cs-hero__sub{
  font-size: 17px; line-height: 1.7;
  color: var(--ink-2);
  max-width: 720px;
}
.cs-hero__meta{
  display:flex; gap: 24px; flex-wrap: wrap;
  margin-top: 28px;
  font-family: var(--font-mono);
  font-size: 14px; color: var(--ink-3);
  letter-spacing: .06em;
}
.cs-hero__meta b{color: var(--ink); font-weight: 800}

/* ---------- 过滤栏 ---------- */
.cs-filter{
  position: sticky; top: 64px; z-index: 10;
  padding: 18px 0;
  background: rgba(239,234,216,.92);
  backdrop-filter: blur(10px);
  border-bottom: 2px dashed var(--paper-line-2);
}
.cs-filter__inner{
  display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
}
.cs-filter__label{
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .12em;
  color: var(--ink-3);
  margin-right: 4px;
}
.cs-chip{
  font-family: var(--font-mono);
  font-size: 14px; letter-spacing: .04em;
  padding: 6px 14px;
  background: var(--cream-1);
  color: var(--ink-2);
  border: 2px solid var(--paper-line-2);
  cursor: pointer;
  transition: all .15s;
}
.cs-chip:hover{ background: var(--cream-2); color: var(--ink) }
.cs-chip.is-active{
  background: var(--ink);
  color: var(--cream);
  border-color: var(--ink);
}

/* ---------- 卡片网格 ---------- */
.cs-grid-wrap{
  padding: 60px 0 120px;
  background: var(--cream);
}
.cs-grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 26px;
}
.cs-grid > .case-cover{ /* 复用 mulerun.css 中的 .case-cover */
  background: var(--cream-1);
}

/* 占位"更多案例陆续上线" */
.cs-coming{
  background: transparent;
  border: 2px dashed var(--paper-line-2);
  box-shadow: none;
  display: flex; align-items: center; justify-content: center;
  text-align: center;
  padding: 60px 28px;
  min-height: 360px;
}
.cs-coming__inner{
  font-family: var(--font-mono);
  color: var(--ink-3);
}
.cs-coming__inner b{
  display: block;
  font-family: var(--font-pixel);
  font-size: 14px;
  color: var(--orange-2);
  margin-bottom: 10px;
}
.cs-coming__inner span{
  display: block;
  font-size: 14px;
  letter-spacing: .04em;
  line-height: 1.6;
}

/* ============================================
   详情页（cases/xxx.html）
   ============================================ */
.cd-hero{
  padding: 130px 0 40px;
  border-bottom: 2px solid var(--ink);
  background:
    linear-gradient(var(--grid) 1px, transparent 1px) 0 0 / 24px 24px,
    linear-gradient(90deg, var(--grid) 1px, transparent 1px) 0 0 / 24px 24px,
    var(--cream);
}
.cd-back{
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--font-mono);
  font-size: 14px; letter-spacing: .06em;
  color: var(--ink-3);
  margin-bottom: 22px;
  transition: color .15s;
}
.cd-back:hover{color: var(--orange-2)}
.cd-tags{
  display: flex; gap: 8px; flex-wrap: wrap;
  margin-bottom: 16px;
}
.cd-tag{
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .08em;
  padding: 4px 10px;
  background: var(--ink); color: var(--cream);
  border: 1.5px solid var(--ink);
}
.cd-tag--scene{background: var(--cap-color, var(--orange)); color: var(--ink)}
.cd-title{
  font-size: clamp(34px, 5vw, 60px);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: -.02em;
  color: var(--ink);
  margin: 6px 0 18px;
}
.cd-lede{
  font-size: 17px; line-height: 1.7;
  color: var(--ink-2);
  max-width: 760px;
}

/* 关键指标条 */
.cd-kpis{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  margin-top: 32px;
}
.cd-kpi{
  background: var(--cream-1);
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 0 var(--ink);
  padding: 20px 22px;
}
.cd-kpi__label{
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .12em;
  color: var(--ink-3);
  margin-bottom: 8px;
}
.cd-kpi__value{
  font-size: 26px; font-weight: 900;
  color: var(--ink);
  line-height: 1.1;
  letter-spacing: -.01em;
}
.cd-kpi__value .ar{color: var(--orange-2); margin: 0 6px}
.cd-kpi__value .strike{
  font-size: .55em; font-weight: 600;
  color: var(--ink-3);
  text-decoration: line-through;
  text-decoration-color: var(--paper-line-2);
  margin-right: 6px;
  letter-spacing: 0;
}

/* ============================================
   DEMO 视频区（最优先呈现）
   ============================================ */
.cd-video{
  padding: 40px 0 80px;
  background: var(--cream);
  border-top: 2px dashed var(--paper-line-2);
}
.cd-video__head{
  display:flex; align-items:baseline; gap: 14px; flex-wrap: wrap;
  margin-bottom: 18px;
}
.cd-video__chip{
  font-family: var(--font-pixel);
  font-size: 13px; letter-spacing: .08em;
  color: var(--ink);
  background: var(--cap-color, var(--orange));
  padding: 6px 10px;
  border: 2px solid var(--ink);
}
.cd-video__title{
  font-size: clamp(22px, 2.4vw, 30px);
  font-weight: 900;
  color: var(--ink);
  letter-spacing: -.01em;
  line-height: 1.25;
}
.cd-video__sub{
  font-family: var(--font-mono);
  font-size: 14px; color: var(--ink-3);
  letter-spacing: .04em;
}

.cd-video__stack{
  display: grid;
  gap: 24px;
}
.cd-video__stack--2{grid-template-columns: 1fr 1fr}

.cd-video__frame{
  position: relative;
  border: 3px solid var(--ink);
  background: var(--ink);
  box-shadow: 8px 8px 0 0 var(--orange);
  overflow: hidden;
}
.cd-video__frame::before,
.cd-video__frame::after{
  content:"";
  position:absolute; width:14px; height:14px;
  background: var(--orange);
  border: 2px solid var(--ink);
  z-index: 3;
}
.cd-video__frame::before{top:-9px; left:-9px}
.cd-video__frame::after{bottom:-9px; right:-9px}
.cd-video__bar{
  display:flex; align-items:center; gap: 10px;
  padding: 10px 14px;
  background: var(--ink);
  color: var(--cream);
  border-bottom: 2px solid var(--ink);
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .08em;
}
.cd-video__bar .dot{
  width: 10px; height: 10px;
  background: #FF5F56;
  display:inline-block;
  border: 1.5px solid var(--ink);
}
.cd-video__bar .dot--y{background:#FFBD2E}
.cd-video__bar .dot--g{background:#27C93F}
.cd-video__bar .lbl{margin-left: 8px; color: var(--orange-1)}
.cd-video__bar .spd{margin-left: auto; color: rgba(239,234,216,.6); font-size: 12px}

.cd-video__media{
  display:block;
  width: 100%;
  aspect-ratio: 16/9;
  object-fit: cover;
  background: #000;
}
.cd-video__cap{
  display:block;
  padding: 12px 16px;
  background: var(--ink);
  color: rgba(239,234,216,.8);
  font-family: var(--font-mono);
  font-size: 13px;
  letter-spacing: .04em;
  border-top: 1px dashed rgba(239,234,216,.18);
}
.cd-video__cap b{color: var(--orange-1); font-weight:700}

.cd-video__hint{
  display: flex; align-items: center; gap: 10px;
  margin-top: 18px;
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--ink-3);
  letter-spacing: .04em;
}
.cd-video__hint .live-dot{
  width: 10px; height: 10px; background: var(--orange);
  display:inline-block;
  box-shadow: 0 0 0 2px var(--ink), 0 0 0 4px var(--orange-1);
  animation: blink 1.4s steps(2) infinite;
}

@media (max-width: 760px){
  .cd-video__stack--2{grid-template-columns: 1fr}
}

/* 正文段落 */
.cd-body{
  padding: 80px 0;
  background: var(--cream-1);
  border-top: 2px solid var(--ink);
}
.cd-section{
  display: grid;
  grid-template-columns: 220px 1fr;
  gap: 40px;
  padding: 32px 0;
  border-bottom: 2px dashed var(--paper-line-2);
}
.cd-section:last-child{border-bottom: none}
.cd-section__no{
  font-family: var(--font-pixel);
  font-size: 14px;
  color: var(--orange-2);
  padding-top: 4px;
}
.cd-section__title{
  display: block;
  font-family: var(--font-cn);
  font-size: 22px; font-weight: 900;
  color: var(--ink);
  letter-spacing: -.005em;
  margin-top: 6px;
}
.cd-section__content{
  font-size: 15.5px; line-height: 1.8;
  color: var(--ink-2);
}
.cd-section__content p{margin: 0 0 14px}
.cd-section__content p:last-child{margin: 0}
.cd-section__content ul, .cd-section__content ol{
  margin: 0; padding-left: 22px;
  display: flex; flex-direction: column; gap: 6px;
}
.cd-section__content li::marker{color: var(--orange-2); font-weight: 700}
.cd-section__content b{color: var(--ink); font-weight: 800}

/* 流程 step 卡片 */
.cd-steps{
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-top: 6px;
}
.cd-step{
  background: var(--cream);
  border: 2px solid var(--ink);
  box-shadow: 4px 4px 0 0 var(--ink);
  padding: 16px 16px 18px;
  position: relative;
}
.cd-step__no{
  font-family: var(--font-pixel);
  font-size: 13px;
  color: var(--orange-2);
  margin-bottom: 10px;
}
.cd-step__t{
  font-size: 14.5px; font-weight: 800;
  color: var(--ink);
  margin-bottom: 6px;
  line-height: 1.3;
}
.cd-step__d{
  font-size: 12.5px;
  color: var(--ink-3);
  line-height: 1.55;
}

/* 截图 / 大图位 */
.cd-shot{
  margin: 18px 0 0;
  border: 2px solid var(--ink);
  box-shadow: 6px 6px 0 0 var(--ink);
  overflow: hidden;
  background: var(--ink);
}
.cd-shot img{width:100%; display:block}
.cd-shot__cap{
  display: block;
  padding: 10px 14px;
  background: var(--ink); color: var(--cream);
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .06em;
  border-top: 2px solid var(--ink);
}

/* 引文卡 */
.cd-quote{
  background: var(--ink);
  color: var(--cream);
  border: 2px solid var(--ink);
  box-shadow: 6px 6px 0 0 var(--orange);
  padding: 28px 32px;
  margin-top: 8px;
}
.cd-quote__txt{
  font-size: 18px; line-height: 1.7;
  color: var(--cream);
  font-weight: 600;
  margin-bottom: 14px;
  font-style: italic;
}
.cd-quote__src{
  font-family: var(--font-mono);
  font-size: 13px; letter-spacing: .08em;
  color: var(--orange-1);
}

/* 底部 CTA 条（详情页结尾） */
.cd-cta{
  padding: 80px 0 100px;
  background: var(--cream);
  border-top: 2px solid var(--ink);
}
.cd-cta__inner{
  background: var(--ink);
  color: var(--cream);
  padding: 44px 40px;
  border: 2px solid var(--ink);
  box-shadow: 8px 8px 0 0 var(--orange);
  display: grid;
  grid-template-columns: 1.4fr 1fr;
  gap: 32px;
  align-items: center;
}
.cd-cta__t{
  font-size: clamp(24px,2.6vw,32px);
  font-weight: 900;
  color: var(--cream);
  line-height: 1.25;
  letter-spacing: -.01em;
}
.cd-cta__t .hl{color: var(--orange-1)}
.cd-cta__d{
  font-size: 14.5px;
  color: rgba(239,234,216,.75);
  line-height: 1.65;
  margin-top: 10px;
}
.cd-cta__btns{
  display: flex; flex-direction: column; gap: 12px;
  align-items: stretch;
}
.cd-cta__btns .btn-pix{justify-content: center}

/* 相邻案例 */
.cd-adj{
  padding: 70px 0 110px;
  background: var(--cream-1);
}
.cd-adj__head{
  font-family: var(--font-mono);
  font-size: 14px; letter-spacing: .12em;
  color: var(--ink-3);
  margin-bottom: 20px;
}
.cd-adj__grid{
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}
.cd-adj__card{
  display: block;
  padding: 22px 24px;
  background: var(--cream);
  border: 2px solid var(--ink);
  box-shadow: 5px 5px 0 0 var(--ink);
  text-decoration: none; color: inherit;
  transition: transform .15s, box-shadow .15s;
}
.cd-adj__card:hover{
  transform: translate(-2px,-2px);
  box-shadow: 7px 7px 0 0 var(--orange);
}
.cd-adj__dir{
  font-family: var(--font-mono);
  font-size: 12px; letter-spacing: .12em;
  color: var(--orange-2);
  margin-bottom: 6px;
}
.cd-adj__t{
  font-size: 18px; font-weight: 800;
  color: var(--ink);
  line-height: 1.35;
}

/* 各 case scene token */
.cd--ecom { --cap-color: #FF8A4D; }
.cd--mkt  { --cap-color: #4DBD7B; }
.cd--con  { --cap-color: #4D96FF; }
.cd--ent  { --cap-color: #9D55E8; }

@media (max-width: 960px){
  .cs-filter{top: 56px}
  .cs-grid{grid-template-columns: 1fr}
  .cd-kpis{grid-template-columns: 1fr}
  .cd-section{grid-template-columns: 1fr; gap: 14px; padding: 24px 0}
  .cd-steps{grid-template-columns: 1fr 1fr}
  .cd-cta__inner{grid-template-columns: 1fr}
  .cd-adj__grid{grid-template-columns: 1fr}
}
