/* Card view modes (covers wide/single, classic, titles), action buttons, video play, sub-cat badge, tags */

/* --- BASE: short description always clamped to 2 lines with ellipsis --- */
.card .short{
  display:-webkit-box !important;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
  text-overflow:ellipsis;
}

/* --- COVERS WIDE view (2 per row, larger thumbnails) --- */
.grid.view-covers-wide{
  grid-template-columns:repeat(2,1fr);gap:28px 24px;
}
.grid.view-covers-wide .card .thumb{aspect-ratio:16/10}
.grid.view-covers-wide .card h3{font-size:20px;line-height:1.25}
.grid.view-covers-wide .card .short{font-size:13.5px;-webkit-line-clamp:3}
.grid.view-covers-wide .card .bottom{padding:18px 22px 20px;gap:10px}
.grid.view-covers-wide .card .cat{font-size:11px}

/* --- COVERS SINGLE view (1 per row, magazine-style large hero) --- */
.grid.view-covers-single{
  grid-template-columns:1fr;gap:32px;
}
.grid.view-covers-single .card{max-width:900px;margin:0 auto;width:100%}
.grid.view-covers-single .card .thumb{aspect-ratio:16/9}
.grid.view-covers-single .card h3{font-size:26px;line-height:1.2;letter-spacing:-0.015em}
.grid.view-covers-single .card .short{font-size:14.5px;line-height:1.55;-webkit-line-clamp:4}
.grid.view-covers-single .card .bottom{padding:22px 28px 24px;gap:12px}
.grid.view-covers-single .card .cat{font-size:11.5px;letter-spacing:.2em}
.grid.view-covers-single .card .post-meta-line{padding-top:14px;font-size:12px}
.grid.view-covers-single .card .post-meta-line .pm-date,
.grid.view-covers-single .card .post-meta-line .pm-size{font-size:11.5px}
.grid.view-covers-single .card .post-meta-line .pm-ftype{width:26px;height:26px}
.grid.view-covers-single .card .post-meta-line .pm-ftype svg{width:26px;height:26px}

/* --- CLASSIC view (horizontal rows with small thumb) --- */
.grid.view-classic{
  grid-template-columns:1fr;gap:10px;
}
.grid.view-classic .card{
  flex-direction:row;align-items:stretch;
}
.grid.view-classic .card .thumb{
  width:220px;aspect-ratio:4/3;flex-shrink:0;
  border-right:1px solid var(--line);border-bottom:0;
}
.grid.view-classic .card .bottom{
  flex:1;padding:16px 20px;
}
.grid.view-classic .card h3{
  font-size:19px;
  min-height:calc(19px * 1.25 * 2);  /* match larger font-size */
}
.grid.view-classic .card .ruler{display:none}

/* --- TITLES ONLY view (compact text list) --- */
.grid.view-titles{
  grid-template-columns:1fr;gap:0;
  background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
}
.grid.view-titles .card{
  flex-direction:row;align-items:center;gap:18px;
  padding:12px 18px;border-radius:0;
  border:0;border-bottom:1px solid var(--line);background:transparent;
  animation:none;transform:none !important;
}
.grid.view-titles .card:last-child{border-bottom:0}
.grid.view-titles .card:hover{background:var(--surface-2);border-color:var(--line)}
.grid.view-titles .card .chips,
.grid.view-titles .card .fmt-overlay{display:none}
.grid.view-titles .card .bottom{
  padding:0;flex-direction:row;align-items:center;gap:18px;width:100%;flex:1;
  min-width:0;  /* allow title ellipsis */
}
.grid.view-titles .card .cat{
  width:200px;flex-shrink:0;margin:0;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  font-size:10px;letter-spacing:.12em;
  display:block;
}
.grid.view-titles .card .cat span{margin:0 4px}
.grid.view-titles .card h3{
  font-size:14px;flex:1;font-family:"Geist",sans-serif;font-weight:500;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  letter-spacing:0;
  min-height:auto;  /* disable 2-line min-height */
  min-width:0;  /* critical: allow flex child to shrink for ellipsis */
  display:block;
  -webkit-line-clamp:initial;-webkit-box-orient:initial;
  position:relative;  /* anchor for popup */
}

/* Titles view: meta line becomes inline, no border-top */
.grid.view-titles .card .post-meta-line{
  margin:0;padding:0;border:0;
  width:auto;flex-shrink:0;gap:10px;
  justify-content:flex-end;
}
.grid.view-titles .card .post-meta-line .pm-date{width:90px}
.grid.view-titles .card .post-meta-line .pm-author{
  width:120px;flex:none;text-align:right;
}
.grid.view-titles .card .post-meta-line .pm-size{width:62px;text-align:right}
.grid.view-titles .card .post-meta-line .pm-ftype{width:20px;height:20px}
.grid.view-titles .card .post-meta-line .pm-ftype svg{width:20px;height:20px}
.grid.view-titles .card .short{display:none}

/* ---------- TITLES VIEW: HOVER PREVIEW ---------- */
.grid.view-titles{position:relative;overflow:visible}
.grid.view-titles .card{position:relative;overflow:visible}

