
:root {
  --cxut-accent: #4a7dff;
  --cxut-container: 1200px;
  --cxut-thumb-ar: 16 / 9;
  --cxut-gap: 16px;
}

.cxut-section { max-width: var(--cxut-container); width: 100%; margin: 0 auto 24px; }
.cxut-section-title {
  font-size: 20px;
  margin: 24px 0 12px;
  font-weight: 700;
  border-left: 4px solid var(--cxut-accent);
  padding-left: 8px;
}
.cxut-section-title-wrap{ display:flex; align-items:center; justify-content:space-between; gap:12px; margin-top:24px; margin-bottom:12px; }
.cxut-more-link{ font-size:14px; color: var(--cxut-accent); text-decoration:none; }
.cxut-more-link:hover{ text-decoration:underline; }

/* Grid */
.cxut-grid.auto-cols {
  max-width: var(--cxut-container);
  width: 100%;
  margin: 0 auto;
  display: grid;
  gap: var(--cxut-gap);
  grid-template-columns: repeat(auto-fit, minmax(var(--cxut-min, 200px), 1fr));
}
.cxut-grid.fixed-cols {
  max-width: var(--cxut-container);
  width: 100%;
  margin: 0 auto;
  display: grid;
  gap: var(--cxut-gap);
  grid-template-columns: repeat(var(--cxut-cols), 1fr);
}
@media (max-width: 640px) {
  .cxut-grid { gap: 12px; padding: 0 10px; }
  .cxut-grid[style*="--cxut-mobile-cols"] { grid-template-columns: repeat(var(--cxut-mobile-cols), 1fr); }
}

/* Card */
.cxut-card { background:#fff; border-radius: 12px; overflow: hidden; box-shadow: 0 6px 18px rgba(0,0,0,0.06); display:flex; flex-direction:column; transition: transform .18s ease, box-shadow .18s ease; }
.cxut-card:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(0,0,0,0.09); }

/* Media */
.cxut-media { display:block; position:relative; aspect-ratio: var(--cxut-thumb-ar); overflow:hidden; background:#f5f7fb; }
.cxut-media img { width:100%; height:100%; object-fit: cover; display:block; }
.cxut-media-placeholder { width:100%; height:100%; background: linear-gradient(135deg, #e9eefc, #f7f9ff); }

/* Content area (plugin skin) */
.cxut-content { padding: 10px 12px 12px; }
.cxut-title a { text-decoration:none; color:#111; font-weight:600; }
.cxut-title a:hover { color: var(--cxut-accent); }

/* Default 1-line clamp for title (applies to both theme and plugin title nodes) */
.case_info .meta-title,
.case_info .meta-title a,
.cxut-content .cxut-title,
.cxut-content .cxut-title a{
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  line-height: 1.4;
  height: 1.4em;
}

/* Hover overlay: show full title upward on thumbnail; keep frame fixed */
.cxut-card{ position: relative; }
.cxut-media{ position: relative; z-index: 1; }
.cxut-media::after{
  content: attr(data-title);
  position: absolute;
  left: 0; right: 0; bottom: 0;
  padding: 10px 12px 12px;
  background: linear-gradient(to top, rgba(0,0,0,.72), rgba(0,0,0,0));
  color: #fff;
  opacity: 0; transform: translateY(8px);
  transition: all .16s ease;
  pointer-events: none;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  white-space: normal;
}
.cxut-card:hover .cxut-media::after{ opacity: 1; transform: translateY(0); }
/* Hide the inline single-line title while hovering (avoid duplicate text) */
.cxut-card:hover .case_info .meta-title,
.cxut-card:hover .cxut-content .cxut-title{ visibility: hidden; }

/* Meta */
.cxut-meta { font-size: 12px; color: #666; display:flex; align-items:center; gap:8px; }
