[hidden]{display:none!important;}
.wwf-tool{
  --wwf-navy:#031725;
  --wwf-deep:#06283d;
  --wwf-cyan:#0f7890;
  --wwf-gold:#c8a45d;
  --wwf-soft:#f5f8fb;
  --wwf-line:#dbe7ee;
  --wwf-text:#1f3442;
  --wwf-muted:#6d7f8b;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI","PingFang SC","Microsoft YaHei",Arial,sans-serif;
  color:var(--wwf-text);
  max-width:1180px;
  margin:0 auto;
  padding:22px 16px 34px;
  box-sizing:border-box;
}
.wwf-tool *{box-sizing:border-box}
.wwf-hero{
  background:radial-gradient(circle at 16% 18%,rgba(18,142,166,.28),transparent 26%),radial-gradient(circle at 82% 16%,rgba(200,164,93,.18),transparent 24%),linear-gradient(135deg,var(--wwf-navy),var(--wwf-deep));
  color:#fff;
  padding:34px 30px;
  border-radius:22px;
  margin-bottom:18px;
  box-shadow:0 18px 46px rgba(3,23,37,.16);
}
.wwf-pill{
  display:inline-flex;
  align-items:center;
  padding:7px 14px;
  border:1px solid rgba(255,255,255,.28);
  border-radius:999px;
  font-size:13px;
  color:rgba(255,255,255,.84);
  margin-bottom:12px;
}
.wwf-hero h1{margin:0 0 10px;font-size:42px;line-height:1.12;font-weight:700;letter-spacing:.03em;color:#fff}
.wwf-hero p{margin:0;max-width:820px;color:rgba(255,255,255,.78);line-height:1.75;font-size:15px}
.wwf-panel,.wwf-card,.wwf-rec-card,.wwf-contact-card,.wwf-buy-note{
  background:#fff;
  border:1px solid var(--wwf-line);
  border-radius:20px;
  box-shadow:0 12px 32px rgba(24,54,72,.06);
}
.wwf-form-panel{padding:18px;margin-bottom:18px}
.wwf-panel-title{font-size:22px;font-weight:700;margin-bottom:4px;color:#1e3749}
.wwf-muted{margin:0 0 14px;color:var(--wwf-muted);font-size:14px;line-height:1.7}
.wwf-input-layout{display:grid;grid-template-columns:270px 1fr;gap:14px;align-items:stretch}
.wwf-date-type-card,.wwf-birth-card{
  border:1px solid var(--wwf-line);
  border-radius:16px;
  background:#f8fbfd;
  padding:16px;
}
.wwf-field-label{display:block;font-weight:700;margin-bottom:10px;color:#213747}
.wwf-radio-row{
  display:flex;
  align-items:center;
  gap:8px;
  border:1px solid #dce8ef;
  border-radius:12px;
  padding:10px 12px;
  margin:8px 0;
  background:#fff;
  cursor:pointer;
}
.wwf-birth-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.wwf-birth-grid span{display:block;font-size:13px;font-weight:700;margin-bottom:7px;color:#344b5d}
.wwf-birth-grid input,.wwf-birth-grid select{
  width:100%;
  height:44px;
  border:1px solid #d6e5ee;
  border-radius:12px;
  padding:0 12px;
  background:#fff;
  color:#1f3442;
  font-size:15px;
  outline:none;
}
.wwf-birth-grid input:focus,.wwf-birth-grid select:focus{border-color:#168da4;box-shadow:0 0 0 3px rgba(22,141,164,.12)}
.wwf-main-btn{
  width:100%;
  border:none;
  border-radius:999px;
  margin-top:18px;
  padding:15px 18px;
  background:linear-gradient(135deg,#06283d,#0f7188);
  color:#fff;
  font-size:16px;
  font-weight:800;
  letter-spacing:.04em;
  cursor:pointer;
  box-shadow:0 12px 26px rgba(15,113,136,.2);
}
.wwf-main-btn:hover{filter:brightness(1.04)}
.wwf-results{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:18px 0}
.wwf-card{padding:18px;min-height:178px;display:flex;flex-direction:column}
.wwf-card h3{font-size:18px;line-height:1.3;margin:0 0 12px;color:#17374a}
.wwf-card p{margin:0 0 9px;line-height:1.7;color:#3a5060}
.wwf-card ul{margin:0;padding-left:18px;line-height:1.72;color:#3a5060}
.wwf-badge-row{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0 2px}
.wwf-badge{display:inline-flex;align-items:center;border-radius:999px;padding:6px 10px;background:#edf7fa;color:#07576a;font-size:13px;font-weight:700}
.wwf-score-line{height:9px;border-radius:999px;background:#eef4f7;overflow:hidden;margin:6px 0 11px}
.wwf-score-line span{display:block;height:100%;border-radius:999px;background:linear-gradient(90deg,#0f7890,#c8a45d)}
.wwf-section-head{margin:26px 0 14px}
.wwf-section-head h2{font-size:26px;line-height:1.25;margin:0 0 8px;color:#17374a}
.wwf-section-head p{margin:0;color:var(--wwf-muted);line-height:1.7}
.wwf-section-head-actions{display:block}
.wwf-refresh-btn{width:100%;border:none;background:linear-gradient(135deg,#06283d,#0f7188);color:#fff;border-radius:999px;padding:15px 18px;margin-top:16px;font-weight:800;font-size:15px;line-height:1;cursor:pointer;white-space:nowrap;box-shadow:0 12px 26px rgba(15,113,136,.18);letter-spacing:.03em}
.wwf-refresh-btn:hover{filter:brightness(1.05)}

.wwf-recommend-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;align-items:stretch}
.wwf-rec-card,.wwf-contact-card{padding:16px;min-height:330px;position:relative;overflow:hidden}
.wwf-rec-card h3,.wwf-contact-card h3{margin:0 0 8px;font-size:18px;color:#17374a}
.wwf-rec-card p,.wwf-contact-card p{margin:0 0 10px;color:#5f7180;line-height:1.62;font-size:14px}
.wwf-mockup-wrap{display:flex;align-items:center;justify-content:center;gap:14px;min-height:224px;margin-top:8px;background:linear-gradient(180deg,#f8fbfd,#eef5f8);border:1px solid #e3eef3;border-radius:18px;padding:12px;cursor:pointer}
.wwf-mockup{position:relative;width:min(46%,190px);max-width:220px;aspect-ratio:1/1.18;display:flex;align-items:center;justify-content:center}
.wwf-mockup.single{width:min(70%,260px)}
.wwf-shirt{width:100%;height:auto;display:block;filter:drop-shadow(0 14px 16px rgba(22,38,48,.12))}
.wwf-pattern{position:absolute;height:auto;object-fit:contain;pointer-events:none;filter:drop-shadow(0 2px 2px rgba(0,0,0,.12))}
.wwf-pattern.left{width:9.2%;max-height:10.5%;left:56.8%;top:31.8%}
.wwf-pattern.back{width:23.5%;max-height:23%;left:38.25%;top:26.8%}
.wwf-pattern.front{width:34%;max-height:36%;left:33%;top:36%}
.wwf-rec-meta{display:flex;justify-content:space-between;gap:10px;align-items:center;margin-top:10px;font-size:13px;color:#607483;flex-wrap:wrap}
.wwf-chip{display:inline-flex;border-radius:999px;padding:5px 9px;background:#f0f6f8;color:#244a5a;font-weight:700}
.wwf-contact-card{text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(180deg,#fff,#f7fbfc)}
.wwf-contact-card img{width:min(72%,230px);max-width:230px;height:auto;border-radius:14px;border:1px solid #e3eef3;background:#fff;padding:8px;margin-top:4px}
.wwf-buy-note{padding:14px 16px;margin-top:16px;color:#536a78;line-height:1.7;background:#fbfcfd}
.wwf-empty{padding:28px;text-align:center;color:#7a8a95;background:#f7fbfd;border:1px dashed #cddde5;border-radius:16px}
.wwf-modal{position:fixed;z-index:99999;inset:0;background:rgba(3,16,25,.72);display:flex;align-items:center;justify-content:center;padding:24px}
.wwf-modal[hidden]{display:none!important}
.wwf-modal-body{max-width:min(980px,96vw);max-height:90vh;overflow:auto;background:#fff;border-radius:20px;padding:18px;box-shadow:0 24px 80px rgba(0,0,0,.32)}
.wwf-modal-body .wwf-mockup-wrap{min-height:520px;width:min(900px,88vw)}
.wwf-modal-close{position:absolute;right:22px;top:18px;width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.14);color:#fff;font-size:26px;line-height:1;display:flex;align-items:center;justify-content:center;padding:0;cursor:pointer;z-index:2}
@media (max-width:900px){
  .wwf-tool{padding:16px 12px 28px}
  .wwf-hero{padding:28px 22px;border-radius:18px}
  .wwf-hero h1{font-size:34px}
  .wwf-input-layout{grid-template-columns:1fr}
  .wwf-birth-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .wwf-results,.wwf-recommend-grid{grid-template-columns:1fr}
  .wwf-contact-card{order:4}
}
@media (max-width:560px){
  .wwf-section-head-actions{display:block}
  .wwf-refresh-btn{margin-top:10px}
  .wwf-modal{padding:16px}
  .wwf-modal-close{right:14px;top:12px;width:42px;height:42px;font-size:24px}
  .wwf-modal-body{max-width:96vw;max-height:88vh;padding:14px}
  .wwf-modal-body .wwf-mockup-wrap{min-height:380px;width:92vw}
  .wwf-hero h1{font-size:30px}
  .wwf-birth-grid{grid-template-columns:1fr}
  .wwf-rec-card,.wwf-contact-card{min-height:auto}
  .wwf-mockup-wrap{min-height:210px}
  .wwf-mockup{width:min(48%,170px)}
  .wwf-mockup.single{width:min(78%,230px)}
}
.wwf-rec-title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:6px}
.wwf-rec-title-row h3{margin-bottom:0;flex:1}
.wwf-fav-btn,.wwf-mini-btn{border:1px solid #d9e8ef;background:#fff;color:#0a6477;border-radius:999px;padding:7px 12px;font-weight:800;font-size:13px;line-height:1;cursor:pointer;white-space:nowrap}
.wwf-fav-btn:hover,.wwf-mini-btn:hover{background:#edf8fb;border-color:#b7d9e4}
.wwf-fav-btn.is-saved{background:#0f7890;color:#fff;border-color:#0f7890}
.wwf-favorites{margin-top:20px}
.wwf-favorites-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.wwf-fav-card{display:grid;grid-template-columns:150px 1fr;gap:12px;border:1px solid var(--wwf-line);border-radius:18px;background:#fff;padding:12px;box-shadow:0 10px 24px rgba(24,54,72,.05)}
.wwf-fav-card h4{margin:0 0 6px;color:#17374a;font-size:16px;line-height:1.35}
.wwf-fav-card p{margin:0 0 8px;color:#5f7180;font-size:13px;line-height:1.55}
.wwf-fav-thumb .wwf-mockup-wrap{min-height:120px;padding:6px;margin:0;border-radius:14px;gap:6px;cursor:pointer}
.wwf-fav-thumb .wwf-mockup{width:min(47%,94px)}
.wwf-fav-thumb .wwf-mockup.single{width:min(78%,118px)}
.wwf-fav-thumb .wwf-pattern.left{width:9.2%;max-height:10.5%;left:56.8%;top:31.8%}
.wwf-fav-thumb .wwf-pattern.back{width:23.5%;max-height:23%;left:38.25%;top:26.8%}
@media (max-width:900px){.wwf-favorites-list{grid-template-columns:1fr}.wwf-fav-card{grid-template-columns:130px 1fr}}
@media (max-width:560px){.wwf-rec-title-row{align-items:center}.wwf-fav-card{grid-template-columns:1fr}.wwf-fav-thumb .wwf-mockup-wrap{min-height:180px}.wwf-fav-thumb .wwf-mockup.single{width:min(72%,210px)}}

/* 2.1.0：预览更轻、位置更稳、空缺不硬推 */
.wwf-pattern.left{width:7.4%;max-height:8.6%;left:57.8%;top:31.4%}
.wwf-pattern.back{width:18.5%;max-height:18.5%;left:40.75%;top:24.6%}
.wwf-rec-empty-card{background:linear-gradient(180deg,#fff,#f8fbfd)}
.wwf-empty-rec{min-height:224px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;line-height:1.7}
.wwf-empty-rec p{margin:0;max-width:340px}
.wwf-modal-body .wwf-mockup{width:min(48%,360px)}
.wwf-modal-body .wwf-mockup.single{width:min(74%,520px)}
.wwf-modal-body .wwf-pattern.left{width:7.4%;max-height:8.6%;left:57.8%;top:31.4%}
.wwf-modal-body .wwf-pattern.back{width:18.5%;max-height:18.5%;left:40.75%;top:24.6%}
.wwf-mockup-wrap{transition:box-shadow .18s ease, transform .18s ease}
.wwf-mockup-wrap:hover{box-shadow:0 12px 30px rgba(24,54,72,.10)}
@media (max-width:560px){
  .wwf-pattern.left{width:7.2%;max-height:8.4%;left:58%;top:31.4%}
  .wwf-pattern.back{width:18%;max-height:18%;left:41%;top:24.8%}
}

/* 2.1.1：小预览提速 + 弹窗放大更明显 */
.wwf-mockup-wrap{will-change:transform}
.wwf-rec-card .wwf-mockup-wrap::after{content:"点击放大";position:absolute;right:22px;bottom:18px;background:rgba(3,30,45,.72);color:#fff;font-size:12px;line-height:1;border-radius:999px;padding:7px 10px;opacity:.86;pointer-events:none}
.wwf-rec-card .wwf-mockup-wrap{position:relative}
.wwf-modal-body{padding:22px}
.wwf-modal-body .wwf-mockup-wrap{min-height:min(760px,78vh);width:min(1120px,92vw);padding:18px}
.wwf-modal-body .wwf-mockup{width:min(48%,460px)}
.wwf-modal-body .wwf-mockup.single{width:min(80%,680px)}
.wwf-modal-body .wwf-pattern.left{width:7.4%;max-height:8.6%;left:57.8%;top:31.4%}
.wwf-modal-body .wwf-pattern.back{width:18.5%;max-height:18.5%;left:40.75%;top:24.6%}
@media (max-width:560px){
  .wwf-rec-card .wwf-mockup-wrap::after{right:14px;bottom:14px;font-size:11px;padding:6px 9px}
  .wwf-modal-body .wwf-mockup-wrap{min-height:68vh;width:92vw;padding:12px}
  .wwf-modal-body .wwf-mockup.single{width:min(86%,430px)}
}


/* 2.1.3：弹窗真正放大；补木缺直接绿时优先水色兜底由 JS 颜色顺序控制 */
.wwf-modal{align-items:center;justify-content:center;}
.wwf-modal-body{width:min(1220px,96vw)!important;max-width:96vw!important;max-height:92vh!important;padding:24px!important;overflow:auto;}
.wwf-modal-body .wwf-modal-view{width:100%!important;min-height:min(760px,82vh)!important;padding:18px!important;gap:24px!important;}
.wwf-modal-body .wwf-modal-view::after{display:none!important;}
.wwf-modal-body .wwf-modal-view .wwf-mockup.single{width:min(86vw,760px)!important;max-width:760px!important;}
.wwf-modal-body .wwf-modal-view .wwf-mockup:not(.single){width:min(42vw,520px)!important;max-width:520px!important;}
.wwf-modal-body .wwf-modal-view .wwf-shirt{width:100%!important;max-width:none!important;}
.wwf-modal-body .wwf-modal-view .wwf-pattern.left{width:7.4%!important;max-height:8.6%!important;left:57.8%!important;top:31.4%!important;}
.wwf-modal-body .wwf-modal-view .wwf-pattern.back{width:18.5%!important;max-height:18.5%!important;left:40.75%!important;top:24.6%!important;}
@media (max-width:560px){
  .wwf-modal-body{padding:14px!important;width:96vw!important;}
  .wwf-modal-body .wwf-modal-view{min-height:72vh!important;padding:12px!important;gap:12px!important;}
  .wwf-modal-body .wwf-modal-view .wwf-mockup.single{width:92vw!important;max-width:480px!important;}
  .wwf-modal-body .wwf-modal-view .wwf-mockup:not(.single){width:44vw!important;max-width:230px!important;}
}

/* 2.1.6：恢复推荐说明，图案默认使用 PNG 原色，不强制改色 */
.wwf-advice-block p{margin:0 0 9px;line-height:1.75;color:#3a5060}
.wwf-precision-note{margin-top:14px;padding:16px 18px;border-radius:18px;background:linear-gradient(135deg,#fffaf0,#f3fbff);border:1px solid rgba(200,164,93,.42);color:#415968;line-height:1.78;font-size:14px;box-shadow:0 10px 26px rgba(12,42,68,.06)}
.wwf-precision-note p{margin:0 0 8px!important;color:#415968!important}.wwf-precision-note p:last-child{margin-bottom:0!important}.wwf-precision-title{display:inline-flex;align-items:center;margin-bottom:8px;padding:6px 12px;border-radius:999px;background:#061a2d;color:#fff;font-size:14px;font-weight:900}
.wwf-rec-detail{display:grid;grid-template-columns:86px 1fr;gap:7px 10px;margin-top:12px;padding:12px 13px;border-radius:14px;background:#f8fbfd;color:#536a78;font-size:14px;line-height:1.5}
.wwf-rec-detail div{display:contents}
.wwf-rec-detail strong{color:#1e3749;font-weight:800}
.wwf-rec-detail span{color:#5b6f7d}
.wwf-rec-note{margin-top:10px;border-radius:14px;background:#fbfcfd;padding:11px 13px;color:#607483;font-size:14px;line-height:1.65}
.wwf-modal-body .wwf-pattern.front{width:34%!important;max-height:36%!important;left:33%!important;top:36%!important}
.wwf-fav-thumb .wwf-pattern.front{width:34%;max-height:36%;left:33%;top:36%}
@media (max-width:560px){
  .wwf-rec-detail{grid-template-columns:76px 1fr;font-size:13px;padding:10px 11px}
  .wwf-precision-note{font-size:13px}
}


/* 2.1.7：按新素材印位调整预览比例；后背更大更低，前胸缩小；移动端沿用单列稳妥布局 */
.wwf-pattern.left{width:7.4%;max-height:8.6%;left:57.8%;top:31.4%}
.wwf-pattern.back{width:34%;max-height:36%;left:33%;top:36%}
.wwf-pattern.front{width:18.5%;max-height:18.5%;left:40.75%;top:36%}
.wwf-modal-body .wwf-pattern.left,
.wwf-modal-body .wwf-modal-view .wwf-pattern.left{width:7.4%!important;max-height:8.6%!important;left:57.8%!important;top:31.4%!important}
.wwf-modal-body .wwf-pattern.back,
.wwf-modal-body .wwf-modal-view .wwf-pattern.back{width:34%!important;max-height:36%!important;left:33%!important;top:36%!important}
.wwf-modal-body .wwf-pattern.front,
.wwf-modal-body .wwf-modal-view .wwf-pattern.front{width:18.5%!important;max-height:18.5%!important;left:40.75%!important;top:36%!important}
.wwf-fav-thumb .wwf-pattern.left{width:7.4%;max-height:8.6%;left:57.8%;top:31.4%}
.wwf-fav-thumb .wwf-pattern.back{width:34%;max-height:36%;left:33%;top:36%}
.wwf-fav-thumb .wwf-pattern.front{width:18.5%;max-height:18.5%;left:40.75%;top:36%}
@media (max-width:560px){
  .wwf-recommend-grid{grid-template-columns:1fr;gap:14px}
  .wwf-rec-card,.wwf-contact-card{padding:14px;border-radius:18px}
  .wwf-mockup-wrap{min-height:210px;gap:10px;padding:10px}
  .wwf-mockup{width:min(48%,170px)}
  .wwf-mockup.single{width:min(78%,230px)}
  .wwf-pattern.left{width:7.2%;max-height:8.4%;left:58%;top:31.4%}
  .wwf-pattern.back{width:34%;max-height:36%;left:33%;top:36%}
  .wwf-pattern.front{width:18.5%;max-height:18.5%;left:40.75%;top:36%}
  .wwf-rec-title-row{align-items:center;gap:8px}
  .wwf-fav-btn{padding:7px 11px;font-size:12px}
  .wwf-rec-detail{grid-template-columns:72px 1fr;gap:6px 8px}
}


/* 2.1.8：后背图案保持 2.1.7 大小，整体上移一点 */
.wwf-pattern.back{width:34%;max-height:36%;left:33%;top:32.8%}
.wwf-modal-body .wwf-pattern.back,
.wwf-modal-body .wwf-modal-view .wwf-pattern.back{width:34%!important;max-height:36%!important;left:33%!important;top:32.8%!important}
.wwf-fav-thumb .wwf-pattern.back{width:34%;max-height:36%;left:33%;top:32.8%}
@media (max-width:560px){
  .wwf-pattern.back{width:34%;max-height:36%;left:33%;top:32.8%}
}

/* 2.1.9：后背图案在 2.1.8 基础上再上移一点点；大小不变 */
.wwf-pattern.back{width:34%;max-height:36%;left:33%;top:31.4%}
.wwf-modal-body .wwf-pattern.back,
.wwf-modal-body .wwf-modal-view .wwf-pattern.back{width:34%!important;max-height:36%!important;left:33%!important;top:31.4%!important}
.wwf-fav-thumb .wwf-pattern.back{width:34%;max-height:36%;left:33%;top:31.4%}
@media (max-width:560px){
  .wwf-pattern.back{width:34%;max-height:36%;left:33%;top:31.4%}
}

/* Pattern library page */
.wwf-pattern-library{max-width:1180px;margin:0 auto;padding:24px 14px 42px;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,"PingFang SC","Microsoft YaHei",sans-serif;color:#173044;}
.wwf-pattern-hero{background:linear-gradient(135deg,#06192b,#0b3550 58%,#0c4b60);border-radius:24px;padding:30px 24px;color:#fff;box-shadow:0 18px 45px rgba(0,0,0,.12);margin-bottom:18px;}
.wwf-pattern-hero h1{margin:12px 0 8px;font-size:clamp(28px,4vw,44px);line-height:1.1;color:#fff;}
.wwf-pattern-hero p{max-width:760px;margin:0;color:rgba(255,255,255,.78);line-height:1.75;}
.wwf-pattern-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin:18px 0;}
.wwf-pattern-stats div{background:#fff;border:1px solid rgba(11,53,80,.08);border-radius:18px;padding:16px;text-align:center;box-shadow:0 10px 26px rgba(8,42,66,.06);}
.wwf-pattern-stats strong{display:block;font-size:28px;color:#0b3550;line-height:1;}
.wwf-pattern-stats span{display:block;margin-top:8px;color:#657888;font-size:13px;}
.wwf-pattern-filters{background:#fff;border:1px solid rgba(11,53,80,.08);border-radius:20px;padding:14px 16px;margin:16px 0;box-shadow:0 10px 26px rgba(8,42,66,.05);}
.wwf-filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:8px 0;}
.wwf-filter-row>span{font-weight:700;color:#173044;margin-right:2px;}
.wwf-filter-btn{border:1px solid rgba(11,53,80,.16);background:#f7fbfd;color:#173044;border-radius:999px;padding:7px 13px;line-height:1;cursor:pointer;font-size:14px;}
.wwf-filter-btn.is-active{background:#0b3550;color:#fff;border-color:#0b3550;}
.wwf-pattern-note,.wwf-pattern-sync-tip,.wwf-pattern-empty{background:#f7fbfd;border:1px solid rgba(11,53,80,.08);border-radius:18px;padding:14px 16px;line-height:1.75;margin:16px 0;color:#40566a;}
.wwf-pattern-sync-tip h2{margin:0 0 6px;color:#173044;font-size:20px;}
.wwf-pattern-sync-tip p{margin:6px 0;}
.wwf-pattern-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin-top:18px;}
.wwf-pattern-card{background:#fff;border:1px solid rgba(11,53,80,.08);border-radius:22px;overflow:hidden;box-shadow:0 12px 30px rgba(8,42,66,.08);}
.wwf-pattern-thumb{aspect-ratio:1/1;background:linear-gradient(135deg,#f8fbfd,#eef5f7);display:flex;align-items:center;justify-content:center;padding:18px;}
.wwf-pattern-thumb img{max-width:100%;max-height:100%;object-fit:contain;display:block;}
.wwf-pattern-body{padding:14px 14px 16px;}
.wwf-pattern-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px;}
.wwf-pattern-tags span{font-size:12px;background:#eef6f8;color:#285169;border-radius:999px;padding:4px 8px;}
.wwf-pattern-body h3{font-size:16px;line-height:1.35;margin:0 0 7px;color:#173044;}
.wwf-pattern-body p{font-size:13px;line-height:1.6;color:#657888;margin:0;}
.wwf-pattern-body code{display:block;margin-top:8px;font-size:11px;white-space:normal;color:#64748b;background:#f7fafc;border-radius:8px;padding:6px;}
@media (max-width: 980px){.wwf-pattern-grid{grid-template-columns:repeat(3,minmax(0,1fr));}.wwf-pattern-stats{grid-template-columns:repeat(2,minmax(0,1fr));}}
@media (max-width: 680px){.wwf-pattern-library{padding:16px 10px 30px;}.wwf-pattern-hero{border-radius:20px;padding:22px 18px;}.wwf-pattern-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}.wwf-pattern-thumb{padding:12px;}.wwf-pattern-body{padding:12px;}.wwf-pattern-tags span{font-size:11px;padding:4px 7px;}.wwf-pattern-body h3{font-size:14px;}.wwf-pattern-body p{display:none;}}

.wwf-badge-soft{background:#f4f8fb!important;color:#355064!important;border:1px solid #dce8ef!important}
