/* ============================================================
   CERYE 陶瓷空器皿现货 (ceramic-vessels.css)
   东方香氛克制风,复用 site.css 变量。大图卡片(不出现小缩略图)。
   ============================================================ */
.cvgrid{width:100%}
.cvc-empty{color:var(--ink-soft);font-size:15px;padding:40px 0;grid-column:1/-1}

/* 搜索 + 筛选 */
.cvfilter{display:flex;flex-direction:column;gap:14px;margin-bottom:26px;background:var(--paper-lt);border:1px solid var(--line);border-radius:14px;padding:18px 22px}
.cvsearch{font:inherit;font-family:var(--cn);font-size:14px;color:var(--ink);background:var(--paper-lt);
  border:1px solid var(--line);padding:13px 18px;width:100%;max-width:460px;letter-spacing:.02em;transition:.3s var(--ease)}
.cvsearch:focus{outline:none;border-color:var(--g500);background:var(--paper)}
.cvfgroup{display:flex;align-items:flex-start;gap:18px;flex-wrap:wrap}
.cvfl{font-family:var(--cn);font-size:12.5px;font-weight:500;letter-spacing:.04em;color:var(--ink);min-width:96px;padding-top:5px;flex-shrink:0}
.cvchips{display:flex;flex-wrap:wrap;gap:8px;flex:1;min-width:240px}
.cvchip{font:inherit;cursor:pointer;border:1px solid var(--line2);background:var(--paper);color:var(--ink);
  padding:6px 15px;border-radius:40px;font-size:12.5px;letter-spacing:.02em;transition:.3s var(--ease)}
.cvchip:hover{color:var(--ink);border-color:var(--ink-faint)}
.cvchip.on{background:var(--g700);border-color:var(--g700);color:var(--paper)}

.cvcount{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-faint);margin-bottom:22px}
.cvcount .cvcnt{color:var(--brand);font-size:14px}

/* 卡片网格:桌面 3-4 列,每列图宽 >=290px,移动 1 列 */
.cvcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:34px 28px}
.cvc{display:flex;flex-direction:column;background:var(--paper);border:1px solid var(--line);cursor:pointer;border-radius:18px;overflow:hidden;
  opacity:0;transform:translateY(14px);transition:opacity .7s var(--ease),transform .7s var(--ease),border-color .4s,box-shadow .4s}
.cvc.in{opacity:1;transform:none}
.cvc:hover{border-color:var(--line2);box-shadow:0 30px 60px -40px rgba(27,36,26,.5)}

/* 产品大图框(用户规范):浅灰底、contain、产品大、不裁切 */
.product-image-wrap{background:#f6f6f3;padding:18px;aspect-ratio:1/1;min-height:320px;
  display:flex;align-items:center;justify-content:center;overflow:hidden}
.product-image-wrap img{width:100%;height:100%;object-fit:contain;image-rendering:auto;display:block;transition:transform 1.1s var(--ease)}
.cvc:hover .product-image-wrap img{transform:scale(1.04)}

.cvc-bd{display:flex;flex-direction:column;gap:6px;padding:18px 18px 18px}
.cvc-sku{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--g500)}
.cvc-name{font-family:var(--cn);font-weight:500;font-size:16px;letter-spacing:.02em;color:var(--ink);line-height:1.35}
.cvc-meta{display:flex;flex-wrap:wrap;gap:4px 10px;font-size:11.5px;color:var(--ink-soft);line-height:1.4}
.cvc-spec{font-family:var(--mono);font-size:10.5px;letter-spacing:.04em;color:var(--ink-faint)}
.cvc-stock{font-family:var(--mono);font-size:9px;letter-spacing:.07em;color:var(--brand);opacity:.92;margin-top:2px}
.cvc-tags{display:flex;flex-wrap:wrap;gap:5px;margin-top:3px}
.cvc-tags span{font-size:9px;letter-spacing:.03em;color:var(--ink-soft);border:1px solid var(--line);padding:2px 8px;border-radius:30px}
.cvc-btns{display:flex;gap:8px;margin-top:13px}
.cvc-btns a{flex:1;text-align:center;font-family:var(--cn);font-size:12px;letter-spacing:.02em;padding:11px 5px;transition:.3s var(--ease)}
.cvc-b1{background:var(--g700);color:var(--paper);border:1px solid var(--g700)}
.cvc-b1:hover{background:var(--g900);border-color:var(--g900)}
.cvc-b2{background:none;color:var(--ink-soft);border:1px solid var(--line)}
.cvc-b2:hover{color:var(--ink);border-color:var(--ink-faint)}

