:root{--c:#111;--g:#666;--b:#0a7cff;--bg:#fff;--muted:#888;--bd:#eee;--card:#fafafa}
*{box-sizing:border-box}html{font-size:16px}body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial;line-height:1.6;color:var(--c);background:var(--bg)}
.container{max-width:1024px;margin:0 auto;padding:0 16px}
.site-header{position:sticky;top:0;background:rgba(255,255,255,.9);backdrop-filter:saturate(180%) blur(10px);border-bottom:1px solid var(--bd)}
.nav{display:flex;justify-content:space-between;align-items:center;height:56px}
.brand{font-weight:700;color:var(--c);text-decoration:none}
.menu a{margin-left:12px;color:var(--c);text-decoration:none}
.site-footer{border-top:1px solid var(--bd);padding:24px 0;margin-top:40px}
.hero{padding:32px 0 16px}
.muted{color:var(--muted)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:20px}
.grid--2{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.card{background:var(--card);border:1px solid var(--bd);border-radius:10px;overflow:hidden}
.card__body{display:block;color:inherit;text-decoration:none;padding:14px}
.card__media{background:#ddd;height:280px;border-radius:6px;overflow:hidden}
.card__media img{width:100%;height:100%;object-fit:cover;display:block}
.card__title{margin:8px 0 4px;font-size:1rem}
.card__meta{margin:4px 0 0;color:var(--g);font-size:.95rem}
.card--panel{padding:16px;text-decoration:none;color:inherit}

/* 评价卡片样式优化 */
#reviews .card--panel {
  padding: 24px;
  margin-bottom: 16px;
  border-radius: 12px;
  background: var(--bg);
  border: 1px solid var(--bd);
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#reviews .card--panel:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.05);
}

#reviews .card--panel strong {
  font-size: 1.1rem;
  color: var(--c);
  margin-right: 8px;
}

#reviews .card--panel .muted {
  color: var(--muted);
  font-size: 0.9rem;
}

#reviews .card--panel p {
  margin-top: 12px;
  line-height: 1.7;
  color: var(--c);
}

#reviews h2 {
  margin-bottom: 20px;
  font-size: 1.4rem;
  color: var(--c);
}

/* 星星评分样式 */
.star-rating {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 16px;
  line-height: 1;
}

.star-rating .star {
  display: inline-block;
  width: 16px;
  height: 16px;
  background-image: url('data:image/svg+xml;charset=utf-8,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23FFD700"%3E%3Cpath d="M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z"/%3E%3C/svg%3E');
  background-size: contain;
  background-repeat: no-repeat;
}

.star-rating .star.blank {
  background-image: url('data:image/svg+xml;charset=utf-8,%3Csvg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%23ddd"%3E%3Cpath d="M12 17.27L18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z"/%3E%3C/svg%3E');
}
.btn{display:inline-block;background:var(--b);color:#fff;border:none;border-radius:8px;padding:8px 14px;text-decoration:none;cursor:pointer}
.btn--ghost{background:transparent;color:var(--b);border:1px solid var(--b)}
.btn--link{background:transparent;border:none;color:var(--b);padding:0;cursor:pointer}
.danger{color:#c62828}
.center{text-align:center}.mt-sm{margin-top:12px}.mt-md{margin-top:24px}
.filters{display:flex;flex-wrap:wrap;gap:14px;margin:14px 0;padding:14px;border:1px solid var(--bd);border-radius:8px;background:#fff}
.filters label{display:flex;gap:8px;align-items:center;flex-wrap:nowrap;white-space:nowrap}
input,select,textarea{width:100%;max-width:420px;padding:8px;border:1px solid var(--bd);border-radius:6px;font:inherit}
label{display:block;margin:8px 0}
.flex{display:flex}.between{justify-content:space-between}.center-v{align-items:center}.gap-sm{gap:8px}
.table{width:100%;border:1px solid var(--bd);border-radius:8px;overflow:hidden}
.table__row{display:grid;grid-template-columns:40px 1.2fr 1fr .8fr .5fr .8fr .6fr 1fr;gap:8px;padding:8px 10px;border-top:1px solid var(--bd);align-items:center}
.table__head{background:#fafafa;font-weight:600}
.pagination{display:flex;gap:8px;margin-top:16px}
.pagination a{padding:6px 10px;border:1px solid var(--bd);border-radius:6px;text-decoration:none;color:var(--c)}
.pagination a.active{background:var(--b);color:#fff;border-color:var(--b)}
.alert{background:#fff3cd;border:1px solid #ffeeba;color:#856404;padding:8px 12px;border-radius:6px}
.detail__media{height:350px;background:#ddd;border-radius:8px;margin:12px 0;overflow:hidden}
.detail__media img{width:100%;height:100%;object-fit:cover;display:block}
.carousel{position:relative;height:100%;touch-action:pan-y;cursor:grab;user-select:none;}
.carousel:active{cursor:grabbing;}
.carousel__viewport{width:100%;height:100%;overflow:hidden;border-radius:8px}
.carousel__track{display:flex;width:100%;height:100%;transition:transform .3s ease}
.carousel__slide{min-width:100%;height:100%;}
.carousel__slide img{width:100%;height:100%;object-fit:cover;display:block;user-drag:none;-webkit-user-drag:none;cursor:pointer;transition:transform 0.2s ease}

.carousel__slide img:hover{
  transform:scale(1.02);
}

/* Lightbox styles */
#image-lightbox{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:100%;
  background-color:rgba(0,0,0,0.9);
  display:none;
  justify-content:center;
  align-items:center;
  z-index:1000;
  opacity:0;
  transition:opacity 0.3s ease;
}

.lightbox-close{
  position:absolute;
  top:20px;
  right:20px;
  color:white;
  background:none;
  border:none;
  font-size:30px;
  cursor:pointer;
  z-index:1001;
  padding:0;
  width:40px;
  height:40px;
  display:flex;
  justify-content:center;
  align-items:center;
}

.lightbox-close:hover{
  color:#f0f0f0;
}

.lightbox-content{
  max-width:90%;
  max-height:90%;
  display:flex;
  justify-content:center;
  align-items:center;
}

.lightbox-content img{
  max-width:100%;
  max-height:100vh;
  object-fit:contain;
  animation:fadeIn 0.3s ease;
}

@keyframes fadeIn{
  from{opacity:0;}
  to{opacity:1;}
}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
.carousel__indicators{position:absolute;bottom:12px;left:50%;transform:translateX(-50%);display:flex;gap:6px;z-index:10;}
.carousel__indicator{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,0.5);border:none;padding:0;cursor:pointer;transition:background-color 0.2s;}
.carousel__indicator.active{background:#fff;}
@media (max-width:640px){.table__row{grid-template-columns:24px 1fr .7fr .5fr .5fr .7fr .5fr .7fr}}