/* Thumb becomes a floating popup on hover, positioned ABOVE the row */
.grid.view-titles .card .thumb{
  display:block;
  position:absolute;
  left:210px;            /* right after the category column */
  bottom:calc(100% + 4px); /* float above the row */
  width:280px;height:175px;
  aspect-ratio:16/10;
  border-radius:10px;overflow:hidden;
  box-shadow:0 20px 50px -12px rgba(0,0,0,.9), 0 0 0 1px var(--line-strong);
  opacity:0;pointer-events:none;
  transform:translateY(6px) scale(.94);
  transform-origin:left bottom;
  transition:opacity .16s ease-out, transform .16s ease-out;
  z-index:50;
  background:var(--bg-2);
}
.grid.view-titles .card:hover .thumb{
  opacity:1;
  transform:translateY(0) scale(1);
}
/* First row: preview can't go above, position BELOW instead */
.grid.view-titles .card:first-child .thumb{
  bottom:auto;
  top:calc(100% + 4px);
  transform-origin:left top;
  transform:translateY(-6px) scale(.94);
}
.grid.view-titles .card:first-child:hover .thumb{
  transform:translateY(0) scale(1);
}
.grid.view-titles .card .thumb-bg{position:absolute;inset:0;border-radius:10px;background-size:cover;background-position:center}
.grid.view-titles .card .video-play-overlay{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:48px;height:48px;border-radius:50%;
  background:var(--accent);display:grid;place-items:center;color:#0b0b0a;
  box-shadow:0 6px 20px rgba(212,255,62,.5);
}
.grid.view-titles .card .video-play-overlay svg{width:20px;height:20px}
.grid.view-titles .card .card-actions,.grid.view-titles .card .fav-toggle{display:none}
.grid.view-titles .card:hover{z-index:20}
.grid.view-titles .card .meta{
  border:0;padding:0;margin:0;flex-shrink:0;min-width:180px;gap:18px;
  grid-template-columns:auto auto auto;justify-content:flex-end;
}
.grid.view-titles .card .fmt-label{
  display:inline-block;
  font-family:"JetBrains Mono",monospace;font-size:10px;font-weight:700;letter-spacing:.1em;
  padding:3px 7px;border-radius:4px;background:var(--bg-2);border:1px solid var(--line);
  color:var(--ink-soft);
}
.fmt-label{display:none}
.grid.view-titles .fmt-label{display:inline-block}

/* Hide cards beyond the selected count */
.grid[data-count="20"] .card:nth-child(n+21){display:none !important}
.grid[data-count="50"] .card:nth-child(n+51){display:none !important}
.grid[data-count="100"] .card:nth-child(n+101){display:none !important}
.grid[data-count="200"] .card:nth-child(n+201){display:none !important}

.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;
  transition:transform .2s, border-color .2s, background .2s;
  position:relative;
  min-width:0;  /* allow child ellipsis when in flex/grid */
}
.card:hover{transform:translateY(-3px);border-color:var(--line-strong);background:var(--surface-2)}
.card .thumb{
  position:relative;aspect-ratio:4/3;overflow:hidden;
  border-bottom:1px solid var(--line);
}
.card .thumb-bg{position:absolute;inset:0}
.card .thumb::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,transparent 55%, rgba(0,0,0,.55));
  pointer-events:none;
}
.card .chips{
  position:absolute;top:10px;left:10px;display:flex;gap:6px;flex-wrap:wrap;z-index:2;
}
.card .chip{
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.12em;text-transform:uppercase;
  padding:4px 8px;background:rgba(11,11,10,.75);border:1px solid rgba(255,255,255,.12);
  border-radius:6px;color:var(--ink);backdrop-filter:blur(6px);
}
.card .chip.free{background:var(--accent);color:#0b0b0a;border-color:var(--accent)}
.card .chip.new{background:var(--accent-2);color:#fff;border-color:var(--accent-2)}
.card .chip.hot{background:#ff3366;color:#fff;border-color:#ff3366}
.card .chip.pro{background:linear-gradient(135deg,#a594f7,#6c5ce7);color:#fff;border-color:#8676e0}

/* Video play overlay (for posts with hasVideo:true) */
.card .video-play-overlay{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:52px;height:52px;border-radius:50%;
  background:rgba(212,255,62,.92);
  display:grid;place-items:center;z-index:2;
  box-shadow:0 6px 24px rgba(0,0,0,.45);
  transition:transform .2s, background .2s;
  pointer-events:none;
}
.card:hover .video-play-overlay{transform:translate(-50%,-50%) scale(1.08);background:var(--accent)}
.card .video-play-overlay svg{width:22px;height:22px;color:#0b0b0a;margin-left:3px}

/* Sub-category badge — shown inside cat line */

.card .fmt{
  position:absolute;right:44px;top:10px;
  font-family:"JetBrains Mono",monospace;font-size:10px;letter-spacing:.04em;font-weight:600;
  padding:5px 10px;border-radius:999px;
  background:var(--accent);color:#0b0b0a;
  border:1px solid var(--accent);
  text-transform:lowercase;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
  cursor:pointer;z-index:3;
  transition:transform .15s, box-shadow .15s, background .15s;
  text-decoration:none;display:inline-flex;align-items:center;
  box-shadow:0 2px 10px rgba(212,255,62,.25);
}
.card .fmt:hover{
  transform:translateY(-1px);
  background:#bff020;
  box-shadow:0 4px 14px rgba(212,255,62,.5);
}
.card .fmt:active{transform:translateY(0)}

/* Alt variant for secondary tags (if we add more later) */
.card .fmt.tag-sub{
  background:rgba(0,212,255,.95);border-color:rgba(0,212,255,1);
  box-shadow:0 2px 10px rgba(0,212,255,.25);
}
.card .fmt.tag-sub:hover{background:#00b8e0;box-shadow:0 4px 14px rgba(0,212,255,.5)}

