/* ===========================
   TOPS (Slider) – 1 Bild/Slide, Swipe-Highlight
   =========================== */

:root{
  --wrap:   clamp(1rem, 3vw, 3.5rem);
  --card-radius: 16px;
  --card-shadow: 0 10px 30px rgba(0,0,0,.15);

  /* Karten-Format: Desktop 5:4, Mobile 1:1 */
  --card-ratio-d: 5 / 4;
  --card-ratio-m: 1 / 1;

  /* Panel Höhe + Timing (öffnen mit kleinem Bounce) */
  --panel-h: 92vh;
  --panel-dur: 900ms;
  --panel-ease: cubic-bezier(.22,1,.36,1); /* soft easeOut, Bounce via keyframes */
  --panel-side-gap: 50px; /* Desktop-Rand links/rechts (20–50px möglich) */

  /* Scrim Blur */
  --scrim-bg: rgba(10,10,12,.45);
  --scrim-blur: 10px;
}
.vsr-tops{  }

.vsr-tops__container{max-width:1200px;margin:0 auto;padding:0 var(--wrap)}
.vsr-tops .char-text h2,.vsr-favs .char-text h2{color:#000;-webkit-text-fill-color:initial;background:none}
.vsr-tops .quote,.vsr-favs .quote{color:#000}

.vsr-tops__viewport{
  position:relative;
  overflow-x:auto; overflow-y:hidden;
  -webkit-overflow-scrolling:touch; scrollbar-width:thin;
  scroll-snap-type:x mandatory;
}
.vsr-tops__track{
  display:flex; gap:clamp(14px,2.5vw,24px); align-items:center; padding-bottom:6px;
  width:max-content;
}

/* Basisbreiten (nicht zu groß auf Desktop) */
.vsr-tops__item{
  position:relative;
  flex:0 0 clamp(320px, 44vw, 560px);
  filter:blur(2px) saturate(.9);
  opacity:.78; transform:scale(.92);
  transition:transform .28s ease, filter .28s ease, opacity .28s ease;
  will-change:transform;
  scroll-snap-align:center;
}
@media (max-width:900px){
  .vsr-tops__item{flex-basis:84vw}
}

.vsr-tops__item.is-active{filter:none; opacity:1; transform:scale(1)}

.vsr-tops__imgwrap{
  position:relative; border-radius:var(--card-radius); overflow:hidden;
  box-shadow:var(--card-shadow);
  aspect-ratio: var(--card-ratio-d);
}
@media (max-width:900px){
  .vsr-tops__imgwrap{aspect-ratio: var(--card-ratio-m)}
}
.vsr-tops__imgwrap img{
  display:block; width:100%; height:100%;
  object-fit:cover; object-position:center;
  border-radius:var(--card-radius);
}

/* Like-Button */
.vsr-like{
  position:absolute; top:.6rem; right:.6rem; width:38px; height:38px;
  border-radius:50%;
  border:2px solid rgba(255,255,255,.95);
  background:rgba(0,0,0,.45); color:#fff; display:grid; place-items:center;
  cursor:pointer; z-index:3; opacity:0; transform:translateY(-6px);
  transition:opacity .2s ease, transform .2s ease, background .2s ease, box-shadow .2s ease;
}
.vsr-tops__imgwrap:hover .vsr-like{opacity:1; transform:translateY(0)}
.vsr-like.is-on{opacity:1 !important; background:#fff; color:#000; border-color:#fff; box-shadow:0 6px 18px rgba(0,0,0,.15)}
.vsr-like:hover{transform:translateY(0) scale(1.06)}

/* Caption */
.vsr-tops__caption{position:absolute; left:0; right:0; bottom:0; height:72px; pointer-events:none}
.vsr-tops__gradient{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.65) 100%);
  z-index:0;
}
.vsr-tops__caption-inner{
  --pad-x:.9rem; --pad-y:.7rem;
  position:absolute; left:0; right:0; bottom:0; height:72px; display:flex; align-items:flex-end; justify-content:space-between;
  padding:var(--pad-y) var(--pad-x); z-index:2;
}
.vsr-tops__name{color:#fff; font-weight:800; line-height:1; margin:0}
.vsr-tops__view{
  pointer-events:auto; border:2px solid #000; background:#fff; color:#000; font-weight:800;
  padding:.38rem .9rem; border-radius:999px; cursor:pointer; opacity:0; transform:translateY(6px);
  transition:opacity .25s ease, transform .25s ease, box-shadow .25s ease; line-height:1;
}
.vsr-tops__imgwrap:hover .vsr-tops__view{opacity:1; transform:translateY(0)}
.vsr-tops__view:hover{box-shadow:0 8px 22px rgba(0,0,0,.18)}

/* Deko-Lippe */
.vsr-tops__imgwrap::after{
  content:""; position:absolute; right:0; bottom:-100px; height:72px; width:min(45%,340px);
  background:#fff; transform:translateY(100%); transition:transform .25s ease; z-index:1; border-top-left-radius:12px;
}
.vsr-tops__imgwrap:hover::after{transform:translateY(0)}

.vsr-tops__controls{display:flex; gap:.6rem; justify-content:center; margin-top:16px}
.btn{
  border:2px solid #000; background:#000; color:#fff; font-weight:800; border-radius:999px; padding:.6rem 1.2rem; cursor:pointer;
  transition:transform .15s ease, box-shadow .25s ease, background .2s ease, color .2s ease, border-color .2s ease;
}
.btn:hover{transform:translateY(-1px); box-shadow:0 10px 24px rgba(0,0,0,.18)}
.vsr-tops__openpanel{background:transparent; color:#000}
.vsr-tops__openpanel:hover{background:#000; color:#fff}

/* ===========================
   PANEL – sanft mit Bounce, Blur-Hintergrund, Desktop-Margins
   =========================== */
.vsr-panel[hidden]{display:none}
.vsr-panel{position:fixed; inset:0; z-index:6000}

/* Scrim mit Blur */
.vsr-panel__scrim{
  position:absolute; inset:0; background:var(--scrim-bg);
  opacity:0; transition:opacity var(--panel-dur) ease;
  backdrop-filter: blur(var(--scrim-blur));
  -webkit-backdrop-filter: blur(var(--scrim-blur));
}

/* Sheet */
.vsr-panel__sheet{
  position:fixed; left:0; right:0; bottom:0;
  height:var(--panel-h);
  background:#fff; color:#000; border-radius:18px 18px 0 0;
  transform:translateY(110%); /* Start off-screen */
  box-shadow:0 -20px 50px rgba(0,0,0,.22);
  display:flex; flex-direction:column; overflow:auto;
  will-change:transform;
}

/* Desktop: mittig, links/rechts Rand, max-Breite = 90vh */
@media (min-width:1024px){
  .vsr-panel__sheet{
    left:50%; right:auto;
    width:min(90vh, calc(100vw - (var(--panel-side-gap)*2)));
    transform:translate(-50%, 110%);
    border-radius:22px;
  }
}

/* Öffnen: Scrim sichtbar + Keyframe-Bounce */
.vsr-panel.is-open .vsr-panel__scrim{opacity:1}
.vsr-panel.is-open .vsr-panel__sheet{
  animation: panelUp var(--panel-dur) var(--panel-ease) forwards;
}

/* Schließen: eigener Keyframe (nach JS-Klasse .is-leaving) */
.vsr-panel.is-leaving .vsr-panel__scrim{opacity:0}
.vsr-panel.is-leaving .vsr-panel__sheet{
  animation: panelDown 420ms cubic-bezier(.2,.7,.4,1) forwards;
}

@keyframes panelUp{
  0%   { transform: translateY(110%); }
  70%  { transform: translateY(-2%); }   /* kleiner Overshoot */
  100% { transform: translateY(0%); }
}
@media (min-width:1024px){
  @keyframes panelUp{
    0%   { transform: translate(-50%, 110%); }
    70%  { transform: translate(-50%, -2%); }
    100% { transform: translate(-50%, 0%); }
  }
}
@keyframes panelDown{
  0%   { transform: translateY(0%); }
  100% { transform: translateY(110%); }
}
@media (min-width:1024px){
  @keyframes panelDown{
    0%   { transform: translate(-50%, 0%); }
    100% { transform: translate(-50%, 110%); }
  }
}

/* Close-Button (SVG, Safari-safe) */
.vsr-panel__close{
  position:absolute; top:12px; right:12px;
  width:44px; height:44px; border-radius:999px;
  display:grid; place-items:center;
  background:#000; color:#fff; border:3px solid #000; cursor:pointer; z-index:10;
  box-shadow:0 8px 22px rgba(0,0,0,.18);
  transition:transform .18s ease, box-shadow .25s ease;
}
.vsr-panel__close svg{width:20px; height:20px; display:block}
.vsr-panel__close:hover{transform:scale(1.06)}

/* Kopf */
.vsr-panel__head{padding:clamp(18px,3vw,28px) clamp(16px,3vw,24px) 8px}
.vsr-panel__title{
  font-size:clamp(2.2rem,8vw,3.2rem);
  font-weight:900; letter-spacing:-.01em; line-height:1.05;
  margin:.2rem 0 .3rem;
}
.vsr-panel__desc{
  color:#000; opacity:.9; margin:.2rem 0 1.1rem; max-width:min(1000px,95vw);
  font-size:clamp(1rem,1.4vw,1.08rem); line-height:1.6; margin-top: 20px;
}

/* ===========================
   ECHTES MASONRY (ohne Lücken, schöneres Intro der Bilder)
   =========================== */
.vsr-masonry{
  display:grid;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  gap:clamp(12px, 2.2vw, 22px);
  padding:0 clamp(16px,3vw,24px) clamp(28px,4vw,40px);
}
.vsr-masonry__item{
  margin:0;
  opacity:0;
  transform:translateY(12px);
  transition:opacity .35s ease, transform .35s ease;
}
.vsr-masonry__item.is-in{
  opacity:1;
  transform:translateY(0);
}
.vsr-masonry__item img{
  width:100%; height:auto; display:block; border-radius:14px;
  box-shadow:0 6px 18px rgba(0,0,0,.1);
  transition:transform .25s ease, box-shadow .25s ease, filter .25s ease;
}
.vsr-masonry__item img:hover{
  transform:translateY(-2px) scale(1.012);
  box-shadow:0 12px 28px rgba(0,0,0,.16);
  filter:brightness(1.03);
}

/* Body-Scroll sperren, wenn Paneel offen */
body.vsr-no-scroll{overflow:hidden}


