@import url('/assets/open-props.min.css');

/* ─────────────────────────────────────────────────────────────
   Дизайн-система «Посредник» — токены (светлая + тёмная по системе/переключателю)
   на базе Open Props. Авто-тема: prefers-color-scheme + ручной [data-theme].
   ───────────────────────────────────────────────────────────── */
:root {
  /* СВЕТЛАЯ ТЕМА (по умолчанию) */
  --bg:#f6f7f9; --bg-2:#eef1f5; --bg-blur:rgba(246,247,249,.82);
  --panel:#ffffff; --panel2:#f1f3f7; --hover:#e9edf3;
  --ink:#10141b; --mut:#5b6573; --line:#e2e6ec; --chip:#eef1f6;
  --acc:#2563eb; --acc-ink:#ffffff; --acc-soft:rgba(37,99,235,.10);
  --good:#16a34a; --warn:#d97706; --bad:#dc2626;
  --good-soft:rgba(22,163,74,.12); --warn-soft:rgba(217,119,6,.14); --bad-soft:rgba(220,38,38,.12); --acc-pill:rgba(37,99,235,.12);
  --shadow-sm:0 1px 2px rgba(16,20,27,.06), 0 1px 3px rgba(16,20,27,.08);
  --shadow-md:0 4px 12px rgba(16,20,27,.08), 0 2px 4px rgba(16,20,27,.05);
  --shadow-lg:0 16px 40px rgba(16,20,27,.16), 0 4px 12px rgba(16,20,27,.08);
  --ring:0 0 0 3px var(--acc-soft);
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:20px;
  --t:.16s var(--ease-3, ease);
  color-scheme: light;
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --bg:#0f1115; --bg-2:#13161c; --bg-blur:rgba(15,17,21,.82);
    --panel:#171a21; --panel2:#1d212b; --hover:#222836;
    --ink:#e8eaed; --mut:#9aa3b2; --line:#2a2f3a; --chip:#222836;
    --acc:#4f9cf9; --acc-ink:#08121f; --acc-soft:rgba(79,156,249,.14);
    --good:#6fd08a; --warn:#f0b440; --bad:#f0746a;
    --good-soft:rgba(111,208,138,.16); --warn-soft:rgba(240,180,64,.16); --bad-soft:rgba(240,116,106,.16); --acc-pill:rgba(79,156,249,.16);
    --shadow-sm:0 1px 2px rgba(0,0,0,.3); --shadow-md:0 6px 18px rgba(0,0,0,.4); --shadow-lg:0 16px 40px rgba(0,0,0,.55);
    color-scheme: dark;
  }
}
/* Ручной выбор темы перекрывает системный */
:root[data-theme="dark"] {
  --bg:#0f1115; --bg-2:#13161c; --bg-blur:rgba(15,17,21,.82);
  --panel:#171a21; --panel2:#1d212b; --hover:#222836;
  --ink:#e8eaed; --mut:#9aa3b2; --line:#2a2f3a; --chip:#222836;
  --acc:#4f9cf9; --acc-ink:#08121f; --acc-soft:rgba(79,156,249,.14);
  --good:#6fd08a; --warn:#f0b440; --bad:#f0746a;
  --good-soft:rgba(111,208,138,.16); --warn-soft:rgba(240,180,64,.16); --bad-soft:rgba(240,116,106,.16); --acc-pill:rgba(79,156,249,.16);
  --shadow-sm:0 1px 2px rgba(0,0,0,.3); --shadow-md:0 6px 18px rgba(0,0,0,.4); --shadow-lg:0 16px 40px rgba(0,0,0,.55);
  color-scheme: dark;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--ink);font:15px/1.55 var(--font-system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif);-webkit-font-smoothing:antialiased;transition:background var(--t),color var(--t)}
a{color:var(--acc);text-decoration:none}a:hover{text-decoration:underline}
::selection{background:var(--acc-soft)}
::-webkit-scrollbar{width:11px;height:11px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px;border:3px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--mut)}

.wrap{max-width:1100px;margin:0 auto;padding:0 18px}
header.top{position:sticky;top:0;z-index:10;background:var(--bg-blur);backdrop-filter:blur(10px) saturate(1.2);border-bottom:1px solid var(--line)}
header.top .wrap{display:flex;align-items:center;gap:14px;height:60px}
.logo{font-weight:800;letter-spacing:-.025em;font-size:19px}
.logo .b{color:var(--acc)}
.role-badge{font-size:12px;color:var(--mut);border:1px solid var(--line);background:var(--chip);padding:3px 11px;border-radius:999px;font-weight:600}
.spacer{flex:1}
.who{font-size:13px;color:var(--mut)}

