.sp-stories{
  --sp-thumb-size:72px;
  --sp-thumb-spacing:12px;
  --sp-bg: rgba(0,0,0,0.65);
  --sp-caption-bg: rgba(220,220,220,0.70);
  --sp-caption-text: #111111;
  --sp-progress: rgba(255,255,255,0.85);
  --sp-caption-space: 92px;
}

.sp-stories-track{
  display:flex;
  align-items:flex-start;
  gap: var(--sp-thumb-spacing);
  overflow-x:auto;
  padding: 6px 2px;
}
.sp-story{
  border:0;
  background:transparent;
  padding:0;
  cursor:pointer;
  display:inline-flex;
  flex-direction:column;
  align-items:center;
  gap:6px;
  min-width: calc(var(--sp-thumb-size) + 2px);
}
.sp-thumb{
  width: var(--sp-thumb-size);
  height: var(--sp-thumb-size);
  border-radius: 999px;
  overflow:hidden;
  border: 2px solid rgba(255, 0, 120, 0.75);
  display:flex;
  align-items:center;
  justify-content:center;
  box-sizing:border-box;
}
.sp-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.sp-thumb-fallback{
  background: rgba(0,0,0,0.08);
  border-color: rgba(0,0,0,0.12);
  color:#111;
  font-weight:700;
}
.sp-title{
  font-size:12px;
  line-height:1.1;
  max-width: calc(var(--sp-thumb-size) + 18px);
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  color: var(--sp-caption-text);
}
.sp-thumb-add{
  border-style:dashed;
  border-color: rgba(0,0,0,0.18);
  background: rgba(0,0,0,0.05);
}
.sp-plus{ font-size: 34px; line-height: 1; color:#111; }

/* Viewer */
.sp-viewer{
  position:fixed;
  inset:0;
  display:none;
  z-index:99999;
  background: var(--sp-bg);
}
.sp-viewer.is-open{ display:flex; flex-direction:column; }
.sp-topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 10px 12px;
  color:#fff;
}
.sp-top-actions{ display:flex; align-items:center; gap:10px; }

.sp-close, .sp-delbtn{
  border:0;
  background: rgba(255,255,255,0.10);
  color:#fff;
  border-radius: 10px;
  width:40px;
  height:40px;
  cursor:pointer;
  font-size:20px;
  line-height:40px;
  display:none;
  align-items:center;
  justify-content:center;
}
.sp-close{ display:inline-flex; font-size:22px; }
.sp-delbtn.is-show{ display:inline-flex; }

.sp-progress{
  display:flex;
  gap:6px;
  padding: 0 12px 10px 12px;
}
.sp-progress > span{
  flex:1;
  height:3px;
  background: rgba(255,255,255,0.18);
  border-radius:999px;
  overflow:hidden;
}
.sp-progress > span > i{
  display:block;
  height:100%;
  width:0%;
  background: var(--sp-progress);
}

.sp-stage{
  position:relative;
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  box-sizing:border-box;
  padding-bottom: 0;
}
.sp-media{
  width:100%;
  height: 100%;
  display:flex;
  align-items:center;
  justify-content:center;
}
.sp-media img, .sp-media video{
  width:auto;
  height:auto;
  max-width: 92vw;
  max-height: calc(92vh - 120px);
  object-fit:contain;
  display:block;
}

.sp-caption{
  flex:1;
  font-size: 14px;
  line-height: 1.25;
}
.sp-caption-overlay{
  flex:0 0 auto;
  margin: 0 12px 12px 12px;
  display:none;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--sp-caption-bg);
  color: var(--sp-caption-text);
  box-sizing:border-box;
}

.sp-link{
  flex:0 0 auto;
  padding: 8px 10px;
  border-radius: 12px;
  text-decoration:none;
  background: rgba(0,0,0,0.08);
  color: inherit;
  font-size: 13px;
}

