.so-page{margin-bottom:24px}
.so-panel{border:1px solid rgba(148,163,184,.24);border-radius:14px;background:linear-gradient(180deg,rgba(30,41,59,.34) 0%,rgba(15,23,42,.18) 100%);box-shadow:0 10px 28px rgba(0,0,0,.16);padding:14px;overflow:visible}
.so-search-bar{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:12px;position:relative;z-index:100}
.so-suggest-wrap{position:relative;flex:1;min-width:240px;z-index:1;isolation:isolate}
.so-search-bar .so-suggest-wrap input{width:100%;box-sizing:border-box;padding:10px 12px;border-radius:12px;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.05);color:#e5e7eb;outline:none}
/* 下拉叠在下方内容上，不参与文档流高度（避免把「约 N 个结果」整块顶下去） */
.so-suggest-wrap .so-suggest-list,
.so-search-bar .so-suggest-list{
  position:absolute;
  left:0;
  right:0;
  top:100%;
  width:100%;
  box-sizing:border-box;
  margin:4px 0 0;
  padding:6px 0;
  list-style:none;
  border-radius:12px;
  border:1px solid rgba(148,163,184,.28);
  background:rgba(15,23,42,.96);
  box-shadow:0 12px 28px rgba(0,0,0,.35);
  max-height:min(40vh,320px);
  overflow-y:auto;
  overflow-x:hidden;
  z-index:100;
}
.so-suggest-list:not([hidden]){
  display:block;
}
.so-suggest-item{padding:8px 12px;color:#e5e7eb;font-size:14px;cursor:pointer;line-height:1.4}
.so-suggest-item:hover,.so-suggest-item.is-active{background:rgba(59,130,246,.25);color:#fff}
.so-search-bar button{padding:10px 14px;border-radius:12px;border:1px solid rgba(148,163,184,.28);background:rgba(255,255,255,.08);color:#e5e7eb;cursor:pointer}
.so-result-count{position:relative;z-index:0;color:#94a3b8;font-size:13px;margin-bottom:12px}
.so-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.so-card{border:1px solid rgba(148,163,184,.22);border-radius:14px;background:rgba(15,23,42,.62);padding:14px;transition:all .22s ease;text-decoration:none;display:block}
.so-card:hover{border-color:rgba(59,130,246,.45);transform:translateY(-2px)}
.so-title-thumb{flex-shrink:0;width:1em;height:1em;font-size:inherit;display:inline-flex;align-items:center;justify-content:center;border-radius:3px;overflow:hidden;border:1px solid rgba(148,163,184,.28);background:rgba(2,6,23,.55);box-sizing:border-box}
.so-title-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.so-title-thumb--empty{padding:1px}
.so-title-thumb--empty .so-model-icon{margin-left:0;opacity:1}
.so-title-thumb--empty .so-model-icon svg{width:0.85em;height:0.85em}
.so-title{color:#e5e7eb;font-weight:600;line-height:1.55;margin-bottom:0;min-width:0;flex:1}
.so-desc{font-size:13px;color:#cbd5e1;line-height:1.82;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.so-card-body{display:flex;gap:12px;align-items:flex-start}
.so-thumb{position:relative;flex:0 0 150px;width:150px;aspect-ratio:16/9;border-radius:10px;overflow:hidden;border:1px solid rgba(148,163,184,.2);background:rgba(2,6,23,.65)}
.so-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.so-title-row{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:1em}
.so-model-tag{flex:0 0 auto;font-size:11px;line-height:1.2;padding:3px 8px;border-radius:999px;border:1px solid rgba(148,163,184,.35);background:rgba(30,41,59,.55);color:#cbd5e1;white-space:nowrap}
.so-model-tag-under{display:inline-flex;margin-top:6px}
.so-main{min-width:0;flex:1}
.so-foot{margin-top:8px;display:flex;justify-content:space-between;gap:8px;flex-wrap:wrap;color:#94a3b8;font-size:12px}
.so-foot-left{display:inline-flex;gap:10px;align-items:center;flex-wrap:wrap}
.so-model-icon{display:inline-flex;align-items:center;justify-content:center;margin-left:6px;vertical-align:-2px;color:#94a3b8;opacity:.92}
.so-model-icon svg{width:14px;height:14px;display:block}
.so-empty{padding:24px 12px;color:#94a3b8;text-align:center}
.so-title em,.so-desc em{font-style:normal;color:#fbbf24}
.so-pager{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-top:16px}
.so-pager a,.so-pager span{min-width:34px;height:34px;padding:0 10px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;border:1px solid rgba(148,163,184,.32);background:rgba(15,23,42,.52);color:#cbd5e1;text-decoration:none;font-size:13px}
.so-pager a:hover{border-color:rgba(59,130,246,.55);color:#fff}
.so-pager .is-active{background:#1d4ed8;border-color:#1d4ed8;color:#fff}
.so-pager .is-disabled{opacity:.45;cursor:not-allowed}
.so-section-header{margin-top:10px}
@media (max-width:1100px){.so-grid{grid-template-columns:1fr}}
@media (max-width:680px){.so-card-body{flex-direction:column}.so-thumb{width:100%;flex-basis:auto}}
