/* messages.css — visual redesign of "Сообщения" tab. Logic untouched. */

/* === Контейнер вкладки === */
#messages.page {
  --m-bg: #f4f6fa;
  --m-card: #ffffff;
  --m-border: #e3e7ee;
  --m-shadow: 0 1px 3px rgba(16,24,40,.04), 0 4px 12px rgba(16,24,40,.04);
  --m-text: #1f2937;
  --m-muted: #6b7280;
  --m-accent: #1976d2;
  --m-accent-soft: #e8f1fb;
  --m-success: #16a34a;
  --m-warning: #d97706;
  --m-danger: #dc2626;
  --m-bubble-in: #ffffff;
  --m-bubble-out: #dcf3ff;
  --m-bubble-system: #fff7e6;

  background: var(--m-bg);
  border-radius: 14px;
  padding: 18px;
}

/* Заголовок и навигация по дате */
#messages .page-header {
  background: var(--m-card);
  border: 1px solid var(--m-border);
  border-radius: 12px;
  padding: 14px 18px;
  margin-bottom: 14px;
  box-shadow: var(--m-shadow);
}
#messages .page-header h2 {
  margin: 0;
  font-size: 20px;
  font-weight: 600;
  color: var(--m-text);
  letter-spacing: -.2px;
}
#messages .messages-date-nav { gap: 8px !important; }
#messages .messages-date-nav .btn {
  border-radius: 8px;
  border: 1px solid var(--m-border);
  background: #fff;
  padding: 6px 12px;
  transition: all .15s;
}
#messages .messages-date-nav .btn:hover { background: var(--m-accent-soft); border-color: var(--m-accent); }
#messages .messages-date-nav .btn-primary { background: var(--m-accent); color: #fff; border-color: var(--m-accent); }
#messages .messages-date-nav input[type=date] {
  border-radius: 8px;
  border: 1px solid var(--m-border);
  padding: 7px 10px;
  font-size: 13px;
}
#messages #messagesCount { color: var(--m-muted); font-size: 13px; font-weight: 500; }

/* === Радиокнопки получателя === */
#messages .messages-controls {
  background: var(--m-card);
  border: 1px solid var(--m-border);
  border-radius: 12px;
  padding: 12px 16px;
  box-shadow: var(--m-shadow);
}
#messages .messages-controls .control-group { margin: 0 !important; }
#messages .messages-controls label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: all .15s;
  font-size: 14px;
  color: var(--m-text);
}
#messages .messages-controls label:hover { background: var(--m-accent-soft); }
#messages .messages-controls input[type=radio] { accent-color: var(--m-accent); }

/* === Форма отправки === */
#messages .send-form {
  background: var(--m-card) !important;
  border: 1px solid var(--m-border);
  border-radius: 12px !important;
  padding: 16px !important;
  box-shadow: var(--m-shadow);
}
#messages .send-form input[type=text],
#messages .send-form select {
  border: 1px solid var(--m-border);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: 14px;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
  background: #fff;
}
#messages .send-form input[type=text]:focus,
#messages .send-form select:focus {
  border-color: var(--m-accent);
  box-shadow: 0 0 0 3px rgba(25,118,210,.12);
}
#messages #messageText {
  border: 1px solid var(--m-border) !important;
  border-radius: 10px !important;
  padding: 12px !important;
  font-size: 14px;
  resize: vertical;
  min-height: 80px !important;
  font-family: inherit;
  outline: none;
  transition: border-color .15s, box-shadow .15s;
}
#messages #messageText:focus { border-color: var(--m-accent); box-shadow: 0 0 0 3px rgba(25,118,210,.12); }

#messages .send-form .btn-primary {
  background: var(--m-accent);
  color: #fff;
  border: none;
  border-radius: 10px;
  padding: 10px 20px;
  font-weight: 600;
  font-size: 14px;
  cursor: pointer;
  transition: background .15s, transform .05s;
  align-self: flex-start;
}
#messages .send-form .btn-primary:hover { background: #1565c0; }
#messages .send-form .btn-primary:active { transform: translateY(1px); }

/* Кнопка "Картинка" + превью */
#messages .send-form .btn-sm {
  border-radius: 8px;
  padding: 7px 12px;
  border: 1px solid var(--m-border);
  background: #fff;
  font-size: 13px;
  cursor: pointer;
  transition: all .15s;
}
#messages .send-form .btn-sm:hover { background: var(--m-accent-soft); border-color: var(--m-accent); }
#messages .send-form .btn-danger { color: var(--m-danger); border-color: #f3c4c4; }
#messages #messageImageName { font-size: 13px; color: var(--m-muted); }
#messages #messageImagePreviewImg {
  border-radius: 10px !important;
  border: 1px solid var(--m-border) !important;
  box-shadow: var(--m-shadow);
}

