/* narma-splash: comments overlay. Self-contained. Hidden on mobile. */

:root {
  --c-comment-primary: #1F6FEB;
  --c-comment-text: #111111;
  --c-comment-muted: #6E6E6E;
}

/* Floating button bottom-right; hidden by default until JS finds host elements */
#commentsBtn {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 30;
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: none;
  background: var(--c-comment-text);
  color: #fff;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 6px 18px rgba(0,0,0,0.25);
  transition: background 0.15s, transform 0.15s;
}
#commentsBtn:hover { transform: translateY(-1px); }
#commentsBtn.active { background: var(--c-comment-primary); }
#commentsBtn svg { width: 22px; height: 22px; }

/* Hover preview while in comments mode — outline around the focused block */
body.comments-on [data-comment-target] {
  outline: 1px dashed transparent;
  outline-offset: 4px;
  transition: outline-color 0.12s;
}
body.comments-on [data-comment-target].comment-target-hover {
  outline-color: var(--c-comment-primary);
}
/* While dragging a pin: make the drop-target outline thicker + tinted so it
   reads even without the cursor on the element. */
body.dragging-pin [data-comment-target].comment-target-hover {
  outline: 2px solid var(--c-comment-primary);
  outline-offset: 4px;
  background-color: rgba(31,111,235,0.06);
}

/* Reposition tool (Shift+drag) — element travels with cursor, others dim. */
body.reposition-active [data-comment-target] {
  cursor: grabbing !important;
}
body.reposition-active .comment-target-moving {
  outline: 2px dashed var(--c-comment-primary);
  outline-offset: 4px;
  box-shadow: 0 8px 24px rgba(31,111,235,0.25);
  z-index: 20;
  position: relative;
}
body.comments-on::before {
  content: "C — режим комментариев · S — список · Shift+drag — двигать элемент";
  position: fixed;
  bottom: 14px; left: 14px;
  z-index: 30;
  padding: 6px 12px;
  font: 500 11px/1 'TT Interphases Pro', sans-serif;
  letter-spacing: 0.02em;
  background: rgba(17,17,17,0.85);
  color: #fff;
  border-radius: 999px;
  pointer-events: none;
}
@media (max-width: 900px) {
  body.comments-on::before { display: none; }
}

/* Pin: teardrop, anchored at the spot via translate(-50%, -100%) */
.comment-pin {
  position: absolute;
  width: 24px; height: 24px;
  border-radius: 50% 50% 50% 0;
  transform: translate(-50%, -100%) rotate(-45deg);
  background: var(--c-comment-primary);
  color: #fff;
  border: none;
  cursor: pointer;
  padding: 0;
  box-shadow: 0 4px 12px rgba(31,58,110,0.35);
  display: none;
  z-index: 11;
  font: 700 12px/24px 'TT Interphases Pro', sans-serif;
  text-align: center;
}
.comment-pin > span { display: block; transform: rotate(45deg); }
.comment-pin.resolved { background: var(--c-comment-muted); opacity: 0.75; }
body.comments-on .comment-pin { display: block; cursor: grab; }
body.comments-on .comment-pin:active { cursor: grabbing; }
body.comments-on [data-comment-target] { cursor: crosshair; }

/* Lift the pin to fixed coords while being dragged */
.comment-pin.dragging {
  position: fixed !important;
  z-index: 33;
  transform: translate(-50%, -100%) rotate(-45deg) scale(1.08);
  box-shadow: 0 8px 20px rgba(31,58,110,0.45);
  cursor: grabbing;
  transition: transform 0.08s;
}