/* Upload modal */
.sp-upload-modal{ position:fixed; inset:0; z-index:100000; display:none; }
.sp-upload-modal.is-open{ display:block; }
.sp-upload-backdrop{ position:absolute; inset:0; background: rgba(0,0,0,0.55); }
.sp-upload-panel{ position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:min(720px, 92vw); max-height: 85vh; overflow:auto; background:#fff; border-radius:14px; padding:14px; box-shadow: 0 12px 40px rgba(0,0,0,0.35); }
.sp-upload-panel h3{ margin:0 0 10px 0; }
.sp-upload-row{ display:flex; gap:12px; padding:10px 0; border-top:1px solid #eee; }
.sp-upload-row:first-of-type{ border-top:0; }
.sp-upload-thumb{ width:72px; height:72px; border-radius:12px; background:#f2f2f2; display:flex; align-items:center; justify-content:center; overflow:hidden; flex:0 0 auto; }
.sp-upload-thumb img{ width:100%; height:100%; object-fit:cover; display:block; }
.sp-upload-fields{ flex:1; }
.sp-upload-fields label{ display:block; font-size:12px; margin:0 0 4px 0; color:#333; }
.sp-upload-fields textarea{ width:100%; min-height:60px; resize: both; }
.sp-upload-fields input[type='text']{ width:100%; }
.sp-upload-actions{ display:flex; justify-content:flex-end; gap:10px; margin-top:12px; }
.sp-btn{ border:0; padding:10px 14px; border-radius:10px; cursor:pointer; }
.sp-btn.primary{ background:#111; color:#fff; }
.sp-btn.ghost{ background:#eee; color:#111; }
.sp-upload-small{ font-size:12px; color:#666; margin-top:6px; }

@media (max-width: 600px){
  .sp-stories{ --sp-caption-space: 96px; }
  .sp-media img, .sp-media video{ max-width: 94vw; max-height: calc(94vh - 130px); }
}

.sp-audio{ border:0; background: rgba(255,255,255,0.10); color:#fff; border-radius:10px; width:40px; height:40px; cursor:pointer; font-size:18px; line-height:40px; display:inline-flex; align-items:center; justify-content:center; }

.sp-play{ border:0; background: rgba(255,255,255,0.10); color:#fff; border-radius:10px; width:40px; height:40px; cursor:pointer; font-size:18px; line-height:40px; display:inline-flex; align-items:center; justify-content:center; }


@media (max-width: 820px){
  /* iOS/Safari sometimes overlays big native controls even when controls=false */
  .sp-media video::-webkit-media-controls,
  .sp-media video::-webkit-media-controls-panel,
  .sp-media video::-webkit-media-controls-enclosure,
  .sp-media video::-webkit-media-controls-overlay-enclosure,
  .sp-media video::-webkit-media-controls-play-button,
  .sp-media video::-webkit-media-controls-start-playback-button,
  .sp-media video::-webkit-media-controls-timeline,
  .sp-media video::-webkit-media-controls-current-time-display,
  .sp-media video::-webkit-media-controls-time-remaining-display,
  .sp-media video::-webkit-media-controls-mute-button,
  .sp-media video::-webkit-media-controls-fullscreen-button,
  .sp-media video::-webkit-media-controls-volume-slider{
    display:none !important;
    -webkit-appearance:none !important;
  }
}

@media (max-width: 820px){ .sp-media video{ pointer-events:none !important; } }

/* v0.1.20 - suppress video controls */
.sp-viewer video{ pointer-events:none; }
.sp-viewer video::-webkit-media-controls{ display:none !important; }
.sp-viewer video::-webkit-media-controls-enclosure{ display:none !important; }
.sp-viewer video::-webkit-media-controls-panel{ display:none !important; }
.sp-viewer video::-webkit-media-controls-play-button{ display:none !important; }
.sp-viewer video::-webkit-media-controls-start-playback-button{ display:none !important; }
.sp-audio,.sp-play{ display:none !important; }

/* v0.1.21 - avatar thumbnails */
.sp-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}


/* Social (likes/comments) */
.sp-social-row{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:6px;
}
.sp-like-btn,
.sp-comment-btn{
  appearance:none;
  background:rgba(0,0,0,.35);
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  padding:6px 10px;
  font-size:14px;
  line-height:1;
  cursor:pointer;
  border-radius:0;
}
.sp-like-btn.is-liked{
  border-color: rgba(255,255,255,.5);
}
.sp-like-count,
.sp-comment-count{
  font-weight:600;
}

.sp-comments{
  margin-top:8px;
  max-height:160px;
  overflow:auto;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.15);
  padding:8px;
  border-radius:0;
}
.sp-comment-item{
  display:flex;
  gap:6px;
  align-items:flex-start;
  margin:0 0 6px 0;
  font-size:13px;
}
.sp-comment-author{
  font-weight:700;
}
.sp-comment-empty{
  font-size:13px;
  opacity:.85;
}
.sp-comment-form{
  display:flex;
  gap:8px;
  align-items:flex-end;
  margin-top:8px;
}
.sp-comment-input{
  flex:1;
  width:100%;
  min-height:44px;
  resize:vertical;
  border-radius:0;
}
.sp-comment-send{
  appearance:none;
  background:rgba(0,0,0,.35);
  color:#fff;
  border:1px solid rgba(255,255,255,.25);
  padding:6px 10px;
  cursor:pointer;
  border-radius:0;
}
.sp-comment-login{
  font-size:13px;
  opacity:.9;
}