/* === Лента сообщений === */
#messages #messagesFeed {
  background: var(--m-card);
  border: 1px solid var(--m-border);
  border-radius: 12px;
  padding: 16px;
  margin-top: 14px;
  max-height: 600px !important;
  box-shadow: var(--m-shadow);
}
#messages #messagesFeed:empty::before {
  content: "Нет сообщений за выбранную дату";
  color: var(--m-muted);
  font-size: 14px;
  display: block;
  text-align: center;
  padding: 30px;
}

/* Bubble сообщения */
#messages .message-item {
  display: flex;
  flex-direction: column;
  margin: 8px 0;
  max-width: 70%;
  position: relative;
  animation: msgFadeIn .2s ease-out;
}
@keyframes msgFadeIn { from { opacity:0; transform: translateY(4px); } to { opacity:1; transform:none; } }

#messages .message-item.inbound { align-items: flex-start; margin-right: auto; }
#messages .message-item.outbound { align-items: flex-end; margin-left: auto; }
#messages .message-item.system { align-items: center; max-width: 85%; margin-left: auto; margin-right: auto; }

#messages .message-header {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  color: var(--m-muted);
  margin-bottom: 4px;
  padding: 0 8px;
}
#messages .message-header strong { color: var(--m-text); font-weight: 600; font-size: 13px; }

#messages .message-text {
  background: var(--m-bubble-in);
  border: 1px solid var(--m-border);
  border-radius: 16px;
  padding: 10px 14px;
  font-size: 14px;
  line-height: 1.45;
  color: var(--m-text);
  word-wrap: break-word;
  box-shadow: 0 1px 2px rgba(16,24,40,.04);
}
#messages .message-item.inbound .message-text {
  background: var(--m-bubble-in);
  border-bottom-left-radius: 4px;
}
#messages .message-item.outbound .message-text {
  background: var(--m-bubble-out);
  border-color: #b6e0fa;
  border-bottom-right-radius: 4px;
}
#messages .message-item.system .message-text {
  background: var(--m-bubble-system);
  border-color: #ffe1a8;
  font-size: 13px;
  text-align: center;
}

/* Непрочитанное / отвеченное */
#messages .message-item.unread .message-text {
  box-shadow: 0 0 0 2px rgba(25,118,210,.18), 0 1px 2px rgba(16,24,40,.04);
}

/* Картинка во вложении */
#messages .message-text img.msg-attach {
  display: block;
  max-width: 320px;
  max-height: 240px;
  border-radius: 10px;
  margin: 0 0 6px 0;
  cursor: pointer;
}

/* Бейджи */
#messages .badge {
  display: inline-block;
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 999px;
  letter-spacing: .2px;
}
#messages .badge-success { background: #dcfce7; color: var(--m-success); }
#messages .badge-warning { background: #fef3c7; color: var(--m-warning); }
#messages .badge-danger  { background: #fee2e2; color: var(--m-danger); }

/* Кнопки действий внутри bubble */
#messages .message-actions { margin-top: 6px; padding: 0 8px; display: flex; gap: 6px; flex-wrap: wrap; }
#messages .message-actions .btn { border-radius: 8px; padding: 5px 12px; font-size: 12px; border: 1px solid var(--m-border); background: #fff; cursor: pointer; transition: all .15s; }
#messages .message-actions .btn:hover { background: var(--m-accent-soft); border-color: var(--m-accent); }
#messages .message-actions .btn-success { background: #16a34a; color:#fff; border-color:#16a34a; }
#messages .message-actions .btn-success:hover { background:#15803d; }
#messages .message-actions .btn-danger { background: #dc2626; color:#fff; border-color:#dc2626; }
#messages .message-actions .btn-danger:hover { background:#b91c1c; }
#messages .message-actions .btn-primary { background: var(--m-accent); color:#fff; border-color: var(--m-accent); }
#messages .message-actions .btn-primary:hover { background:#1565c0; }

/* Аватарки-инициалы рядом с bubble */
#messages .message-item .msg-avatar {
  position: absolute;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--m-accent); color: #fff;
  font-size: 11px; font-weight: 700;
  display: flex; align-items: center; justify-content: center;
  bottom: 0;
}
#messages .message-item.inbound .msg-avatar { left: -38px; background: #6366f1; }
#messages .message-item.outbound .msg-avatar { right: -38px; background: var(--m-accent); }

/* Скроллбар */
#messages #messagesFeed::-webkit-scrollbar { width: 8px; }
#messages #messagesFeed::-webkit-scrollbar-thumb { background: #d1d5db; border-radius: 4px; }
#messages #messagesFeed::-webkit-scrollbar-thumb:hover { background: #9ca3af; }

