/* ═══════════════════════════════════════════
   III. MESSAGE FRAGMENTS
═══════════════════════════════════════════ */
.fragments { display: flex; flex-direction: column; gap: 40px; }

.fragment-card {
  background: var(--cream); border: 1px solid var(--paper-aged);
  position: relative; box-shadow: 2px 4px 16px rgba(44,36,22,0.08);
}
.fragment-time-bar {
  background: var(--paper-dark); padding: 10px 20px;
  border-bottom: 1px solid var(--paper-aged);
  display: flex; justify-content: space-between; align-items: center;
}
.fragment-time { font-family: 'Special Elite', monospace; font-size: 11px; letter-spacing: 1px; color: var(--ink-mid); }
.fragment-meta { font-family: 'Caveat', cursive; font-size: 14px; color: var(--ink-faded); }

.fragment-body { padding: 24px 20px; display: flex; flex-direction: column; gap: 10px; }

.msg-line { display: flex; flex-direction: column; gap: 3px; max-width: 78%; }
.msg-line.right { align-self: flex-end; align-items: flex-end; }

.msg-who { font-family: 'Special Elite', monospace; font-size: 8px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ink-muted); }

.msg-bubble {
  font-family: 'Caveat', cursive; font-size: 17px; color: var(--ink);
  background: rgba(255,255,255,0.6); border: 0.5px solid var(--paper-aged);
  padding: 10px 16px; border-radius: 16px 16px 16px 3px; line-height: 1.5;
}
.msg-line.right .msg-bubble { background: rgba(139,58,30,0.07); border-radius: 16px 16px 3px 16px; }

.msg-redacted {
  font-family: 'Special Elite', monospace; font-size: 14px;
  color: var(--paper); background: var(--ink);
  padding: 8px 16px; border-radius: 4px; letter-spacing: 2px;
  user-select: none; cursor: help; position: relative;
}
.msg-redacted::after {
  content: attr(data-secret); position: absolute; top: 0; left: 0; right: 0; bottom: 0;
  color: transparent; background: var(--ink); padding: 8px 16px; border-radius: 4px; transition: color 0.3s;
}
.msg-redacted:hover::after { color: var(--paper); background: var(--ink-mid); }

.fragment-dur { text-align: center; margin: 8px 0; font-family: 'Special Elite', monospace; font-size: 9px; letter-spacing: 2px; color: var(--ink-muted); text-transform: uppercase; border-top: 1px dashed var(--paper-aged); border-bottom: 1px dashed var(--paper-aged); padding: 8px; }
.ellipsis-line { text-align: center; font-family: 'Caveat', cursive; font-size: 22px; color: var(--ink-muted); opacity: 0.5; letter-spacing: 6px; margin: 4px 0; }