/* Кнопки */
.btn{cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--ink);padding:8px 15px;border-radius:var(--r-sm);font:inherit;font-size:14px;font-weight:500;transition:background var(--t),border-color var(--t),box-shadow var(--t),transform .05s;box-shadow:var(--shadow-sm)}
.btn:hover{border-color:var(--mut);background:var(--hover)}
.btn:active{transform:translateY(1px)}
.btn:focus-visible{outline:none;box-shadow:var(--ring)}
.btn.primary{background:var(--acc);color:var(--acc-ink);border-color:transparent;font-weight:600}
.btn.primary:hover{filter:brightness(1.07);background:var(--acc)}
.btn.ghost{background:transparent;box-shadow:none}
.btn.ghost:hover{background:var(--hover)}
.btn.sm{padding:5px 11px;font-size:13px;border-radius:7px}
.btn.danger{color:var(--bad)}
.btn.danger:hover{background:var(--bad-soft);border-color:var(--bad)}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ── Навигация кабинетов: группы (верхний ряд) + вкладки группы (нижний ряд) ── */
.navg{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}
.navg .gbtn{cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--mut);padding:7px 14px;border-radius:999px;font:inherit;font-size:13.5px;font-weight:600;white-space:nowrap;transition:background var(--t),color var(--t),border-color var(--t)}
.navg .gbtn:hover{background:var(--hover);color:var(--ink)}
.navg .gbtn.on{background:var(--acc);color:var(--acc-ink);border-color:transparent}
.navg .gbtn .gn{display:inline-block;min-width:16px;text-align:center;margin-left:5px;font-size:11px;padding:0 5px;border-radius:999px;background:var(--acc-pill);color:var(--acc)}
.navg .gbtn.on .gn{background:rgba(255,255,255,.25);color:inherit}
/* Скроллируемый ряд вкладок (помещается всегда — свайп по горизонтали на мобиле) */
.navt{display:flex;gap:6px;overflow-x:auto;scrollbar-width:thin;padding-bottom:6px;margin-bottom:14px;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}
.navt::-webkit-scrollbar{height:6px}
.navt .btn{flex:0 0 auto;white-space:nowrap;scroll-snap-align:start}
@media(max-width:560px){.navg .gbtn{padding:6px 11px;font-size:12.5px}}

/* Поля ввода */
input,select,textarea{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--ink);border-radius:var(--r-sm);padding:9px 12px;font:inherit;font-size:14px;transition:border-color var(--t),box-shadow var(--t)}
input::placeholder,textarea::placeholder{color:var(--mut);opacity:.7}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--acc);box-shadow:var(--ring)}
label{display:block;font-size:12.5px;color:var(--mut);margin:0 0 5px;font-weight:500}
.field{margin-bottom:13px}

.grid{display:grid;gap:13px}
@media(min-width:600px){.g2{grid-template-columns:1fr 1fr}.g3{grid-template-columns:1fr 1fr 1fr}.g4{grid-template-columns:repeat(4,1fr)}}

/* Карточки */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:20px;box-shadow:var(--shadow-sm)}
.muted{color:var(--mut)}
.section-title{font-size:21px;font-weight:750;letter-spacing:-.02em;margin:24px 0 4px}
h2{font-size:18px;margin:0 0 12px;letter-spacing:-.01em}
.toolbar{display:flex;flex-wrap:wrap;gap:10px;align-items:flex-end;margin:14px 0}
.toolbar .field{margin:0}

/* Статы */
.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:16px;box-shadow:var(--shadow-sm)}
.stat .big{font-size:25px;font-weight:760;letter-spacing:-.02em}.stat .lbl{font-size:12px;color:var(--mut);margin-top:2px}

/* Таблицы */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 11px;border-bottom:1px solid var(--line);vertical-align:middle}
th{color:var(--mut);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.04em}
tbody tr{transition:background var(--t)}
tbody tr:hover{background:var(--bg-2)}

/* Пилюли/бейджи */
.pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:12px;font-weight:600;line-height:1.4}
.pill.low,.pill.s-available,.pill.s-won{background:var(--good-soft);color:var(--good)}
.pill.medium,.pill.s-reserved{background:var(--warn-soft);color:var(--warn)}
.pill.high,.pill.s-lost{background:var(--bad-soft);color:var(--bad)}
.pill.s-sold{background:var(--chip);color:var(--mut)}
.pill.s-new,.pill.s-in_progress{background:var(--acc-pill);color:var(--acc)}

