:root {
  --bg:#07070b;
  --card:#0f1016;
  --accent:#ff7a18;
}

*{box-sizing:border-box;margin:0;padding:0}
body{
  background:radial-gradient(circle at top,#1a1b22,#050508);
  color:#fff;
  font-family:system-ui,sans-serif;
  overflow:hidden;
}

.reels{
  height:100vh;
  overflow-y:auto;
  scroll-snap-type:y mandatory;
  scroll-behavior:smooth;
}

.reel{
  position:relative;
  height:100vh;
  scroll-snap-align:start;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:.3s ease;
  will-change:transform,opacity;
}

.reel.active{
  transform:scale(1);
  opacity:1;
}

.reel.inactive{
  transform:scale(.96);
  opacity:.6;
}

.media{width:100%;height:100%}
.media video,.media img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(0,0,0,.6),transparent 40%);
  pointer-events:none;
}

.info{
  position:absolute;
  bottom:90px;
  left:20px;
  font-size:14px;
}

.actions{
  position:absolute;
  right:15px;
  bottom:110px;
  display:flex;
  flex-direction:column;
  gap:16px;
}

.actions button{
  width:48px;height:48px;border-radius:50%;
  border:none;background:rgba(0,0,0,.55);
  backdrop-filter:blur(8px);
  color:var(--accent);font-size:20px;
  cursor:pointer;transition:.25s;
}

.topbar{
  position:fixed;
  top:12px;left:50%;
  transform:translateX(-50%);
  display:flex;gap:8px;z-index:10;
}

.topbar button{
  padding:8px 16px;border-radius:20px;
  border:none;background:rgba(0, 0, 0, 0);
  color:#fff;cursor:pointer;
  backdrop-filter:blur(5px);
  transition:.25s;
  font-size: 10px;
}

.topbar button.active{
  background:linear-gradient(135deg,#ff7a1896,#ff8e25bf);
  color:#000;font-weight:600;
}

.reels::-webkit-scrollbar{display:none}

.filter-dropdown{position:relative}

.filter-btn{
  padding:8px 18px;
  border-radius:20px;
  border:none;
  background:rgba(0, 0, 0, 0);
  color:#fff;
  cursor:pointer;
  backdrop-filter:blur(6px);
}

.filter-btn .arrow{margin-left:6px;transition:.3s}
.filter-btn.open .arrow{transform:rotate(180deg)}

.filter-panel{
  position:absolute;
  top:110%;
  left:50%;
  transform:translateX(-50%);
  background:rgba(15, 16, 22, 0);
  backdrop-filter:blur(10px);
  border-radius:16px;
  padding:14px;
  width:220px;
  box-shadow:0 0 20px rgba(0,0,0,.6);
  display:none;
}

.filter-panel.show{display:block}

.filter-group{margin-bottom:10px}
.filter-group strong{
  font-size:12px;
  opacity:.7;
}

.filter-group button{
  margin-top:6px;
  padding:6px 10px;
  border:none;
  border-radius:12px;
  background:#22222273;
  color:#fff;
  cursor:pointer;
  margin-right:6px;
}

.filter-group input{
  width:100%;
  margin-top:6px;
  padding:6px 8px;
  border-radius:8px;
  border:none;
  background:#222;
  color:#fff;
}
.thumb{
  position:absolute;
  inset:0;
  background:#000;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}

/* .thumb.hidden{
  opacity:0;
  pointer-events:none;
} */

.thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  filter:brightness(.9);
}

.thumb::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.08) 50%,transparent 70%);
  animation:shimmer 1.2s infinite;
}

@keyframes shimmer{
  from{transform:translateX(-100%)}
  to{transform:translateX(100%)}
}

.loading{
  position:fixed;
  inset:0;
  background:radial-gradient(circle at top,#1a1b22,#050508);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  z-index:999;
  transition:.4s;
}

.loading.hidden{
  opacity:0;
  pointer-events:none;
}

.spinner{
  width:54px;
  height:54px;
  border:4px solid rgba(255,255,255,.15);
  border-top-color:#ff7a18;
  border-radius:50%;
  animation:spin 1s linear infinite;
  margin-bottom:16px;
}

@keyframes spin{
  to{transform:rotate(360deg)}
}