/* ======== Banner ======== */
.trgsi-banner img{
  width:100%;
  height:420px;
  object-fit:cover;
  border-radius:12px;
}
@media(max-width:768px){
  .trgsi-banner img{height:200px;}
}

.trgsi-about-wrap{
  display:flex;
  gap:40px;
  align-items:center;
  flex-wrap:wrap;
}
.trgsi-about-video,
.trgsi-about-text{
  flex:1;
  min-width:260px;
}
.trgsi-about-video video{
  width:100%;
  height:auto;
  display:block;
  border-radius:12px;
}
.trgsi-about-text{
  line-height:1.8;
  font-size:16px;
}
@media(max-width:768px){
  .trgsi-about-wrap{flex-direction:column;}
}

#trgsiCasesSwiper .swiper-slide{width:260px;}
#trgsiCasesSwiper img{width:100%;border-radius:12px;}
@media(max-width:768px){
  #trgsiCasesSwiper .swiper-slide{width:180px;}
}

.trgsi-news-list{
  margin:0;padding:0;
}
.trgsi-news-list li{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 0;
  border-bottom:1px solid #eee;
}
.trgsi-news-date{
  font-size:14px;
  color:var(--trgsi-primary-light);
  white-space:nowrap;
}

.trgsi-links-inner {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 15px;
  flex-direction: row;
}
.trgsi-links-label {
  font-weight: bold;
  color: var(--trgsi-text);
  margin-right: 6px;
}

.trgsi-link-list {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  padding: 0;
  margin: 0;
}
.trgsi-link-list li {
  display: inline-block;
}
.trgsi-link-list li a {
  color: var(--trgsi-text);
  font-size: 15px;
  transition: 0.3s;
}
.trgsi-link-list li a:hover {
  color: var(--trgsi-primary-light);
  text-decoration: underline;
}

@media (max-width: 768px) {
  .trgsi-links-inner {
    flex-direction: column;
    align-items: flex-start;
  }
  .trgsi-link-list {
    justify-content: flex-start;
  }
}

.trgsi-section-title{
  font-size:1.5rem;
  margin-bottom:20px;
  color:var(--trgsi-primary);
  font-weight:bold;
}