/* Карточка авто */
.carcard{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px;display:flex;flex-direction:column;gap:8px;min-width:0;box-shadow:var(--shadow-sm);transition:box-shadow var(--t),border-color var(--t),transform var(--t)}
.carcard *{min-width:0}
.carcard img{max-width:100%}
/* Мультивыбор статусов (фильтр склада) */
.schip{cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--mut);padding:5px 11px;border-radius:999px;font:inherit;font-size:12.5px;font-weight:600;white-space:nowrap;transition:background var(--t),color var(--t),border-color var(--t)}
.schip:hover{background:var(--hover);color:var(--ink)}
.schip.on{background:var(--acc);color:var(--acc-ink);border-color:transparent}
.schip .n{opacity:.7;margin-left:4px;font-weight:400}
.carcard:hover{box-shadow:var(--shadow-md);border-color:var(--mut);transform:translateY(-2px)}
.carcard h3{margin:0;font-size:16px;letter-spacing:-.01em}
.carcard .price{font-size:21px;font-weight:800;letter-spacing:-.025em}
.carcard .specs{font-size:13px;color:var(--mut);display:flex;flex-wrap:wrap;gap:4px 14px}
/* Единый строгий каркас карточки — все слоты на фиксированных местах, чтобы авто легко сравнивать */
.carcard h3{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.carcard .cmod{font-size:12px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:15px}
.cspec{display:grid;grid-template-columns:1fr 1fr;gap:0 14px;font-size:12.5px;margin:2px 0}
.cspec > div{display:flex;justify-content:space-between;gap:6px;padding:3px 0;border-bottom:1px solid var(--line);min-width:0}
.cspec .k{color:var(--mut);white-space:nowrap}
.cspec .v{font-weight:600;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.carcard .copts{font-size:11.5px;color:var(--mut);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-height:16px}
/* VIN — отдельная строка во всю ширину, полностью видимый (17 знаков), моноширинный, переносится при нехватке места */
.cvin{display:flex;align-items:baseline;gap:8px;padding:3px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.cvin .k{color:var(--mut);flex:0 0 auto}
.cvin .vinval{font-weight:600;font-family:ui-monospace,Menlo,Consolas,monospace;letter-spacing:.3px;word-break:break-all;line-height:1.25;text-align:left}
/* спецификация/документ — отдельной строкой, ярлык не обрезается */
.cdoc{display:flex;align-items:baseline;gap:8px;padding:3px 0;border-bottom:1px solid var(--line);font-size:12.5px}
.cdoc .k{color:var(--mut);flex:0 0 auto}
.cdoc a,.cdoc .val{font-weight:600;word-break:break-word;line-height:1.25}
/* Единый формат карточки авто (общий для кабинетов дилера и поставщика) */
.score{font-weight:800;font-size:13px;padding:2px 8px;border-radius:999px}
.iconbtn{font-size:15px;line-height:1;padding:6px 9px}
.cc-head{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.cc-head h3{margin:0;font-size:16px;line-height:1.25}
.cc-year{color:var(--mut);font-weight:500}
.cc-specs{display:flex;flex-wrap:wrap;gap:4px 10px;font-size:13px;color:var(--mut)}
.cc-specs b{color:var(--ink);font-weight:600}
.cc-meta{display:flex;flex-wrap:wrap;gap:4px 12px;font-size:12.5px;color:var(--mut)}
.cc-foot{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-top:2px;padding-top:10px;border-top:1px solid var(--line)}
.cc-actions{display:flex;gap:6px;align-items:center}
.cc-sel{display:flex;align-items:center;gap:8px;font-size:13px;cursor:pointer;user-select:none;padding:8px 10px;border:1px dashed var(--line);border-radius:var(--r-sm);color:var(--mut);transition:.15s}
.cc-sel:hover{border-color:var(--acc);color:var(--ink)}
.cc-sel input{width:auto;margin:0}
.carcard.selected{border-color:var(--acc);box-shadow:0 0 0 1px var(--acc) inset}
.carcard.selected .cc-sel{border-style:solid;border-color:var(--acc);color:var(--acc);background:var(--acc-soft)}
.carcard .cfoot{margin-top:auto;padding-top:6px}
/* единый низ карточки: 2 равные основные кнопки + компактный ряд иконок (одинаково при любом числе) */
.carcard .cact{display:grid;grid-template-columns:1fr 1fr;gap:6px;margin-top:6px}
.carcard .cact .btn{width:100%}
.carcard .cact-mini{display:flex;gap:6px;margin-top:6px;align-items:center}
.carcard .cact-mini .btn{flex:0 0 auto;min-width:38px;text-align:center;padding:5px 9px}
.catalog{display:grid;gap:14px}
@media(min-width:560px){.catalog{grid-template-columns:1fr 1fr}}
@media(min-width:900px){.catalog{grid-template-columns:1fr 1fr 1fr}}

/* Модалки */
.modal-bg{position:fixed;inset:0;background:rgba(5,7,10,.55);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;z-index:50;overflow:auto;animation:fade .15s ease}
.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);padding:24px;max-width:560px;width:100%;box-shadow:var(--shadow-lg);animation:pop .18s var(--ease-3,ease)}
.modal h2{font-size:20px}
.close{float:right;cursor:pointer;color:var(--mut);font-size:24px;line-height:1;transition:color var(--t)}
.close:hover{color:var(--ink)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes pop{from{opacity:0;transform:translateY(8px) scale(.99)}to{opacity:1;transform:none}}

/* Тосты */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--panel);border:1px solid var(--line);padding:12px 18px;border-radius:var(--r-md);z-index:100;box-shadow:var(--shadow-lg);font-size:14px;animation:toastin .2s var(--ease-3,ease)}
@keyframes toastin{from{opacity:0;transform:translate(-50%,10px)}to{opacity:1;transform:translate(-50%,0)}}

/* Логин */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px}
.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-xl);padding:32px;max-width:380px;width:100%;box-shadow:var(--shadow-lg)}
.empty{text-align:center;color:var(--mut);padding:40px 20px}
.flex{display:flex;gap:10px;align-items:center}.between{justify-content:space-between}
.reason{font-size:12.5px;color:var(--mut);margin:3px 0 0;padding-left:16px;position:relative}
.reason::before{content:"•";position:absolute;left:3px;color:var(--mut)}