/* === Группировка по дням === */
#messages .msg-day-sep {
    display: flex; align-items: center; gap: 10px;
    margin: 14px 0 8px;
}
#messages .msg-day-sep::before,
#messages .msg-day-sep::after {
    content: ""; flex: 1; height: 1px; background: #e3e7ee;
}
#messages .msg-day-sep span {
    font-size: 12px; font-weight: 600; color: #6b7280;
    background: #f4f6fa; padding: 4px 12px; border-radius: 999px;
    border: 1px solid #e3e7ee;
}

/* === Поиск === */
#messages .msg-search-bar {
    margin-top: 14px;
    background: var(--m-card);
    border: 1px solid var(--m-border);
    border-radius: 12px;
    padding: 10px 14px;
    box-shadow: var(--m-shadow);
}
#messages #messagesSearchInput {
    width: 100%; border: none; outline: none; font-size: 14px;
    padding: 4px 0; background: transparent; color: var(--m-text);
}
#messages #messagesSearchInput::placeholder { color: #9ca3af; }

/* === Поправляем место под лентой ===*/
#messages #messagesFeed { margin-top: 8px !important; }


/* === FIX: внутренний отступ ленты, чтобы пузыри не упирались в края === */
#messages #messagesFeed {
    padding: 18px 24px !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    box-sizing: border-box;
}
#messages .message-item {
    max-width: 65% !important;
    margin: 10px 0 !important;
}
#messages .message-item.outbound {
    margin-right: 8px !important;
}
#messages .message-item.inbound {
    margin-left: 8px !important;
}
#messages .message-item .msg-avatar {
    /* вместо абсолюта — встроим внутри bubble чтобы не торчало за край */
    position: static;
    width: 22px; height: 22px; font-size: 10px;
    display: inline-flex; vertical-align: middle;
    margin-right: 6px;
}
#messages .message-item.outbound .msg-avatar { margin-left: 6px; margin-right: 0; }
#messages .message-text { padding: 12px 16px !important; }
#messages .message-actions { padding: 0 4px !important; }

/* Кнопка удалить — компактная, всегда видима */
#messages .message-actions .btn-danger {
    background: #fee2e2; color: #dc2626; border: 1px solid #fecaca;
}
#messages .message-actions .btn-danger:hover { background: #fecaca; }

/* === Навигация по дням крупнее === */
#messages .messages-date-nav { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
#messages .messages-date-nav .btn { min-width: 36px; }
#messages .messages-date-nav input[type=date] { font-size: 14px; padding: 7px 12px; }


/* === FIX: разумные отступы и ширина === */
#messages #messagesFeed {
    padding: 14px 18px !important;
}
#messages .message-item { max-width: 75% !important; margin: 8px 0 !important; }
#messages .message-item.outbound { margin-right: 0 !important; }
#messages .message-item.inbound { margin-left: 0 !important; }
#messages .message-text { padding: 10px 14px !important; }

/* Подсветка важных действий клиента */
#messages .message-item.action-cancel .message-text { background: #fff5f5 !important; border-left: 3px solid #dc2626 !important; }
#messages .message-item.action-makeup-accept .message-text { background: #f0fdf4 !important; border-left: 3px solid #16a34a !important; }
#messages .message-item.action-makeup-decline .message-text { background: #fff7ed !important; border-left: 3px solid #ea580c !important; }
#messages .message-item.action-transfer .message-text { background: #eff6ff !important; border-left: 3px solid #2563eb !important; }
#messages .message-item .action-tag {
    display: inline-block;
    font-size: 10px;
    font-weight: 700;
    text-transform: uppercase;
    padding: 2px 8px;
    border-radius: 4px;
    margin-right: 6px;
    letter-spacing: .3px;
}
#messages .action-cancel .action-tag { background:#fee2e2; color:#b91c1c; }
#messages .action-makeup-accept .action-tag { background:#dcfce7; color:#15803d; }
#messages .action-makeup-decline .action-tag { background:#ffedd5; color:#c2410c; }
#messages .action-transfer .action-tag { background:#dbeafe; color:#1d4ed8; }

/* Toggle "показать все/только важное" */
#messages .messages-filter-bar {
    display: flex; gap: 10px; align-items: center; flex-wrap: wrap;
    margin-top: 10px;
    background: var(--m-card);
    border: 1px solid var(--m-border);
    border-radius: 12px;
    padding: 10px 14px;
    box-shadow: var(--m-shadow);
    font-size: 13px;
}
#messages .messages-filter-bar label {
    display: inline-flex; align-items: center; gap: 6px;
    cursor: pointer; padding: 4px 8px; border-radius: 6px;
}
#messages .messages-filter-bar label:hover { background: var(--m-accent-soft); }
#messages .messages-filter-bar input[type=checkbox] { accent-color: var(--m-accent); }
