.admin-layout { padding-top: 80px; display:flex; }
.sidebar { width: 240px; background:#fff; box-shadow: var(--shadow); position: sticky; top:80px; height: calc(100vh - 80px); padding:12px; }
.sidebar-section { display:flex; flex-direction:column; gap:8px; }
.sidebar-link { display:flex; align-items:center; gap:8px; padding:10px 12px; border-radius:8px; color:#555; }
.sidebar-link.active, .sidebar-link:hover { background: var(--secondary-color); color:#333; }

.admin-content { flex:1; padding: 12px; }
.content-card { background:#fff; border-radius:10px; box-shadow: var(--shadow); padding:16px; min-height: 60vh; }

/* 相册管理区块更紧凑：不强制最低高度 */
.content-card.albums-compact { min-height: 0; }

/* 列表操作区布局优化 */
.log-item { gap:10px; }
.log-actions { display:flex; gap:6px; flex-wrap: wrap; align-items:center; justify-content:flex-end; }
.btn-sm { padding: 8px 12px; border-radius: 18px; font-size: 12px; }

@media (max-width: 768px){
  .log-item { flex-direction: column; align-items: stretch; }
  .log-left { align-items:flex-start; }
  .log-actions { width:100%; justify-content:flex-start; margin-top:6px; }
}

@media (max-width: 992px){
  .sidebar { position:fixed; left:-260px; top:65px; height: calc(100vh - 65px); transition: var(--transition); z-index:1002; }
  .sidebar.open { left:10px; }
}

/* 次卡卡片（用户维度，卡片芯片） */
.user-card { border:1px solid var(--border-color); border-radius:10px; padding:12px; margin-bottom:10px; }
.user-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.user-header .meta { color:#999; font-size:13px; }
.card-chips { display:flex; flex-wrap:wrap; gap:8px; }
.card-chip { display:inline-flex; align-items:center; gap:8px; padding:8px 10px; border:1px solid var(--border-color); border-radius:20px; cursor:pointer; background:#fff; }
.card-chip .count { font-weight:700; color: var(--accent-color); }
.card-chip.bath { border-color:#49c66e; }
.card-chip.rehab { border-color:#e77ea9; }
.card-chip:hover { box-shadow: var(--shadow); }

/* ===== 预约管理样式 ===== */
.booking-item {
  padding: 16px;
  margin-bottom: 12px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #e0e0e0;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.booking-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  padding-bottom: 10px;
  border-bottom: 1px solid #f0f0f0;
}

.booking-user {
  display: flex;
  align-items: center;
  gap: 16px;
}

.user-name {
  font-weight: 600;
  font-size: 15px;
  color: #333;
}

.user-phone {
  color: #666;
  font-size: 13px;
  padding: 4px 10px;
  background: #f5f5f5;
  border-radius: 12px;
}

.booking-time {
  color: #666;
  font-size: 13px;
  font-weight: 500;
  padding: 4px 10px;
  background: #e8f5e9;
  border-radius: 12px;
}

.booking-details {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
}

.booking-actions {
  display: flex;
  gap: 6px;
  justify-content: flex-end;
}

.badge {
  padding: 4px 12px;
  border-radius: 12px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
}

.badge-type {
  background: #e3f2fd;
  color: #1976d2;
}

.badge-status {
  font-weight: 600;
}

.badge-card {
  background: #fff3e0;
  color: #f57c00;
  border: 1px solid #ffb74d;
}

.badge-note {
  background: #f5f5f5;
  color: #666;
  max-width: 200px;
  overflow: hidden;
  text-overflow: ellipsis;
}

.badge-completed {
  background: #f3e5f5;
  color: #9b59b6;
}

.btn-confirm { background: #4caf50 !important; color: white !important; }
.btn-cancel { background: #ff9800 !important; color: white !important; }
.btn-reject { background: #ff9800 !important; color: white !important; }
.btn-deduct { background: #9c27b0 !important; color: white !important; }
.btn-delete { background: #f44336 !important; color: white !important; }

/* ===== 评价管理样式 ===== */
.review-item {
  padding: 16px;
  margin-bottom: 12px;
  border-radius: 8px;
  background: #fff;
  border: 1px solid #e0e0e0;
  box-shadow: 0 2px 4px rgba(0,0,0,0.05);
}

.review-content {
  display: flex;
  gap: 12px;
}

.review-image {
  width: 96px;
  height: 64px;
  object-fit: cover;
  border-radius: 6px;
  border: 1px solid var(--border-color);
  flex-shrink: 0;
}

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

.review-header {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-bottom: 8px;
}

.review-user {
  font-weight: 600;
  color: #333;
}

.review-stars {
  color: #f5a623;
}

.review-status {
  color: #999;
  font-size: 12px;
  padding: 2px 8px;
  background: #f5f5f5;
  border-radius: 10px;
}

.review-text {
  color: #444;
  white-space: pre-wrap;
  word-break: break-word;
  margin-bottom: 10px;
  line-height: 1.6;
}

.review-actions {
  display: flex;
  gap: 6px;
}

.btn-approve { background: #4caf50 !important; color: white !important; }
.btn-home { background: var(--primary-color) !important; color: white !important; }

/* 电脑端固定布局 */
@media (min-width: 769px) {
  .booking-details {
    flex-wrap: nowrap;
  }
  .booking-actions {
    flex-wrap: nowrap;
  }
  .review-header {
    flex-wrap: nowrap;
  }
  .review-actions {
    flex-wrap: nowrap;
  }
}

/* 手机端响应式 */
@media (max-width: 768px) {
  .booking-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
  }
  .booking-user {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .user-phone {
    font-size: 12px;
  }
  .booking-time {
    font-size: 12px;
  }
  .booking-details {
    flex-wrap: wrap;
  }
  .booking-actions {
    flex-wrap: wrap;
  }
  .review-content {
    flex-direction: column;
  }
  .review-image {
    width: 100%;
    height: 150px;
  }
  .review-header {
    flex-wrap: wrap;
  }
  .review-actions {
    flex-wrap: wrap;
  }
}