.trgsi-cases-swiper .swiper-slide {
  width: 260px;
}
.trgsi-case-item {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(0,0,0,0.05);
  overflow: hidden;
  text-align: center;
}
.trgsi-case-image img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  display: block;
}
.trgsi-case-title {
  padding: 12px;
  font-size: 15px;
  color: #333;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.swiper-button-prev,
.swiper-button-next {
  color: #fff;
  width: 32px;
  height: 32px;
  background: rgba(0,0,0,0.3);
  border-radius: 50%;
  top: 40%;
}

.trgsi-news-list {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  margin: 0 -10px;
}

.trgsi-news-item {
  width: calc(25% - 20px); 
  background: #fff;
  border-radius: 10px;
  overflow: hidden;
  box-shadow: 0 2px 6px rgba(0,0,0,0.05);
  padding: 12px;
  display: flex;
  flex-direction: column;
}

.trgsi-news-thumb {
  width: 100%;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: 6px;
  margin-bottom: 10px;
}
.trgsi-news-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.trgsi-news-content {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}

.trgsi-news-title {
  font-weight: bold;
  font-size: 15px;
  color: var(--trgsi-text);
  margin-bottom: 6px;
  line-height: 1.4;
}
.trgsi-news-title:hover {
  color: var(--trgsi-primary-light);
}

.trgsi-news-desc {
  font-size: 14px;
  color: #666;
  flex-grow: 1;
  line-height: 1.6;
  margin-bottom: 8px;
}

.trgsi-news-date {
  font-size: 13px;
  color: #999;
}

@media (max-width: 768px) {
  .trgsi-news-list {
    flex-direction: column;
    gap: 16px;
    margin: 0;
  }

  .trgsi-news-item {
    flex-direction: row;
    align-items: flex-start;
    width: 100%;
    padding: 0;
    box-shadow: none;
    border-bottom: 1px solid #eee;
    border-radius: 0;
  }

  .trgsi-news-thumb {
    width: 100px;
    aspect-ratio: unset;
    height: 80px;
    margin: 0 10px 0 0;
    border-radius: 6px;
  }

  .trgsi-news-content {
    flex: 1;
    padding-right: 10px;
  }

  .trgsi-news-title {
    font-size: 15px;
    margin-bottom: 4px;
  }

  .trgsi-news-desc {
    font-size: 13px;
    color: #666;
    margin-bottom: 4px;
  }

  .trgsi-news-date {
    font-size: 12px;
    color: #aaa;
  }
}

.trgsi-news-list{
  display:flex;flex-wrap:wrap;gap:20px;margin:0 -10px;
}
.trgsi-news-item{
  width:calc(25% - 20px);
  background:#fff;border-radius:10px;overflow:hidden;
  box-shadow:0 2px 6px rgba(0,0,0,.05);
  padding:12px;display:flex;flex-direction:column;
}
.trgsi-news-thumb{width:100%;aspect-ratio:4/3;overflow:hidden;border-radius:6px;margin-bottom:10px;}
.trgsi-news-thumb img{width:100%;height:100%;object-fit:cover;display:block;}

.trgsi-news-content{flex:1;display:flex;flex-direction:column;justify-content:space-between;}
.trgsi-news-title{font-weight:bold;font-size:15px;color:var(--trgsi-text);margin-bottom:6px;line-height:1.4;}
.trgsi-news-title:hover{color:var(--trgsi-primary-light);}
.trgsi-news-desc{font-size:14px;color:#666;flex-grow:1;line-height:1.6;margin-bottom:8px;}
.trgsi-news-date{font-size:13px;color:#999;}

.trgsi-news-more{text-align:center;margin-top:20px;}
.trgsi-news-more a{
  display:inline-block;padding:8px 24px;
  background:var(--trgsi-primary-light);color:#fff;border-radius:6px;
  transition:.3s;
}
.trgsi-news-more a:hover{background:var(--trgsi-primary);}

@media(max-width:768px){
  .trgsi-news-item{width:100%;flex-direction:row;align-items:flex-start;padding:0;box-shadow:none;border-bottom:1px solid #eee;}
  .trgsi-news-thumb{width:100px;height:80px;aspect-ratio:auto;margin:0 10px 0 0;border-radius:6px;}
  .trgsi-news-content{padding-right:10px;}
  .trgsi-news-title{font-size:15px;margin-bottom:4px;}
  .trgsi-news-desc{font-size:13px;margin-bottom:4px;}
  .trgsi-news-date{font-size:12px;color:#aaa;}
}


/* 场馆列表卡片 2.0 优化版 */
.trgsi-venues {
  padding-top: 0px;
}

.trgsi-venues-card {
  margin-top: 16px;
  border-radius: 18px;
  padding: 18px 18px 20px;
  background: #f9fafb;
  box-shadow: 0 18px 40px rgba(15, 23, 42, 0.08);
}

/* 只影响场馆模块里的标题，不会影响别的 section */
.trgsi-venues-card .trgsi-section-title {
  font-size: 20px;
  margin-bottom: 12px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.trgsi-venues-card .trgsi-section-title::before {
  content: "";
  width: 4px;
  height: 18px;
  border-radius: 999px;
  background: linear-gradient(135deg, #2563eb, #60a5fa);
}

/* 使用网格布局，自适应 1 / 2 / 3 列 */
.trgsi-venue-list {
  display: grid;
  grid-template-columns: repeat(1, minmax(0, 1fr));
  gap: 10px;
  margin-top: 8px;
}

@media (min-width: 640px) {
  .trgsi-venue-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 1024px) {
  .trgsi-venue-list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.trgsi-venue-item {
  position: relative;
  overflow: hidden;
  border-radius: 14px;
  padding: 10px 12px;
  background:
    radial-gradient(circle at 0 0, rgba(59, 130, 246, .28), transparent 55%),
    #020617;
  box-shadow: 0 10px 25px rgba(15, 23, 42, 0.45);
  display: flex;
  align-items: center;
  gap: 10px;
}

.trgsi-venue-item::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid rgba(148, 163, 184, 0.24);
  pointer-events: none;
}

.trgsi-venue-logo {
  flex-shrink: 0;
}

.trgsi-venue-logo img {
  width: 44px;
  height: 44px;
  border-radius: 12px;   /* 想要圆头像改成 50% */
  object-fit: cover;
  display: block;
  background: #f3f4f6;
}

.trgsi-venue-info {
  flex: 1;
  min-width: 0;
}

.trgsi-venue-name {
  font-size: 15px;
  font-weight: 700;
  color: #e5f0ff;
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.trgsi-venue-desc {
  font-size: 12px;
  color: #cbd5f5;
  line-height: 1.5;
}

/* 可选：名字旁边的小徽标，比如“官方推荐” */
.trgsi-venue-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 6px;
  border-radius: 999px;
  font-size: 11px;
  background: rgba(15, 23, 42, 0.7);
  color: #e5f0ff;
  margin-left: 4px;
}

/* PC 端 hover 动画，移动端几乎感觉不到 */
@media (hover: hover) {
  .trgsi-venue-item {
    transition: transform .16s ease-out, box-shadow .16s ease-out;
  }
  .trgsi-venue-item:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 40px rgba(15, 23, 42, 0.55);
  }
}
