:root{
  --red:#951B16; --red-dark:#7a1612; --ink:#222; --muted:#6c757d;
  --bg:#f6f6f4; --card:#fff; --line:#e7e7e3;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  color:var(--ink); background:var(--bg); -webkit-font-smoothing:antialiased;
}
.wrap{max-width:1100px;margin:0 auto;padding:32px 20px 56px}
.head{text-align:center;margin:8px 0 28px}
.head h1{font-size:clamp(26px,4vw,40px);margin:0 0 8px;color:var(--ink);letter-spacing:-.01em}
.head .sub{margin:0 auto;max-width:620px;color:var(--muted);font-size:16px;line-height:1.5}

.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:22px}
.loading{grid-column:1/-1;text-align:center;color:var(--muted);padding:40px}

.card{
  background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;
  display:flex;flex-direction:column;box-shadow:0 2px 10px rgba(0,0,0,.04);
  transition:transform .18s ease, box-shadow .18s ease;
}
.card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.12)}
.card__cover{position:relative;aspect-ratio:760/1075;background:#ddd;cursor:pointer;overflow:hidden}
.card__cover img{width:100%;height:100%;object-fit:cover;display:block}
.card__cover::after{
  content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.28),transparent 38%);
  opacity:0;transition:opacity .18s ease;
}
.card:hover .card__cover::after{opacity:1}
.card__play{
  position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) scale(.9);
  width:64px;height:64px;border-radius:50%;background:rgba(149,27,22,.92);color:#fff;
  display:flex;align-items:center;justify-content:center;opacity:0;transition:all .2s ease;pointer-events:none;
}
.card:hover .card__play{opacity:1;transform:translate(-50%,-50%) scale(1)}
.card__body{padding:14px 16px 16px;display:flex;flex-direction:column;gap:10px}
.card__title{font-weight:700;font-size:17px;margin:0}
.card__meta{color:var(--muted);font-size:13px;margin:-4px 0 2px}
.card__actions{display:flex;gap:8px;margin-top:2px}
.btn{
  appearance:none;border:0;border-radius:9px;padding:10px 14px;font-weight:700;font-size:14px;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;text-decoration:none;
}
.btn--primary{background:var(--red);color:#fff;flex:1;justify-content:center}
.btn--primary:hover{background:var(--red-dark)}
.btn--ghost{background:#f1f1ee;color:var(--ink)}
.btn--ghost:hover{background:#e7e7e3}
.foot{text-align:center;color:var(--muted);font-size:13px;margin-top:40px}

/* Embed-Modus (im Shop per iFrame, ?embed=1): innere Kopf-/Fußzeile aus, Karten vertikal zentriert */
.embed body{background:#fff}
.embed .head,.embed .foot{display:none}
.embed .wrap{display:flex;flex-direction:column;justify-content:center;min-height:96vh;padding:24px 20px}

/* ---------- Viewer ---------- */
.viewer{position:fixed;inset:0;background:#1c1c1e;z-index:9999;display:flex;flex-direction:column}
.viewer[hidden]{display:none}
.viewer__bar{
  display:flex;align-items:center;gap:10px;padding:10px 14px;background:#141416;color:#fff;
  border-bottom:1px solid rgba(255,255,255,.08);flex:0 0 auto;
}
.viewer__title{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50vw}
.viewer__count{color:#aaa;font-size:13px;font-variant-numeric:tabular-nums}
.viewer__spacer{flex:1}
.vbtn{
  appearance:none;background:rgba(255,255,255,.08);color:#fff;border:0;border-radius:8px;
  height:38px;min-width:38px;padding:0 10px;display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  text-decoration:none;font-weight:600;font-size:14px;
}
.vbtn:hover{background:rgba(255,255,255,.18)}
.vbtn--close:hover{background:var(--red)}
.vbtn__t{font-size:13px}

.viewer__stage{position:relative;flex:1 1 auto;display:flex;align-items:center;justify-content:center;min-height:0;padding:14px}
.flip-host{width:100%;height:100%;display:flex;align-items:center;justify-content:center}
.flip-cap{height:100%;max-width:100%;margin:auto;aspect-ratio:3000 / 2105}
#flip{width:100%;height:100%}
.page{background:#fff;overflow:hidden}
.page img{width:100%;height:100%;display:block;object-fit:contain;background:#fff}
.page__ph{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;color:#bbb;font-size:13px}

.nav{
  position:absolute;top:50%;transform:translateY(-50%);z-index:5;
  width:48px;height:48px;border-radius:50%;border:0;cursor:pointer;
  background:rgba(255,255,255,.14);color:#fff;display:flex;align-items:center;justify-content:center;
}
.nav:hover{background:rgba(255,255,255,.28)}
.nav--prev{left:10px}
.nav--next{right:10px}
.nav:disabled{opacity:.3;cursor:default}

.viewer__foot{flex:0 0 auto;padding:12px 18px 16px;background:#141416}
#v-range{width:100%;accent-color:var(--red);cursor:pointer}

@media (max-width:600px){
  .vbtn__t{display:none}
  .viewer__title{max-width:38vw}
  .nav{width:40px;height:40px}
  .viewer__stage{padding:6px}
}
