.join-story-reel{
  --bg:#fff;
  --ink:#0b3a6f;
  --wrap:min(1100px, calc(100% - 64px));
  --gap: clamp(16px, 2vw, 26px);
  --radius: 18px;

  background: var(--bg);
  padding: clamp(34px, 5vw, 72px) 0;
  position: relative;
}

.jsr-wrap{ width: var(--wrap); margin: 0 auto; }

.jsr-title{
  margin: 0 0 clamp(18px, 3vw, 34px) 0;
  text-align: center;
  font-family: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  font-weight: 500;
  letter-spacing: .2px;
  color: var(--ink);
  font-size: clamp(34px, 4.2vw, 58px);
  line-height: 1.1;
}

/* ── Grid mode (≤3 kart) ── */
.jsr-reel{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--gap);
  justify-items: center;
}

/* ── Swiper mode (>3 kart, JS tarafından .is-swiper eklenir) ── */
.jsr-reel.is-swiper {
  display: block;
  overflow: hidden;
  position: relative;
}

.jsr-track {
  display: flex;
  gap: var(--gap);
  transition: transform .4s cubic-bezier(.4,0,.2,1);
  will-change: transform;
}

.jsr-track .jsr-card {
  flex: 0 0 calc(33.333% - (var(--gap) * 2 / 3));
  max-width: none;
}

/* Nav buttons */
.jsr-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: 1px solid rgba(0,0,0,.12);
  background: #fff;
  box-shadow: 0 4px 14px rgba(0,0,0,.14);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background .15s, opacity .15s;
  color: #1a1a1a;
}
.jsr-nav:hover  { background: #f1f5f9; }
.jsr-nav:disabled { opacity: .3; cursor: default; }
.jsr-prev { left: -22px; }
.jsr-next { right: -22px; }
.jsr-nav svg { width: 18px; height: 18px; }

/* Dots */
.jsr-dots {
  display: flex;
  justify-content: center;
  gap: 7px;
  margin-top: 22px;
}
.jsr-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #d1d5db;
  border: none;
  padding: 0;
  cursor: pointer;
  transition: background .2s, transform .2s;
}
.jsr-dot.is-active {
  background: var(--ink);
  transform: scale(1.25);
}

/* Card */
.jsr-card{
  width: 100%;
  max-width: 320px;
  aspect-ratio: 9 / 16;
  border-radius: var(--radius);
  border: 0;
  padding: 0;
  cursor: pointer;
  position: relative;
  overflow: hidden;
  box-shadow: 0 18px 44px rgba(0,0,0,.12);
  background: #000;
}

.jsr-card:focus-visible{
  outline: 2px solid rgba(11,58,111,.55);
  outline-offset: 3px;
}

.jsr-video{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
  object-position: 50% 50%;
}

/* play overlay */
.jsr-play{
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  pointer-events: none;
}
.jsr-play::before{
  content:"";
  width: 54px;
  height: 54px;
  border-radius: 999px;
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  box-shadow: 0 10px 26px rgba(0,0,0,.18);
}
.jsr-play::after{
  content:"";
  position: absolute;
  width: 0;
  height: 0;
  border-left: 14px solid rgba(20,23,26,.9);
  border-top: 9px solid transparent;
  border-bottom: 9px solid transparent;
  transform: translateX(2px);
}

@media (hover:hover){
  .jsr-card:hover{
    transform: translateY(-2px);
    transition: transform .18s ease;
  }
}

/* Join widget hidden */
.jsr-join-mount{
  position: absolute;
  width: 1px;
  height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

/* ── Mobile ── */
@media (max-width: 640px){
  .join-story-reel{ --wrap: min(100%, calc(100% - 32px)); }

  /* Grid mode mobilde scroll-snap */
  .jsr-reel:not(.is-swiper){
    display: flex;
    gap: 14px;
    overflow-x: auto;
    overflow-y: hidden;
    scroll-snap-type: x mandatory;
    -webkit-overflow-scrolling: touch;
    padding: 4px 2px 12px;
  }
  .jsr-reel:not(.is-swiper) .jsr-card{
    flex: 0 0 78%;
    max-width: none;
    scroll-snap-align: center;
  }
  .jsr-reel:not(.is-swiper)::-webkit-scrollbar{ display: none; }

  /* Swiper mode mobilde 1 kart */
  .jsr-reel.is-swiper .jsr-track .jsr-card {
    flex: 0 0 100%;
  }

  /* Nav butonlarını içe al */
  .jsr-prev { left: 4px; }
  .jsr-next { right: 4px; }
}

/* Tablet */
@media (max-width: 980px) and (min-width: 641px){
  .jsr-reel:not(.is-swiper){
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .jsr-reel:not(.is-swiper) .jsr-card{ max-width: 360px; }

  .jsr-reel.is-swiper .jsr-track .jsr-card {
    flex: 0 0 calc(50% - var(--gap) / 2);
  }
}

/* =========================
   MODAL (Frosted glass)
========================= */
.jsr-modal{
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: none;
}

.jsr-modal.is-open{ display: block; }

.jsr-modal__backdrop{
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.25);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

.jsr-modal__dialog{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: min(520px, calc(100% - 32px));
  border-radius: 22px;
  overflow: hidden;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.26);
  box-shadow: 0 30px 90px rgba(0,0,0,.35);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.jsr-modal__close{
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 2;
  width: 42px;
  height: 42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.35);
  background: rgba(255,255,255,.18);
  color: #fff;
  cursor: pointer;
}

.jsr-modal__close:focus-visible{
  outline: 2px solid rgba(255,255,255,.7);
  outline-offset: 3px;
}

.jsr-modal__media{
  width: 100%;
  aspect-ratio: 9 / 16;
  background: #000;
}

.jsr-modal__video{
  width: 100%;
  height: 100%;
  display: block;
  object-fit: cover;
}

body.jsr-lock{ overflow: hidden; }