/* Popover */
.comment-popover {
  position: fixed; z-index: 32;
  width: 280px;
  background: #fff;
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,0.2);
  padding: 14px;
  font: 400 13px/1.5 'TT Interphases Pro', sans-serif;
  color: var(--c-comment-text);
}
.comment-popover .meta {
  font: 500 10px/1 'TT Interphases Pro', sans-serif;
  color: var(--c-comment-muted);
  letter-spacing: 0.06em;
  text-transform: uppercase;
  margin-bottom: 8px;
  display: flex;
  justify-content: space-between;
  gap: 8px;
}
.comment-popover .meta .author { color: var(--c-comment-text); }
.comment-popover .tag {
  display: inline-block;
  margin: 0 0 8px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(31,111,235,0.10);
  color: var(--c-comment-primary);
  font: 500 10px/1.4 'TT Interphases Pro', sans-serif;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.comments-sidebar .item .tag {
  font: 500 9px/1 'TT Interphases Pro', sans-serif;
  color: var(--c-comment-primary);
  letter-spacing: 0.05em;
  text-transform: uppercase;
  margin: 0 0 4px;
}
.comment-popover textarea {
  width: 100%; min-height: 72px; resize: vertical;
  border: 1px solid #E0E3EA; border-radius: 6px; padding: 8px 10px;
  font: 400 13px/1.4 'TT Interphases Pro', sans-serif;
  color: var(--c-comment-text); outline: none;
}
.comment-popover textarea:focus { border-color: var(--c-comment-primary); }
.comment-popover .text-display { white-space: pre-wrap; word-wrap: break-word; }
.comment-popover .actions {
  display: flex; gap: 6px; justify-content: flex-end; margin-top: 10px;
}
.comment-popover .actions .spacer { flex: 1; }
.comment-popover button {
  height: 30px; padding: 0 12px; border-radius: 6px; cursor: pointer;
  font: 500 11px/1 'TT Interphases Pro', sans-serif;
  letter-spacing: 0.04em; text-transform: uppercase;
  border: 1px solid transparent; background: transparent; color: var(--c-comment-text);
}
.comment-popover button.primary { background: var(--c-comment-primary); color: #fff; }
.comment-popover button.primary:hover { background: var(--c-comment-text); }
.comment-popover button.secondary { border-color: #E0E3EA; }
.comment-popover button.secondary:hover { background: #F4F5F8; }
.comment-popover button.danger { color: #B83232; }
.comment-popover button.danger:hover { background: #FCEEEE; }

/* Sidebar */
.comments-sidebar {
  position: fixed; top: 24px; right: 24px;
  width: 280px; max-height: 70vh; overflow-y: auto;
  background: rgba(255,255,255,0.97);
  border-radius: 12px;
  box-shadow: 0 10px 28px rgba(0,0,0,0.12);
  padding: 14px;
  z-index: 14;
  display: none;
  font: 400 12px/1.4 'TT Interphases Pro', sans-serif;
  color: var(--c-comment-text);
}
body.comments-on .comments-sidebar { display: block; }
body.comments-on.comments-sidebar-collapsed .comments-sidebar { display: none; }

.comments-sidebar .sidebar-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
  margin-bottom: 8px;
}
.comments-sidebar .sidebar-close {
  background: transparent; border: none; cursor: pointer;
  width: 24px; height: 24px; border-radius: 6px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--c-comment-muted);
  font: 500 14px/1 'TT Interphases Pro', sans-serif;
}
.comments-sidebar .sidebar-close:hover {
  background: #F4F5F8; color: var(--c-comment-text);
}

.comments-sidebar h4 {
  margin: 0;
  font: 500 11px/1 'TT Interphases Pro', sans-serif;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--c-comment-muted);
}

/* Re-open capsule when sidebar is collapsed */
.sidebar-reopen {
  position: fixed; top: 24px; right: 24px;
  z-index: 14;
  display: none;
  align-items: center; gap: 8px;
  padding: 8px 14px;
  border-radius: 999px;
  background: var(--c-comment-text); color: #fff;
  border: none; cursor: pointer;
  font: 500 12px/1 'TT Interphases Pro', sans-serif;
  letter-spacing: 0.02em;
  box-shadow: 0 6px 18px rgba(0,0,0,0.20);
}
.sidebar-reopen svg { width: 16px; height: 16px; }
.sidebar-reopen:hover { background: var(--c-comment-primary); }
body.comments-on.comments-sidebar-collapsed .sidebar-reopen { display: inline-flex; }
.comments-sidebar .empty { color: var(--c-comment-muted); font-style: italic; padding: 12px 0; text-align: center; }
.comments-sidebar .item {
  border-top: 1px solid #ECEEF2;
  padding: 9px 0;
  cursor: pointer;
}
.comments-sidebar .item:first-of-type { border-top: 0; }
.comments-sidebar .item .meta {
  font: 500 10px/1 'TT Interphases Pro', sans-serif;
  color: var(--c-comment-muted);
  letter-spacing: 0.05em; text-transform: uppercase;
  margin-bottom: 4px;
  display: flex; justify-content: space-between; gap: 8px;
}
.comments-sidebar .item .meta .ix { color: var(--c-comment-primary); }
.comments-sidebar .item .meta .status.resolved { color: #5A8552; }
.comments-sidebar .item .text {
  color: var(--c-comment-text);
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.comments-sidebar .item.resolved .text {
  text-decoration: line-through;
  color: var(--c-comment-muted);
}

/* Mobile: skip the feature altogether — pins/popovers don't fit on tiny screens */
@media (max-width: 900px) {
  .comments-sidebar,
  .comment-popover,
  #commentsBtn,
  .sidebar-reopen { display: none !important; }
}
