/* DvTruck — умный подбор техники (поиск + ИИ-чат + подборка) */
.dvp { --dvp-accent: #e8412c; --dvp-bg: #fff; --dvp-line: #e3e5e8;
  font: 14px/1.5 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  color: #1d2327; max-width: 980px; margin: 0 auto; }
.dvp * { box-sizing: border-box; }

/* --- строка поиска --- */
.dvp-searchbar { position: relative; display: flex; gap: 8px; }
.dvp-input { flex: 1; padding: 13px 16px; border: 2px solid var(--dvp-line);
  border-radius: 10px; font-size: 15px; outline: none; transition: border-color .15s; }
.dvp-input:focus { border-color: var(--dvp-accent); }
.dvp-ask { padding: 0 22px; border: 0; border-radius: 10px; background: var(--dvp-accent);
  color: #fff; font-size: 15px; font-weight: 600; cursor: pointer; white-space: nowrap; }
.dvp-ask:hover { filter: brightness(1.07); }
.dvp-hint { margin: 6px 2px 0; font-size: 12.5px; color: #757b80; }

/* --- подсказки typeahead --- */
.dvp-suggest { position: absolute; top: calc(100% + 4px); left: 0; right: 0; z-index: 50;
  background: var(--dvp-bg); border: 1px solid var(--dvp-line); border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,.12); overflow: hidden; display: none; }
.dvp-suggest.open { display: block; }
.dvp-sg-item { display: flex; align-items: center; gap: 10px; padding: 9px 12px;
  cursor: default; }
.dvp-sg-item:hover { background: #f6f7f7; }
.dvp-sg-text { flex: 1; min-width: 0; }
.dvp-sg-title { font-weight: 600; }
.dvp-sg-meta { font-size: 12px; color: #757b80; white-space: nowrap; overflow: hidden;
  text-overflow: ellipsis; }
.dvp-sg-add { flex: none; width: 30px; height: 30px; border-radius: 8px; border: 0;
  background: var(--dvp-accent); color: #fff; font-size: 18px; line-height: 1;
  cursor: pointer; }
.dvp-sg-add[disabled] { background: #9aa0a6; cursor: default; }

/* --- сценарии-чипы --- */
.dvp-chips { display: flex; flex-wrap: wrap; gap: 8px; margin: 12px 0 16px; }
.dvp-chip { padding: 6px 14px; border: 1px solid var(--dvp-line); border-radius: 999px;
  background: #fff; font-size: 13px; cursor: pointer; }
.dvp-chip:hover { border-color: var(--dvp-accent); color: var(--dvp-accent); }

/* --- двухколоночный корпус --- */
.dvp-body { display: grid; grid-template-columns: 1fr 290px; gap: 16px; }
@media (max-width: 760px) { .dvp-body { grid-template-columns: 1fr; } }
/* компактный режим: узкий контейнер (плавающая панель чата) */
.dvp--compact .dvp-body { grid-template-columns: 1fr; }
.dvp--compact .dvp-chips { display: none; }
.dvp--compact .dvp-hint { display: none; }
.dvp--compact .dvp-wishlist { position: static; }

/* --- чат --- */
.dvp-chat { border: 1px solid var(--dvp-line); border-radius: 12px; display: flex;
  flex-direction: column; min-height: 320px; max-height: 560px; background: #fafbfc; }
.dvp-messages { flex: 1; overflow-y: auto; padding: 14px; display: flex;
  flex-direction: column; gap: 10px; }
.dvp-msg { padding: 9px 13px; border-radius: 12px; max-width: 88%; white-space: pre-wrap; }
.dvp-msg.user { background: var(--dvp-accent); color: #fff; align-self: flex-end; }
.dvp-msg.assistant { background: #fff; border: 1px solid var(--dvp-line); align-self: flex-start; }
.dvp-msg.typing { color: #757b80; font-style: italic; }

/* карточки моделей в чате */
.dvp-cards { display: flex; flex-direction: column; gap: 6px; align-self: stretch; }
.dvp-card { display: flex; align-items: center; gap: 10px; background: #fff;
  border: 1px solid var(--dvp-line); border-radius: 10px; padding: 8px 12px; }
.dvp-card-info { flex: 1; min-width: 0; }
.dvp-card-title { font-weight: 600; font-size: 13.5px; }
.dvp-card-title a { color: inherit; text-decoration: none; }
.dvp-card-title a:hover { color: var(--dvp-accent); }
.dvp-card-meta { font-size: 12px; color: #757b80; }
.dvp-card-price { font-size: 12.5px; color: #1d7a34; font-weight: 600; }
.dvp-card-add { flex: none; padding: 6px 10px; border-radius: 8px; border: 1px solid var(--dvp-accent);
  background: #fff; color: var(--dvp-accent); font-size: 12.5px; cursor: pointer; }
.dvp-card-add:hover { background: var(--dvp-accent); color: #fff; }
.dvp-card-add[disabled] { border-color: #9aa0a6; color: #9aa0a6; background: #fff; cursor: default; }

/* --- подборка (вишлист) --- */
.dvp-wishlist { border: 1px solid var(--dvp-line); border-radius: 12px; padding: 14px;
  align-self: start; position: sticky; top: 12px; background: #fff; }
.dvp-wl-head { display: flex; align-items: center; justify-content: space-between;
  font-weight: 700; margin-bottom: 10px; }
.dvp-wl-count { background: var(--dvp-accent); color: #fff; border-radius: 999px;
  font-size: 12px; padding: 1px 9px; }
.dvp-wl-empty { color: #757b80; font-size: 13px; }
.dvp-wl-item { display: flex; align-items: center; gap: 8px; padding: 7px 0;
  border-bottom: 1px dashed var(--dvp-line); }
.dvp-wl-title { flex: 1; font-size: 13px; min-width: 0; }
.dvp-wl-del { border: 0; background: none; color: #b32d2e; font-size: 16px; cursor: pointer; }
.dvp-wl-actions { display: flex; flex-direction: column; gap: 8px; margin-top: 12px; }
.dvp-btn { padding: 9px 12px; border-radius: 9px; font-size: 13.5px; cursor: pointer;
  border: 1px solid var(--dvp-accent); background: #fff; color: var(--dvp-accent); }
.dvp-btn.primary { background: var(--dvp-accent); color: #fff; }
.dvp-btn:hover { filter: brightness(1.05); }

/* --- кликабельное название модели --- */
.dvp-plink { color: var(--dvp-accent); text-decoration: none; cursor: pointer;
  border-bottom: 1px dashed rgba(232,65,44,.4); }
.dvp-plink:hover { border-bottom-style: solid; }

/* --- попап карточки товара --- */
.dvp-modal-overlay { position: fixed; inset: 0; z-index: 100000;
  background: rgba(20,22,25,.55); display: none; align-items: center;
  justify-content: center; padding: 18px; }
.dvp-modal-overlay.open { display: flex; }
.dvp-modal { position: relative; background: #fff; border-radius: 14px;
  width: 560px; max-width: 100%; max-height: 88vh; overflow-y: auto;
  padding: 22px 24px; box-shadow: 0 20px 60px rgba(0,0,0,.3);
  font: 14px/1.5 system-ui, -apple-system, "Segoe UI", Roboto, sans-serif; }
.dvp-modal-close { position: absolute; top: 10px; right: 12px; border: 0;
  background: none; font-size: 26px; line-height: 1; color: #9aa0a6; cursor: pointer; }
.dvp-modal-close:hover { color: #1d2327; }
.dvp-modal-loading { color: #757b80; padding: 20px 0; }
.dvp-modal-title { margin: 0 28px 4px 0; font-size: 19px; }
.dvp-modal-sub { color: #757b80; font-size: 13px; margin-bottom: 12px; }
.dvp-modal-desc { margin: 0 0 12px; color: #2c3338; }
.dvp-modal-uses { background: #fff7f6; border: 1px solid #e8412c22;
  border-radius: 8px; padding: 8px 12px; font-size: 13px; margin-bottom: 14px; }
.dvp-modal-specs-h { font-weight: 700; margin-bottom: 6px; }
.dvp-modal-specs { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.dvp-modal-specs td { padding: 6px 10px; border-bottom: 1px solid #eef0f2;
  vertical-align: top; }
.dvp-spec-k { color: #50575e; width: 55%; }
.dvp-spec-v { font-weight: 600; }
.dvp-modal-price { margin-top: 16px; font-size: 20px; font-weight: 700;
  color: #1d7a34; }
.dvp-modal-price-ask { margin-top: 16px; color: #757b80; font-size: 14px; }
.dvp-modal-actions { margin-top: 18px; }

/* --- лид-форма --- */
.dvp-lead { margin-top: 10px; display: none; flex-direction: column; gap: 8px; }
.dvp-lead.open { display: flex; }
.dvp-lead input { padding: 9px 11px; border: 1px solid var(--dvp-line); border-radius: 8px;
  font-size: 13.5px; }
.dvp-lead-ok { color: #1d7a34; font-size: 13px; }
