:root{
  --jg:#39ff14; --bg:#0a0a0a; --card:#101010; --fg:#f2f2f2; --muted:#bdbdbd; --soft:#B7FF9E;
}
*{box-sizing:border-box} html,body{margin:0;background:var(--bg);color:var(--fg);font:16px/1.5 system-ui,Segoe UI,Inter,Arial}
a{color:var(--jg);text-decoration:none}
.btn{background:var(--jg);color:#000;border:none;border-radius:14px;padding:.55rem .9rem;font-weight:800}
.btn.ghost{background:transparent;color:var(--jg);border:1px solid var(--jg)}
.topbar{position:sticky;top:0;z-index:10;display:flex;justify-content:space-between;align-items:center;padding:.7rem 1rem;background:rgba(0,0,0,.5);backdrop-filter:blur(8px);border-bottom:1px solid rgba(57,255,20,.2)}
.brand{font-weight:900;letter-spacing:.5px}
.topnav{display:flex;gap:.5rem;align-items:center}
.avatar img,.ava{width:36px;height:36px;border-radius:999px;border:1px solid rgba(57,255,20,.3)}
.feed{max-width:980px;margin:16px auto;padding:0 12px;display:grid;gap:14px}
.card{background:var(--card);border:1px solid rgba(57,255,20,.18);border-radius:20px;overflow:hidden;box-shadow:0 8px 30px rgba(0,0,0,.25)}
.card-head{display:flex;gap:.6rem;align-items:center;padding:.7rem .8rem}
.card-head .ava{width:42px;height:42px;border-radius:999px}
.user .handle{font-weight:700;color:#fff}
.user .meta{font-size:.86rem;color:var(--muted)}
.media img,.media video{display:block;width:100%;height:auto;aspect-ratio:auto;border-top:1px solid rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.04)}
.actions{display:flex;gap:8px;padding:.6rem .8rem}
.like{background:#1a1a1a;color:#fff;border:1px solid rgba(255,255,255,.08);padding:.4rem .7rem;border-radius:999px;cursor:pointer}
.like.active{background:var(--jg);color:#000}
.cmt{background:#1a1a1a;color:#fff;border:1px solid rgba(255,255,255,.08);padding:.4rem .7rem;border-radius:999px;cursor:pointer}
.counts,.cap{padding:0 .9rem .6rem}
.comment-form{display:flex;gap:.5rem;padding:.5rem .8rem;border-top:1px solid rgba(255,255,255,.06)}
.comment-form input{flex:1;border-radius:12px;border:1px solid #2a2a2a;background:#0f0f0f;color:#eaeaea;padding:.55rem .7rem}
.comment-form button{border-radius:12px;border:1px solid var(--jg);background:transparent;color:var(--jg);padding:.55rem .8rem}
.empty{padding:1rem;border:1px dashed rgba(57,255,20,.35);border-radius:14px;background:#0e0e0e;margin:1rem}
.bnav{position:sticky;bottom:0;display:flex;justify-content:space-around;align-items:center;padding:.4rem;background:rgba(0,0,0,.6);backdrop-filter:blur(8px);border-top:1px solid rgba(57,255,20,.2)}
.fab{background:var(--jg);color:#000;width:44px;height:44px;border-radius:999px;text-align:center;line-height:44px;font-weight:900}
.page .uploadbox,.auth .authbox{max-width:560px;margin:40px auto;background:var(--card);border:1px solid rgba(57,255,20,.18);border-radius:20px;padding:16px}
label{display:block;margin:.55rem 0 .2rem}
input,textarea,select{width:100%;padding:.65rem .7rem;border-radius:12px;border:1px solid #2a2a2a;background:#0f0f0f;color:#eaeaea}
.ok{background:#152e17;border:1px solid #1db954;color:#b7ffce;padding:.6rem;border-radius:12px;margin:.5rem 0}
.err{background:#2e1515;border:1px solid #ff4d4d;color:#ffd6d6;padding:.6rem;border-radius:12px;margin:.5rem 0}
.profile{max-width:980px;margin:16px auto;padding:0 12px;display:flex;gap:16px;align-items:center}
.avatar-lg{width:96px;height:96px;border-radius:999px;border:2px solid rgba(57,255,20,.35)}
.profile .handle{font-weight:700;color:#bdbdbd;margin-left:.5rem}
.grid{max-width:980px;margin:12px auto;padding:0 12px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}
.grid-item img,.grid-item video{width:100%;height:100%;object-fit:cover;border-radius:12px;border:1px solid rgba(255,255,255,.06)}
.profile-ava{display:inline-block;width:120px;height:120px;border-radius:999px;padding:4px;background:#111}
.profile-ava img{width:100%;height:100%;border-radius:999px;display:block;object-fit:cover}
.profile-ava.has-story{background:conic-gradient(#39ff14, #39ff14 40%, transparent 60%)}
.profile-ava.has-story img{border:3px solid #000}

.post-card{position:relative}
.post-thumb{width:100%;display:block;border-radius:12px}
.post-menu-btn{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.5);border:none;color:#fff;font-size:20px;padding:4px 8px;border-radius:8px;cursor:pointer}
.post-menu{display:none;position:absolute;top:36px;right:6px;background:#111;padding:10px;border-radius:12px;box-shadow:0 0 15px rgba(0,0,0,.4);z-index:50}
.post-menu a,.post-menu button{display:block;width:100%;background:none;border:none;color:#fff;text-align:left;font-size:14px;padding:6px 0}
.post-menu button.danger{color:#ff4d4d}
/* Bottom-Bar über Content, aber unter Menüs */
.bnav{ z-index:60; height:56px; }

/* Genug Platz unterhalb, wenn Bottom-Bar da ist */
body.has-bnav .feed,
body.has-bnav .grid,
body.has-bnav .page { 
  padding-bottom: calc(72px + env(safe-area-inset-bottom, 0px));
}

/* Menü nicht abgeschnitten + über der Bottom-Bar */
.post-card{ overflow: visible; }
.post-menu{ z-index:100; }       /* über .bnav (60) */
.post-menu-btn{ z-index:110; }   /* über .post-menu */

/* Optional: bei sehr kleinen Screens zusätzlich etwas Abstand nach unten */
@media (max-width: 480px){
  body.has-bnav .grid,
  body.has-bnav .feed { padding-bottom: calc(84px + env(safe-area-inset-bottom, 0px)); }
}
.emoji-btn {
  background: none;
  border: none;
  color: var(--jg);
  font-size: 22px;
  padding: 0 4px;
  cursor: pointer;
}

.emoji-box {
  position: absolute;
  background: #111;
  padding: 12px;
  border-radius: 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  width: 240px;
  height: 160px;
  overflow-y: auto;
  border: 1px solid rgba(57,255,20,.3);
  z-index: 999999;
}

.emoji-box span {
  cursor: pointer;
  font-size: 22px;
}
/* Bubble Layout */
.msg{
  max-width:75%;
  padding:6px;
  border-radius:14px;
  display:flex;
  flex-direction:column;
  gap:6px;
}

.msg.me{
  align-self:flex-end;
  background:var(--jg);
  color:#000;
}

.msg.them{
  align-self:flex-start;
  background:#1c1c1c;
  border:1px solid rgba(255,255,255,.08);
}

/* Media inside bubbles */
.bubble-media{
  max-width:260px;
  max-height:320px;
  border-radius:12px;
  object-fit:cover;
  cursor:pointer;
}

/* Make video interactive */
.bubble-media video{
  pointer-events:auto;
}

/* Text inside bubble */
.bubble-text{
  line-height:1.35;
  font-size:15px;
}
/* Quoted reply bubble */
.reply-bubble{
  padding:4px 6px;
  background:#000;
  border-left:3px solid var(--jg);
  opacity:.75;
  font-size:.8rem;
  border-radius:6px;
  margin-bottom:4px;
}

/* Reaction under bubble */
.reaction{
  font-size:18px;
  margin-top:2px;
  align-self:flex-end;
  opacity:.9;
}

/* Swipe reply gesture hint on hover */
.msg.them:hover, .msg.me:hover{
  cursor:pointer;
}
/* ❤️ Reaction pop animation */
@keyframes heart-pop {
  0% { transform:scale(0); opacity:0; }
  40% { transform:scale(1.4); opacity:1; }
  100% { transform:scale(1); opacity:0; }
}
.heart-pop {
  position:absolute;
  font-size:28px;
  color:#ff4d4d;
  top:50%; left:50%;
  transform:translate(-50%,-50%);
  animation:heart-pop 0.6s ease-out;
  pointer-events:none;
}

/* Swipe-to-reply */
.msg {
  position:relative;
  transition:transform .2s ease;
}
.msg.swiping {
  transform:translateX(60px);
  background:linear-gradient(90deg,var(--soft) 0%,transparent 80%);
}
.reply-preview {
  border-left:3px solid var(--jg);
  padding-left:6px;
  color:var(--muted);
  font-size:.85rem;
  margin-bottom:4px;
}
.notif-link {
  position:relative;
}

.notif-badge {
  position:absolute;
  top:2px;
  right:6px;
  width:10px;
  height:10px;
  background:#ff3333;
  border-radius:999px;
  border:2px solid rgba(0,0,0,.6);
}
/* Reactions */
.rxbar{display:flex;gap:8px;align-items:center;padding:.5rem .8rem}
.rx{background:#1a1a1a;border:1px solid rgba(255,255,255,.08);border-radius:999px;padding:.35rem .6rem;cursor:pointer}
.rx-view{background:transparent;border:1px dashed rgba(255,255,255,.2);border-radius:999px;padding:.3rem .6rem;color:#bdbdbd}

/* Carousel */
.carousel{position:relative}
.carousel img,.carousel video{display:block;width:100%}
.carousel .dots{position:absolute;bottom:8px;left:50%;transform:translateX(-50%);display:flex;gap:6px}
.carousel .dot{width:8px;height:8px;border-radius:999px;background:rgba(255,255,255,.35)}
.carousel .dot.on{background:#fff}

/* Pinned badge */
.pin-badge{position:absolute;top:6px;left:6px;background:rgba(0,0,0,.55);padding:4px 6px;border-radius:8px;font-size:14px}

/* Verified */
.badge-verified{display:inline-block;margin-left:6px;padding:0 6px;border-radius:8px;background:var(--jg);color:#000;font-size:.8rem;font-weight:900}

/* Bottom sheet (reactions list) */
.sheet{position:fixed;left:0;right:0;bottom:0;background:#0f0f0f;border-top:1px solid rgba(255,255,255,.08);max-height:70vh;overflow:auto;padding:12px;z-index:999}
.sheet .item{display:flex;gap:10px;align-items:center;padding:8px 0;border-bottom:1px solid rgba(255,255,255,.06)}

/* Avoid overlap with bottom nav */
.feed,.grid,.page{padding-bottom:72px}