/* Комбобокс */
.cb-panel{display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:60;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);max-height:260px;overflow:auto;box-shadow:var(--shadow-lg)}
.cb-item{padding:8px 11px;font-size:14px;cursor:pointer}
.cb-item:hover,.cb-item.on{background:var(--acc);color:var(--acc-ink)}
.cb-item b{color:inherit}

/* Мини-карусель */
.ccar{position:relative;border-radius:var(--r-md);overflow:hidden;background:#11141b}
.ccar-track{display:flex;transition:transform .28s var(--ease-3,ease)}
.ccar-slide{min-width:100%;aspect-ratio:16/10}
.ccar-slide img{width:100%;height:100%;object-fit:cover;display:block}
.ccar-nav{position:absolute;top:50%;transform:translateY(-50%);background:rgba(0,0,0,.45);color:#fff;border:0;width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:16px;line-height:1;opacity:0;transition:.15s}
.ccar:hover .ccar-nav{opacity:1}
.ccar-prev{left:6px}.ccar-next{right:6px}
.ccar-dots{position:absolute;bottom:6px;left:0;right:0;text-align:center;pointer-events:none}
.ccar-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.5);margin:0 2px;pointer-events:auto;cursor:pointer}.ccar-dot.on{background:#fff}
.ccar-count{position:absolute;top:6px;right:6px;background:rgba(0,0,0,.55);color:#fff;font-size:11px;padding:1px 7px;border-radius:8px}

/* Подсказка-онбординг */
.hint{position:relative;background:linear-gradient(180deg,var(--acc-soft),transparent);border:1px solid var(--line);border-radius:var(--r-md);padding:14px 18px;margin:16px 0}
.hint b{color:var(--ink)}.hint ol{margin:8px 0 0;padding-left:20px}.hint li{margin:4px 0;color:var(--mut);font-size:14px}
.hx{position:absolute;top:8px;right:12px;cursor:pointer;color:var(--mut);font-size:20px;line-height:1}
.hx:hover{color:var(--ink)}

/* Переключатель темы */
.theme-btn{cursor:pointer;border:1px solid var(--line);background:var(--panel);color:var(--ink);width:34px;height:34px;border-radius:999px;font-size:15px;display:inline-flex;align-items:center;justify-content:center;transition:background var(--t),border-color var(--t);box-shadow:var(--shadow-sm)}
.theme-btn:hover{background:var(--hover);border-color:var(--mut)}

/* Мобильная адаптация */
@media(max-width:600px){
  .wrap{padding:0 12px}
  header.top .wrap{gap:8px;height:54px}
  .who{display:none}
  .logo{font-size:16px}
  .role-badge{display:none}
  .section-title{font-size:18px}
  .modal{padding:18px}
  .modal-bg{padding:16px 8px}
  .card{padding:15px}
  .toolbar{gap:8px}
  h2{font-size:17px}
  .btn{padding:8px 12px}
  #root .flex{flex-wrap:wrap}
  .carcard h3{font-size:15px}
  table{font-size:13px}
  th,td{padding:7px 8px}
  input,select,textarea{font-size:16px}
}