/* 详情弹窗 */
.cvmodal{position:fixed;inset:0;z-index:300;display:none}
.cvmodal.on{display:block}
.cvmodal-ov{position:absolute;inset:0;background:rgba(24,33,25,.46);backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.cvmodal-box{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:min(920px,93vw);max-height:90vh;
  overflow-y:auto;background:var(--paper-lt);display:grid;grid-template-columns:1fr 1fr;gap:0;box-shadow:0 50px 120px -40px rgba(0,0,0,.6)}
.cvmodal-x{position:absolute;right:14px;top:14px;z-index:2;border:none;background:none;cursor:pointer;font-size:17px;color:var(--ink-soft);line-height:1}
.cvmodal-x:hover{color:var(--ink)}
.cvmodal-img{background:#f6f6f3;display:flex;align-items:center;justify-content:center;min-height:380px}
.cvmodal-img img{width:100%;height:100%;object-fit:contain;padding:8%}
.cvmodal-info{padding:40px 38px 36px;display:flex;flex-direction:column}
.cvm-sku{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--g500)}
.cvm-name{font-family:var(--cn);font-weight:600;font-size:22px;color:var(--ink);margin:8px 0 12px;line-height:1.25}
.cvm-stock{font-family:var(--mono);font-size:9.5px;letter-spacing:.07em;color:var(--brand);margin-bottom:20px;line-height:1.6}
.cvm-rows{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.cvm-row{display:flex;gap:16px;padding:10px 0;border-bottom:1px solid var(--line);font-size:13px}
.cvm-k{flex:0 0 92px;font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-faint);padding-top:2px}
.cvm-v{color:var(--ink);line-height:1.55}
.cvm-btns{display:flex;gap:10px;margin-top:24px}
.cvm-btns a{flex:1;text-align:center;font-family:var(--cn);font-size:13px;padding:12px 8px;transition:.3s var(--ease)}

/* 双语 .zh/.en */
.cvc .en,.cvchip .en,.cvcount .en,.cvfl .en,.cvc-empty .en,.cvc-stock .en,.cvc-meta .en,.cvmodal .en{display:none}
body[data-lang="en"] .cvc .zh,body[data-lang="en"] .cvchip .zh,body[data-lang="en"] .cvcount .zh,
body[data-lang="en"] .cvfl .zh,body[data-lang="en"] .cvc-empty .zh,body[data-lang="en"] .cvc-stock .zh,
body[data-lang="en"] .cvc-meta .zh,body[data-lang="en"] .cvmodal .zh{display:none}
body[data-lang="en"] .cvc .en,body[data-lang="en"] .cvchip .en,body[data-lang="en"] .cvcount .en,
body[data-lang="en"] .cvfl .en,body[data-lang="en"] .cvc-empty .en,body[data-lang="en"] .cvc-stock .en,
body[data-lang="en"] .cvc-meta .en,body[data-lang="en"] .cvmodal .en{display:inline}
body[data-lang="en"] .cvc-name .zh,body[data-lang="en"] .cvm-name .zh{display:none}
body[data-lang="en"] .cvc-name .en,body[data-lang="en"] .cvm-name .en{display:inline;font-family:var(--cn);font-weight:500}

@media(max-width:900px){ .cvcards{grid-template-columns:repeat(auto-fill,minmax(240px,1fr))} }
@media(max-width:700px){
  .cvmodal-box{grid-template-columns:1fr;max-height:88vh}
  .cvmodal-img{min-height:280px}
  .cvmodal-info{padding:26px 22px}
}
@media(max-width:600px){
  .cvcards{grid-template-columns:1fr;gap:24px}
  .product-image-wrap{min-height:300px}
  .cvc-btns{flex-direction:column}
}
