/* Approval cards and chat source attribution. */

.chat-approvals{
  display:none;
  flex-direction:column;
  gap:10px;
  max-width:820px;
  margin:0 auto 12px;
}
.chat-approvals.on{display:flex}
.chat-approval-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.chat-approval-list{
  display:flex;
  flex-direction:column;
  gap:10px;
}
.chat-approval-card{
  border:1px solid rgba(169,113,52,.16);
  border-radius:20px;
  background:linear-gradient(135deg,rgba(255,248,239,.92),rgba(247,236,221,.82));
  padding:14px;
  box-shadow:var(--shadow-soft);
}
.chat-approval-copy{
  margin-top:8px;
  font-size:13px;
  color:var(--ink-soft);
  line-height:1.7;
}
.approval-email-preview{
  margin-top:10px;
  border:1px solid rgba(169,113,52,.14);
  border-radius:16px;
  background:rgba(255,255,255,.58);
  padding:12px;
}
.approval-email-row{
  display:grid;
  grid-template-columns:58px 1fr;
  gap:10px;
  align-items:center;
  margin-bottom:6px;
}
.approval-email-label{
  font-size:11px;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:var(--muted);
  line-height:1.5;
}
.approval-email-value{
  font-size:13px;
  color:var(--ink);
  line-height:1.5;
  word-break:break-word;
}
.approval-email-body{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(169,113,52,.12);
  font-size:13px;
  color:var(--ink-soft);
  line-height:1.7;
  word-break:break-word;
}
.approval-email-input,
.approval-email-textarea{
  width:100%;
  border:1px solid rgba(169,113,52,.16);
  border-radius:10px;
  background:rgba(255,255,255,.9);
  color:var(--ink);
  font:inherit;
  line-height:1.5;
  padding:8px 10px;
}
.approval-email-subject-wrap{
  display:flex;
  align-items:center;
  gap:8px;
}
.approval-email-subject-wrap .approval-email-input{
  flex:1;
}
.approval-calendar-grid{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
}
.approval-calendar-cell{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.approval-email-error{
  margin-top:8px;
  font-size:12px;
  color:#8a4f3a;
}
.approval-slack-suggest{
  display:none;
  flex-direction:column;
  gap:0;
  margin:6px 0 6px;
  border:1px solid rgba(169,113,52,.2);
  border-radius:12px;
  background:rgba(255,255,255,.95);
  max-height:180px;
  overflow:auto;
}
.approval-slack-suggest.on{display:flex}
.approval-slack-suggest-row{
  width:100%;
  border:0;
  background:transparent;
  color:var(--ink);
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:8px 12px;
  font-size:12px;
  line-height:1.4;
  cursor:pointer;
  text-align:left;
}
.approval-slack-suggest-row + .approval-slack-suggest-row{
  border-top:1px solid rgba(169,113,52,.1);
}
.approval-slack-suggest-row:hover{
  background:rgba(169,113,52,.08);
}
.approval-slack-suggest-name{
  font-weight:600;
}
.approval-slack-suggest-meta{
  color:rgba(60,43,26,.65);
  margin-left:8px;
  white-space:nowrap;
}
.approval-email-input:focus,
.approval-email-textarea:focus{
  outline:none;
  border-color:rgba(169,113,52,.4);
  box-shadow:0 0 0 2px rgba(169,113,52,.12);
}
.approval-email-body-wrap{
  margin-top:10px;
  padding-top:10px;
  border-top:1px solid rgba(169,113,52,.12);
  display:flex;
  flex-direction:column;
  gap:6px;
}
.approval-edit-actions{
  margin-top:10px;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
}
@media (max-width:760px){
  .approval-calendar-grid{grid-template-columns:1fr}
}
.chat-approval-actions{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top:12px;
}
.pill.attn{
  background:rgba(255,244,230,.9);
  border-color:rgba(169,113,52,.2);
  color:var(--warn);
}
.pill.attn .dot{
  background:var(--warn);
}
.msg-meta{
  display:flex;
  flex-wrap:wrap;
  gap:6px;
  margin-top:10px;
}
.msg-source-chip{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 9px;
  border-radius:999px;
  border:1px solid rgba(140,102,64,.14);
  background:rgba(140,102,64,.06);
  color:var(--accent);
  font-family:'IBM Plex Mono',monospace;
  font-size:10px;
  line-height:1;
}
.msg-source-chip.live{
  background:rgba(63,123,90,.1);
  color:var(--success);
  border-color:rgba(63,123,90,.18);
}
.msg-source-chip.read{
  background:rgba(104,123,153,.08);
  color:#516173;
  border-color:rgba(104,123,153,.16);
}
