/* Snak Fase 2 — dashboard, chat, emoji. Bygger oven på theme.css (insekthaver). */

#status.ok { color: var(--accent); }
#status { color: var(--muted); }
header .ghost { margin-top: 0; padding: 7px 12px; }

.centerbox { max-width: 420px; margin: 8vh auto; }

/* Gridstack-temasætning til mørk palette */
.grid-stack { max-width: 1280px; margin: 14px auto; padding: 0 10px; }
.grid-stack-item-content {
  inset: 0;
  background: linear-gradient(180deg, var(--panel), var(--panel2)) !important;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.widget { height: 100%; }
.wtitle {
  padding: 10px 14px;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: .5px;
  color: var(--accent);
  border-bottom: 1px solid var(--border);
  cursor: move;
  user-select: none;
  background: #07120a;
}
.placeholder { padding: 16px; }
.placeholder .muted { margin: 6px 0; }

/* Chat-layout */
.chat { flex: 1; display: flex; min-height: 0; }
.rooms {
  width: 38%;
  max-width: 230px;
  border-right: 1px solid var(--border);
  overflow-y: auto;
}
.rooms .pad { padding: 14px; }
.room {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.room:hover { background: #07140b; }
.room.active { background: #0b1f10; border-left: 3px solid var(--accent); }
.room .rname { font-size: 14px; color: var(--text); font-weight: 600; }
.room .rlast { font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }

.thread { flex: 1; display: flex; flex-direction: column; min-width: 0; }
.thread-head {
  padding: 9px 14px;
  font-size: 13px;
  color: var(--muted);
  border-bottom: 1px solid var(--border);
}
.msgs { flex: 1; overflow-y: auto; padding: 12px; display: flex; flex-direction: column; gap: 6px; }
.msg { display: flex; }
.msg.mine { justify-content: flex-end; }
.bubble {
  max-width: 78%;
  background: #07140b;
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 7px 11px;
  font-size: 14px;
  line-height: 1.35;
  word-wrap: break-word;
}
.msg.mine .bubble { background: #0b3; color: #04140a; border-color: transparent; }
.bubble .who { display: block; font-size: 11px; color: var(--accent); margin-bottom: 2px; }
.bubble .body { white-space: pre-wrap; }

/* Composer (delt værktøj — Messenger-stil) */
.composer { display: flex; gap: 8px; padding: 10px; border-top: 1px solid var(--border); position: relative; }
.composer input { margin: 0; flex: 1; }
.composer button { margin: 0; padding: 10px 13px; }
#emojiBtn { background: transparent; color: var(--accent); border: 1px solid var(--border); font-size: 16px; }

.emoji-pop { position: absolute; bottom: 56px; left: 10px; z-index: 50; box-shadow: 0 8px 30px rgba(0,0,0,.6); border-radius: 12px; overflow: hidden; }
emoji-picker {
  --background: #0a130a;
  --border-color: var(--border);
  --input-border-color: var(--border);
  --input-font-color: var(--text);
  --category-font-color: var(--accent);
  width: 320px;
  height: 320px;
}

.newchat { display: flex; gap: 8px; padding: 10px; border-top: 1px solid var(--border); }
.newchat input { margin: 0; flex: 1; }
.newchat button { margin: 0; }

/* Kald-widget */
.callbar { display: flex; gap: 8px; padding: 10px; border-bottom: 1px solid var(--border); }
.callbar button { margin: 0; }
.callbox { flex: 1; min-height: 0; position: relative; background: #04140a; }
.callhint { padding: 16px; }
.callframe { width: 100%; height: 100%; border: 0; display: block; }

@media (max-width: 720px) {
  .rooms { width: 42%; }
  .grid-stack { padding: 0 4px; }
}
