/* ════════════════════════════════════════════════════════════════════════════
   DETAILING ADMIN — структура и компоненты
   Все цвета/шрифты/радиусы/тени — через CSS variables из themes/*.css
   Темы переключаются через [data-theme="dark"] на <html>
   ════════════════════════════════════════════════════════════════════════════ */

/* ───── Resets / base ───── */
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }

body {
  font-family: var(--font-body);
  background: var(--bg-page);
  color: var(--text-primary);
  line-height: 1.55;
  font-weight: 400;
  font-size: 15px;
  -webkit-font-smoothing: antialiased;
  transition: var(--theme-transition);
  min-height: 100vh;
}

a { color: var(--text-primary); }
.link { color: var(--accent-primary); text-decoration: none; border-bottom: 1px solid var(--accent-soft-strong); }
.link:hover { border-bottom-color: var(--accent-primary); }

h1, h2, h3 {
  font-family: var(--font-display);
  font-weight: var(--font-display-weight);
  font-style: var(--font-display-style);
  line-height: var(--font-display-line);
  letter-spacing: var(--font-display-letter);
}

em { font-style: italic; color: var(--accent-primary); }

/* ───── TOPBAR ───── */
.topbar {
  background: var(--bg-topbar);
  color: var(--text-on-dark);
  border-bottom: 1px solid var(--border-on-dark);
  box-shadow: var(--shadow-topbar);
  transition: var(--theme-transition);
}
.topbar-inner {
  max-width: var(--container, 1320px);
  margin: 0 auto;
  padding: 14px var(--pad-x, 40px);
  display: flex;
  align-items: center;
  gap: 24px;
  flex-wrap: wrap;
}
.brand {
  font-family: var(--font-display);
  font-weight: var(--font-display-weight);
  font-size: 22px;
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
}
.brand-dot { width: 5px; height: 5px; border-radius: 50%; background: var(--accent-secondary); display: inline-block; transform: translateY(-2px); }
.brand-sub { font-family: var(--font-body); font-size: 10px; letter-spacing: 0.32em; text-transform: uppercase; opacity: 0.7; font-weight: 400; }

.nav { display: flex; gap: 22px; flex: 1; flex-wrap: wrap; }
.nav-item { color: var(--text-on-dark); text-decoration: none; font-size: 13.5px; opacity: 0.65; padding: 6px 0; border-bottom: 1px solid transparent; transition: opacity var(--transition-base), color var(--transition-base), border-color var(--transition-base); }
.nav-item:hover { opacity: 0.95; }
.nav-item.is-active { opacity: 1; border-bottom-color: var(--accent-secondary); }

.topbar-right { display: flex; align-items: center; gap: 16px; }
.user-chip { font-size: 12px; letter-spacing: 0.04em; opacity: 0.7; }

.btn-link { background: none; border: none; color: inherit; cursor: pointer; font: inherit; text-decoration: underline; text-underline-offset: 3px; padding: 0; opacity: 0.85; }
.btn-link:hover { opacity: 1; }
.btn-link.danger { color: var(--status-danger); }
.logout-form { display: inline; }

/* ───── THEME TOGGLE ───── */
.theme-toggle {
  background: transparent;
  border: 1px solid var(--border-on-dark);
  border-radius: var(--radius-pill);
  width: 36px;
  height: 36px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text-on-dark);
  transition: var(--theme-transition), transform var(--transition-base);
}
.theme-toggle:hover { transform: rotate(15deg); border-color: var(--accent-primary); color: var(--accent-primary); }
.theme-toggle svg { width: 18px; height: 18px; }
.theme-toggle .icon-sun { display: none; }
.theme-toggle .icon-moon { display: block; }
:root[data-theme="dark"] .theme-toggle .icon-sun { display: block; }
:root[data-theme="dark"] .theme-toggle .icon-moon { display: none; }
.theme-toggle-floating { position: fixed; top: 18px; right: 18px; z-index: 100; background: rgba(255,255,255,0.06); backdrop-filter: blur(8px); border-color: rgba(255,255,255,0.18); color: var(--text-on-dark); }

/* ───── MAIN ───── */
.main { max-width: var(--container, 1320px); margin: 0 auto; padding: 32px var(--pad-x, 40px) 80px; }
.main-bare { padding: 0; max-width: none; }
:root { --pad-x: clamp(16px, 3.5vw, 40px); --container: 1320px; }

/* ───── PAGE HEAD ───── */
.page-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 24px; margin-bottom: 28px; padding-bottom: 22px; border-bottom: 1px solid var(--border-default); flex-wrap: wrap; }
.page-head.with-actions { align-items: center; }
.eyebrow { font-size: 11px; letter-spacing: var(--eyebrow-letter); text-transform: uppercase; color: var(--text-dim); display: block; margin-bottom: 8px; }
.page-title { font-size: clamp(26px, 3.2vw, 42px); font-weight: var(--font-display-weight); }
.page-sub { margin-top: 8px; color: var(--text-dim); font-size: 14px; max-width: 70ch; }

/* ───── BUTTONS ───── */
.btn { display: inline-flex; align-items: center; gap: 8px; padding: 11px 22px; font-size: 13.5px; font-family: inherit; font-weight: 500; letter-spacing: 0.02em; border: 1px solid transparent; border-radius: var(--radius-pill); cursor: pointer; text-decoration: none; transition: all 0.18s ease; background: transparent; color: var(--text-primary); }
.btn-primary { background: var(--accent-primary); color: var(--text-on-accent); border-color: var(--accent-primary); }
.btn-primary:hover { background: var(--accent-primary-hover); transform: translateY(-1px); box-shadow: var(--shadow-button-hover); }
.btn-ghost { background: transparent; border-color: var(--border-strong); color: var(--text-primary); }
.btn-ghost:hover { border-color: var(--accent-primary); color: var(--accent-primary); }
.btn-ghost.is-active { background: var(--accent-primary); color: var(--text-on-accent); border-color: var(--accent-primary); }
.btn-danger { background: transparent; color: var(--status-danger); border-color: var(--status-danger-border); }
.btn-danger:hover { background: var(--status-danger); color: var(--text-on-accent); border-color: var(--status-danger); }
.btn-sm { padding: 7px 14px; font-size: 12.5px; }
.inline { display: inline; }

/* ───── STAT GRID ───── */
.stat-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; margin-bottom: 36px; }
.stat-grid-3 { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.stat-card { display: flex; flex-direction: column; gap: 6px; padding: 20px 22px; background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-3xl); text-decoration: none; color: inherit; transition: var(--theme-transition), transform var(--transition-base); box-shadow: var(--shadow-card); }
a.stat-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-card-hover); border-color: var(--accent-soft-border); }
.stat-card-muted { background: var(--bg-card-muted); border-style: dashed; }
.stat-label { font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--text-dim); }
.stat-value { font-family: var(--font-display); font-size: 42px; line-height: 1; font-weight: var(--font-display-weight); }
.stat-value-text { font-size: 24px; }
.stat-of { font-size: 18px; color: var(--text-dim); margin-left: 4px; }
.stat-link { font-size: 12.5px; color: var(--accent-primary); }
.stat-hint { font-size: 11px; color: var(--text-dim); letter-spacing: 0.05em; }

/* ───── DASH GRID ───── */
.dash-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 22px; }
.dash-col { display: flex; flex-direction: column; gap: 22px; }
@media (max-width: 980px) { .dash-grid { grid-template-columns: 1fr; } }

/* ───── TABLE / SEARCH ───── */
.search-bar { display: flex; gap: 10px; align-items: center; margin-bottom: 22px; flex-wrap: wrap; }
.search-bar input[type=search] { flex: 1; min-width: 240px; padding: 11px 16px; border: 1px solid var(--border-strong); border-radius: var(--radius-pill); font: inherit; background: var(--bg-input); color: var(--text-primary); transition: var(--theme-transition); }
.search-bar input[type=search]:focus { outline: none; border-color: var(--accent-primary); }

.table-wrap { background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-3xl); overflow: hidden; transition: var(--theme-transition); }
.table-flat { border: none; background: transparent; }
.table { width: 100%; border-collapse: collapse; }
.table th, .table td { text-align: left; padding: 12px 16px; font-size: 14px; vertical-align: middle; }
.table th { font-size: 10.5px; letter-spacing: 0.18em; text-transform: uppercase; color: var(--text-dim); font-weight: 500; background: var(--bg-row-header); border-bottom: 1px solid var(--border-default); }
.table-flat .table th { background: transparent; padding-left: 0; padding-right: 0; }
.table-flat .table td { padding-left: 0; padding-right: 0; border-color: var(--border-default); }
.table tr + tr td { border-top: 1px solid var(--border-default); }
.table .num { text-align: right; white-space: nowrap; }
.table .dim { color: var(--text-dim); font-size: 13px; }
.table .center { text-align: center; }
.cell-strong { font-weight: 500; }

/* ───── TAGS ───── */
.tag { display: inline-block; padding: 3px 10px; border-radius: var(--radius-pill); font-size: 11px; letter-spacing: 0.06em; border: 1px solid var(--border-strong); background: transparent; vertical-align: middle; transition: var(--theme-transition); }
.tag-individual { color: var(--text-dim); }
.tag-legal { color: var(--tag-legal-fg); border-color: var(--tag-legal-border); background: var(--tag-legal-bg); }

/* ───── EMPTY ───── */
.empty { text-align: center; padding: 60px 24px; color: var(--text-dim); border: 1px dashed var(--border-strong); border-radius: var(--radius-3xl); display: flex; flex-direction: column; align-items: center; gap: 16px; }
.empty-inline { color: var(--text-dim); font-size: 14px; padding: 14px 0; }

/* ───── CARDS ───── */
.card { background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-3xl); padding: 22px 26px; margin-bottom: 20px; transition: var(--theme-transition); box-shadow: var(--shadow-card); }
.card-head { display: flex; justify-content: space-between; align-items: center; gap: 16px; margin-bottom: 16px; flex-wrap: wrap; }
.card-title { font-size: 22px; margin-bottom: 12px; }
.card-head .card-title { margin-bottom: 0; }
.card-info { background: var(--bg-card-info); border-color: var(--accent-soft-border); }
.card-ai { background: var(--bg-card-ai); border-color: var(--accent-soft-border); }

.info-list { display: grid; grid-template-columns: 180px 1fr; gap: 8px 24px; font-size: 14px; }
.info-list.compact { grid-template-columns: 130px 1fr; font-size: 13.5px; gap: 6px 14px; }
.info-list dt { color: var(--text-dim); }
.info-list dd .mono { font-family: var(--font-mono); font-size: 12.5px; }
.info-list .pre { white-space: pre-wrap; }
.mono { font-family: var(--font-mono); font-size: 12.5px; }

/* ───── VEHICLES ───── */
.vehicle-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 16px; }
.vehicle-card { background: var(--bg-card-soft); border: 1px solid var(--border-default); border-radius: var(--radius-2xl); padding: 16px 18px; transition: var(--theme-transition); }
.vehicle-head { display: flex; justify-content: space-between; align-items: baseline; gap: 12px; margin-bottom: 10px; }
.vehicle-head h3 { font-size: 19px; }
.plate { font-family: var(--font-mono); font-size: 12px; padding: 3px 8px; background: var(--plate-bg); color: var(--plate-fg); border-radius: var(--radius-sm); letter-spacing: 0.05em; display: inline-block; transition: var(--theme-transition); }
.plate-sm { font-size: 11px; padding: 2px 6px; }
.plate-md { font-size: 14px; padding: 4px 10px; vertical-align: middle; margin-left: 8px; }
.vehicle-actions { margin-top: 12px; display: flex; gap: 14px; align-items: center; }

/* ───── FORMS ───── */
.form { display: flex; flex-direction: column; gap: 16px; max-width: 480px; }
.form-wide { max-width: 920px; }
.field { display: flex; flex-direction: column; gap: 6px; }
.field > span { font-size: 11.5px; letter-spacing: 0.06em; text-transform: uppercase; color: var(--text-dim); }
.field input, .field select, .field textarea { padding: 11px 14px; border: 1px solid var(--border-strong); border-radius: var(--radius-lg); font: inherit; background: var(--bg-input); color: var(--text-primary); transition: var(--theme-transition); }
.field input:focus, .field select:focus, .field textarea:focus { outline: none; border-color: var(--accent-primary); }
.field textarea { resize: vertical; font-family: inherit; }
.fieldset { border: 1px solid var(--border-default); border-radius: var(--radius-2xl); padding: 18px 22px; background: var(--bg-card); margin-bottom: 4px; transition: var(--theme-transition); }
.fieldset legend { font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--text-dim); padding: 0 8px; }
.fieldset.hidden { display: none; }
.grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr)); gap: 14px; }
.grid-span-2 { grid-column: 1 / -1; }
@media (min-width: 720px) { .grid-span-2 { grid-column: span 2; } }
.check-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 8px; margin-bottom: 12px; }
.check { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; padding: 6px 0; }
.check input { accent-color: var(--accent-primary); }
.radio-row { display: flex; gap: 18px; flex-wrap: wrap; }
.radio { display: inline-flex; gap: 8px; align-items: center; cursor: pointer; }
.radio input { accent-color: var(--accent-primary); }
.form-actions { display: flex; gap: 12px; margin-top: 6px; }

.error-msg { padding: 12px 16px; background: var(--status-danger-soft); color: var(--status-danger); border: 1px solid var(--status-danger-border); border-radius: var(--radius-lg); font-size: 14px; margin-bottom: 14px; }
.flash { max-width: var(--container); margin: 0 auto 18px; padding: 11px 18px; border-radius: var(--radius-lg); font-size: 14px; border: 1px solid; }
.flash-success { background: var(--status-ok-soft); color: var(--status-ok); border-color: var(--status-ok-border); }
.flash-error { background: var(--status-danger-soft); color: var(--status-danger); border-color: var(--status-danger-border); }
.flash-info { background: var(--bg-overlay-soft); color: var(--text-primary); border-color: var(--border-strong); }

/* ───── LOGIN ───── */
.login-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 24px; background: var(--login-bg); background-image: radial-gradient(circle at 20% 20%, var(--login-bg-grad-1), transparent 50%), radial-gradient(circle at 80% 80%, var(--login-bg-grad-2), transparent 60%); transition: var(--theme-transition); }
.login-card { background: var(--login-card-bg); padding: 44px 40px 36px; border-radius: var(--radius-modal); width: 100%; max-width: 380px; box-shadow: var(--shadow-login); transition: var(--theme-transition); }
.login-brand { font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 24px; display: flex; align-items: baseline; gap: 8px; margin-bottom: 18px; }
.login-brand .brand-dot { background: var(--login-brand-dot); }
.login-title { font-size: 30px; margin-bottom: 24px; }

/* ───── STATUS BADGE ───── */
.status-badge { display: inline-block; padding: 3px 11px; border-radius: var(--radius-pill); font-size: 11.5px; letter-spacing: 0.04em; border: 1px solid var(--border-strong); background: var(--bg-card); color: var(--text-primary); white-space: nowrap; transition: var(--theme-transition); }
.status-badge.status-lead { background: var(--badge-lead-bg); color: var(--badge-lead-fg); border-color: var(--badge-lead-border); }
.status-badge.status-inspection_scheduled { background: var(--badge-scheduled-bg); color: var(--badge-scheduled-fg); border-color: var(--badge-scheduled-border); }
.status-badge.status-inspected { background: var(--badge-inspected-bg); color: var(--badge-inspected-fg); }
.status-badge.status-estimate_sent,
.status-badge.status-estimate_approved { background: var(--badge-estimate-bg); color: var(--badge-estimate-fg); border-color: var(--badge-estimate-border); }
.status-badge.status-arrived { background: var(--badge-arrived-bg); color: var(--badge-arrived-fg); border-color: var(--badge-arrived-border); }
.status-badge.status-in_progress { background: var(--badge-progress-bg); color: var(--badge-progress-fg); border-color: var(--badge-progress-border); }
.status-badge.status-ready { background: var(--badge-ready-bg); color: var(--badge-ready-fg); border-color: var(--badge-ready-border); }
.status-badge.status-completed { background: var(--badge-completed-bg); color: var(--badge-completed-fg); border-color: var(--badge-completed-border); }
.status-badge.status-post_care_pending,
.status-badge.status-post_care_done { background: var(--badge-postcare-bg); color: var(--badge-postcare-fg); border-color: var(--badge-postcare-border); }
.status-badge.status-paused { background: var(--badge-paused-bg); color: var(--badge-paused-fg); border-color: var(--badge-paused-border); }
.status-badge.status-closed { background: var(--badge-closed-bg); color: var(--badge-closed-fg); }

/* ───── CHANNEL CHIP ───── */
.channel-chip { display: inline-flex; align-items: center; gap: 6px; font-size: 12.5px; color: var(--text-primary); }
.ch-icon { display: inline-flex; align-items: center; justify-content: center; width: 22px; height: 22px; border-radius: var(--radius-md); background: var(--channel-default-bg); font-size: 13px; font-weight: 500; transition: var(--theme-transition); }
.ch-icon.ch-telegram { background: var(--channel-telegram-bg); color: var(--channel-telegram-fg); }
.ch-icon.ch-email { background: var(--channel-email-bg); color: var(--channel-email-fg); }
.ch-icon.ch-web_form { background: var(--channel-web-bg); color: var(--channel-web-fg); }
.ch-icon.ch-avito { background: var(--channel-avito-bg); color: var(--channel-avito-fg); }
.ch-icon.ch-yandex_uslugi { background: var(--channel-yandex-bg); color: var(--channel-yandex-fg); }
.ch-icon.ch-instagram { background: var(--channel-instagram-bg); color: var(--channel-instagram-fg); }

/* ───── PROGRESS BAR ───── */
.progress { position: relative; height: 8px; background: var(--bg-progress); border-radius: var(--radius-pill); overflow: hidden; margin: 6px 0; transition: var(--theme-transition); }
.progress-fill { height: 100%; background: var(--accent-primary); border-radius: var(--radius-pill); transition: width var(--transition-slow), background var(--transition-slow); }
.progress-label { position: absolute; right: 6px; top: -16px; font-size: 11px; color: var(--text-dim); }

/* ───── MINI BOXES (dashboard) ───── */
.mini-boxes { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; }
@media (max-width: 760px) { .mini-boxes { grid-template-columns: repeat(2, 1fr); } }
.mini-box { display: flex; gap: 10px; padding: 14px; border-radius: var(--radius-2xl); border: 1px solid var(--border-default); text-decoration: none; color: inherit; min-height: 110px; transition: var(--theme-transition); }
.mini-box-free { background: var(--bg-overlay-soft); flex-direction: column; align-items: flex-start; justify-content: center; border-style: dashed; }
.mini-box-busy { background: var(--bg-card); align-items: flex-start; }
.mini-box-busy:hover { border-color: var(--accent-primary); }
.mb-num { font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 28px; line-height: 1; color: var(--text-dim); }
.mini-box-busy .mb-num { color: var(--accent-primary); }
.mb-info { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.mb-state { font-size: 12px; color: var(--text-dim); letter-spacing: 0.1em; text-transform: uppercase; }
.mb-car { font-weight: 500; font-size: 13.5px; }
.mb-status { font-size: 12px; color: var(--text-dim); }
.mb-eta { font-size: 11px; color: var(--text-dim); margin-top: 4px; }

/* ───── BOXES PAGE ───── */
.boxes-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 16px; margin-bottom: 24px; }
.box-card { background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-3xl); padding: 22px; transition: var(--theme-transition); box-shadow: var(--shadow-card); }
.box-card-free { border-style: dashed; background: transparent; text-align: center; padding: 60px 22px; }
.box-card-free .box-num { font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 64px; line-height: 1; color: var(--text-dim); }
.box-card-free .box-state { color: var(--text-dim); letter-spacing: 0.16em; text-transform: uppercase; font-size: 12px; margin-top: 8px; }
.box-card-free .box-hint { color: var(--text-dim); font-size: 13px; margin-top: 6px; }
.box-card-busy { border-color: var(--accent-soft-border); }
.box-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 14px; }
.box-card-busy .box-num { font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 44px; line-height: 1; color: var(--accent-primary); }
.box-car { font-size: 18px; font-weight: 500; text-decoration: none; color: var(--text-primary); display: block; margin-bottom: 4px; }
.box-card-busy .box-car:hover { color: var(--accent-primary); }
.box-client { color: var(--text-dim); font-size: 13px; margin-bottom: 12px; }
.box-card-busy .info-list { margin: 12px 0; }
.box-card-busy .btn { margin-top: 12px; width: 100%; justify-content: center; }

/* ───── SOURCES PAGE ───── */
.sources-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 16px; margin-bottom: 24px; }
@media (max-width: 1080px) { .sources-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 640px) { .sources-grid { grid-template-columns: 1fr; } }
.source-card { background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-3xl); padding: 20px 22px; transition: var(--theme-transition); box-shadow: var(--shadow-card); display: flex; flex-direction: column; }
.source-card.is-off { opacity: 0.72; background: var(--bg-card-muted); }
.source-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; }
.source-head .ch-icon { width: 36px; height: 36px; font-size: 18px; }
.source-title { flex: 1; }
.source-name { font-weight: 500; font-size: 16px; }
.source-type { font-size: 12px; color: var(--text-dim); margin-top: 2px; }
.switch { padding: 5px 12px; border-radius: var(--radius-pill); border: 1px solid var(--border-strong); background: transparent; cursor: pointer; font-size: 11px; letter-spacing: 0.1em; font-family: inherit; font-weight: 500; color: var(--text-primary); transition: var(--theme-transition); }
.switch-on { background: var(--accent-primary); color: var(--text-on-accent); border-color: var(--accent-primary); }
.switch-off { background: transparent; color: var(--text-dim); }
.source-stats { display: flex; flex-direction: column; gap: 4px; font-size: 13px; }
.source-notes { margin-top: auto; padding-top: 14px; border-top: 1px solid var(--border-default); font-size: 12.5px; color: var(--text-dim); line-height: 1.5; }
.source-card .source-stats { margin-bottom: 6px; }

.list-bullets { list-style: disc; padding-left: 20px; }
.list-bullets li { margin: 6px 0; }

/* ───── AI METRICS ───── */
.ai-metrics { display: flex; flex-direction: column; gap: 14px; }
.ai-metric { padding: 14px 16px; background: var(--accent-soft); border-radius: var(--radius-xl); display: flex; flex-direction: column; gap: 2px; transition: var(--theme-transition); }
.ai-metric-value { font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 28px; line-height: 1; color: var(--accent-primary); }
.ai-metric-label { font-size: 12px; color: var(--text-dim); }

/* ───── TABS ───── */
.tabs { display: flex; gap: 4px; margin-bottom: 22px; border-bottom: 1px solid var(--border-default); flex-wrap: wrap; }
.tab { padding: 10px 16px; font-size: 13.5px; text-decoration: none; color: var(--text-dim); border-bottom: 2px solid transparent; margin-bottom: -1px; display: inline-flex; align-items: center; gap: 8px; transition: var(--theme-transition); }
.tab:hover { color: var(--text-primary); }
.tab.is-active { color: var(--text-primary); border-bottom-color: var(--accent-primary); }
.tab-count { font-size: 11px; background: var(--bg-overlay-soft); padding: 2px 8px; border-radius: var(--radius-pill); color: var(--text-dim); }
.tab.is-active .tab-count { background: var(--accent-soft-strong); color: var(--accent-primary); }

/* ───── VISIT GRID ───── */
.visit-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 22px; }
.visit-col { display: flex; flex-direction: column; }
.visit-col-narrow .card { padding: 18px 20px; }
@media (max-width: 980px) { .visit-grid { grid-template-columns: 1fr; } }
.visit-head .actions { display: flex; align-items: center; gap: 12px; }

.status-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.status-actions-sub { margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--border-default); }
.status-actions-label { font-size: 11px; color: var(--text-dim); letter-spacing: 0.1em; text-transform: uppercase; align-self: center; margin-right: 8px; }

.svc-list { list-style: none; }
.svc-list li { display: flex; justify-content: space-between; padding: 8px 0; border-top: 1px solid var(--border-default); font-size: 14px; }
.svc-list li:first-child { border-top: none; }
.svc-total { margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--border-default); display: flex; justify-content: flex-end; font-size: 15px; }

.doc-buttons { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: 8px; margin-bottom: 16px; }
.btn-doc { justify-content: flex-start; }
.doc-icon { font-size: 16px; }
.docs-list { list-style: none; display: flex; flex-direction: column; gap: 6px; font-size: 13.5px; }

.notif-list { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.notif-list li { display: grid; grid-template-columns: 110px auto 1fr auto; gap: 10px; font-size: 12.5px; align-items: baseline; }
.notif-time { font-size: 11px; }
.notif-channel { color: var(--accent-primary); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; }
.notif-body { color: var(--text-primary); }
.notif-status { font-size: 10px; padding: 2px 8px; border-radius: var(--radius-pill); background: var(--bg-overlay-soft); color: var(--text-dim); letter-spacing: 0.1em; text-transform: uppercase; }
.notif-status.status-sent { background: var(--status-ok-soft); color: var(--status-ok); }
.notif-status.status-failed { background: var(--status-danger-soft); color: var(--status-danger); }

/* ───── PHOTOS ───── */
.photo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 10px; }
@media (max-width: 600px) { .photo-grid { grid-template-columns: 1fr; } }
.photo-slot { background: var(--bg-photo-placeholder); border: 1px dashed var(--border-strong); border-radius: var(--radius-xl); aspect-ratio: 4/3; display: flex; align-items: center; justify-content: center; position: relative; overflow: hidden; transition: var(--theme-transition); }
.photo-slot.has-photo { border-style: solid; }
.photo-slot img { width: 100%; height: 100%; object-fit: cover; }
.photo-placeholder { color: var(--text-dim); font-size: 13px; letter-spacing: 0.1em; text-transform: uppercase; }
.photo-label { position: absolute; bottom: 6px; left: 8px; background: var(--bg-photo-label); color: var(--text-on-dark); padding: 3px 8px; border-radius: var(--radius-md); font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; }

/* ───── MODAL ───── */
.modal { position: fixed; inset: 0; z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 24px; }
.modal.hidden { display: none; }
.modal-backdrop { position: absolute; inset: 0; background: var(--bg-modal-backdrop); }
.modal-card { position: relative; background: var(--bg-page); border-radius: var(--radius-modal); max-width: 540px; width: 100%; max-height: 90vh; overflow: auto; box-shadow: var(--shadow-modal); transition: var(--theme-transition); }
.modal-head { display: flex; justify-content: space-between; align-items: center; padding: 20px 26px; border-bottom: 1px solid var(--border-default); }
.modal-head h3 { font-size: 22px; }
.modal-body { padding: 26px; }
.doc-preview { background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-xl); padding: 30px 28px; margin-bottom: 18px; position: relative; min-height: 220px; }
.doc-preview-stamp { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%) rotate(-12deg); font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 72px; color: var(--doc-stamp-color); letter-spacing: 0.15em; pointer-events: none; }
.doc-preview-body { display: flex; flex-direction: column; gap: 12px; }
.doc-preview-line { height: 10px; background: var(--bg-overlay-soft); border-radius: var(--radius-sm); }
.doc-preview-line.w-50 { width: 50%; }
.doc-preview-line.w-60 { width: 60%; }
.doc-preview-line.w-70 { width: 70%; }
.doc-preview-line.w-80 { width: 80%; }
.doc-preview-line.w-90 { width: 90%; }

/* ───── CHAT THREAD ───── */
.chat-wrap { display: grid; grid-template-columns: 1fr 280px; gap: 22px; }
@media (max-width: 980px) { .chat-wrap { grid-template-columns: 1fr; } }
.chat-thread { background: var(--bg-card); border: 1px solid var(--border-default); border-radius: var(--radius-3xl); padding: 22px; display: flex; flex-direction: column; gap: 14px; max-height: 75vh; overflow-y: auto; transition: var(--theme-transition); }
.msg { padding: 12px 16px; border-radius: var(--radius-2xl); max-width: 78%; transition: var(--theme-transition); }
.msg-head { display: flex; gap: 10px; align-items: baseline; font-size: 11.5px; margin-bottom: 6px; }
.msg-author { font-weight: 500; letter-spacing: 0.04em; }
.msg-time { color: var(--text-dim); font-size: 11px; }
.msg-mode { font-size: 10px; padding: 1px 7px; border-radius: var(--radius-pill); background: var(--accent-soft-strong); color: var(--accent-primary); letter-spacing: 0.08em; text-transform: uppercase; }
.msg-mode.msg-mode-warn { background: var(--status-warn-soft); color: var(--status-warn); }
.msg-body { font-size: 14px; line-height: 1.5; white-space: pre-wrap; word-break: break-word; }
.msg-tokens { margin-top: 4px; font-size: 10.5px; letter-spacing: 0.04em; }

.msg-user { align-self: flex-start; background: var(--bg-overlay-soft); }
.msg-ai { align-self: flex-end; background: var(--accent-soft); border: 1px solid var(--accent-soft-border); }
.msg-owner { align-self: flex-end; background: var(--bg-topbar); color: var(--text-on-dark); }
.msg-owner .msg-author, .msg-owner .msg-time { color: var(--text-on-dark-dim); }
.msg-owner .msg-mode { background: rgba(243, 241, 237, 0.18); color: var(--text-on-dark); }

.chat-side { display: flex; flex-direction: column; gap: 16px; }

/* ───── UTILITIES ───── */
.hidden { display: none !important; }
.dim { color: var(--text-dim); }
.center { text-align: center; }

@media (max-width: 720px) {
  .topbar-inner { gap: 10px; }
  .topbar-right { margin-left: auto; }
  .page-head { align-items: flex-start; flex-direction: column; }
  .notif-list li { grid-template-columns: 1fr; gap: 2px; }
}

/* ════════════════════════════════════════════════════════════════════════════
   INBOX / SOURCES GROUPS / DASHBOARD WIDGET (сессия #8)
   Все цвета через переменные → работают в обеих темах.
   ════════════════════════════════════════════════════════════════════════════ */

/* ───── Channel plate (большая иконка канала, для inbox/sources headers) ───── */
.ch-plate {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-lg);
  font-size: 18px;
  font-weight: 600;
  flex-shrink: 0;
  background: var(--channel-default-bg);
  color: var(--text-primary);
  transition: var(--theme-transition);
}
.ch-plate.group-calls { background: var(--group-calls-bg); color: var(--group-calls-fg); }
.ch-plate.group-telegram { background: var(--channel-telegram-bg); color: var(--channel-telegram-fg); }
.ch-plate.group-email { background: var(--channel-email-bg); color: var(--channel-email-fg); }
.ch-plate.group-avito { background: var(--channel-avito-bg); color: var(--channel-avito-fg); }
.ch-plate.group-classifieds { background: var(--channel-yandex-bg); color: var(--channel-yandex-fg); }
.ch-plate.group-instagram { background: var(--channel-instagram-bg); color: var(--channel-instagram-fg); }
.ch-plate.group-website { background: var(--channel-web-bg); color: var(--channel-web-fg); }
.ch-plate.group-manual { background: var(--channel-default-bg); color: var(--text-dim); }

/* ───── Inbox widget (на главной) ───── */
.inbox-widget {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  padding: 22px 26px;
  margin-bottom: 14px;
  text-decoration: none;
  color: inherit;
  border-color: var(--border-default);
}
.inbox-widget:hover { border-color: var(--accent-soft-border); box-shadow: var(--shadow-card-hover); }
.inbox-widget.has-unhandled { border-color: var(--status-danger-border); background: var(--status-danger-soft); }
.iw-main { display: flex; flex-direction: column; gap: 4px; flex: 1; }
.iw-label { font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--text-dim); }
.iw-value { font-family: var(--font-display); font-weight: var(--font-display-weight); font-size: 44px; line-height: 1; display: flex; align-items: baseline; gap: 12px; }
.iw-dot { display: inline-block; width: 12px; height: 12px; border-radius: 50%; background: var(--status-danger); }
.has-unhandled .iw-value { color: var(--status-danger); }
.iw-hint { font-size: 12px; color: var(--text-dim); margin-top: 6px; }
.iw-cta { font-size: 14px; color: var(--accent-primary); white-space: nowrap; }

.inbox-fresh-missed {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  margin-bottom: 26px;
  background: var(--status-danger-soft);
  border: 1px solid var(--status-danger-border);
  border-radius: var(--radius-3xl);
  text-decoration: none;
  color: var(--status-danger);
  transition: var(--theme-transition);
}
.inbox-fresh-missed:hover { background: var(--status-danger); color: var(--text-on-accent); }
.pulse-dot {
  width: 12px; height: 12px; border-radius: 50%; background: var(--status-danger);
  animation: pulse-red 1.6s ease-in-out infinite;
  flex-shrink: 0;
}
.inbox-fresh-missed:hover .pulse-dot { background: var(--text-on-accent); }
.ifm-text { flex: 1; }
.ifm-title { font-weight: 600; font-size: 14px; }
.ifm-sub { font-size: 12.5px; opacity: 0.85; margin-top: 2px; }
.ifm-cta { font-weight: 500; font-size: 13px; white-space: nowrap; }

@keyframes pulse-red {
  0%, 100% { transform: scale(1); box-shadow: 0 0 0 0 var(--status-danger-border); }
  50% { transform: scale(1.15); box-shadow: 0 0 0 8px transparent; }
}

/* ───── Inbox list ───── */
.inbox-list { display: flex; flex-direction: column; gap: 4px; }

.inbox-row {
  background: var(--bg-card);
  border: 1px solid var(--border-default);
  border-radius: var(--radius-2xl);
  transition: var(--theme-transition);
  overflow: hidden;
}
.inbox-row[open] { box-shadow: var(--shadow-card-hover); border-color: var(--accent-soft-border); }
.inbox-row.is-missed-call { border-left: 3px solid var(--status-danger); }
.inbox-row.is-missed-call:not([open]) { background: var(--status-danger-soft); }

.inbox-row-head {
  display: grid;
  grid-template-columns: 36px 120px 1fr 2fr auto auto;
  align-items: center;
  gap: 14px;
  padding: 12px 16px;
  cursor: pointer;
  list-style: none;
  user-select: none;
}
.inbox-row-head::-webkit-details-marker { display: none; }
.inbox-row-head::marker { content: ''; }
.inbox-row-head:hover { background: var(--bg-overlay-soft); }

.inbox-time { font-size: 12.5px; color: var(--text-dim); white-space: nowrap; }
.inbox-contact { font-size: 14px; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.inbox-preview { font-size: 13.5px; color: var(--text-dim); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.call-meta { display: inline-block; margin-left: 8px; font-size: 12px; }
.inbox-visit-badge { font-size: 11.5px; padding: 3px 8px; border-radius: var(--radius-pill); background: var(--accent-soft); border: none; }

.status-pill {
  display: inline-block;
  padding: 3px 10px;
  border-radius: var(--radius-pill);
  font-size: 11px;
  letter-spacing: 0.04em;
  background: var(--badge-scheduled-bg);
  color: var(--badge-scheduled-fg);
  white-space: nowrap;
  border: 1px solid transparent;
}
.status-pill-new { background: var(--accent-soft); color: var(--accent-primary); border-color: var(--accent-soft-border); }
.status-pill-in_progress { background: var(--badge-progress-bg); color: var(--badge-progress-fg); }
.status-pill-answered { background: var(--badge-ready-bg); color: var(--badge-ready-fg); border-color: var(--badge-ready-border); }
.status-pill-missed { background: var(--status-danger); color: var(--text-on-accent); }
.status-pill-escalated { background: var(--badge-postcare-bg); color: var(--badge-postcare-fg); border-color: var(--badge-postcare-border); }
.status-pill-archived { background: var(--bg-overlay-soft); color: var(--text-dim); }

.inbox-row-body {
  padding: 14px 18px 16px 70px;
  border-top: 1px solid var(--border-default);
  background: var(--bg-overlay-soft);
}
.inbox-meta { display: flex; flex-wrap: wrap; gap: 18px; font-size: 12.5px; color: var(--text-dim); margin-bottom: 12px; }
.inbox-meta strong { color: var(--text-primary); font-weight: 500; }
.inbox-actions { display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }

/* ───── Channel chips (фильтры на /inbox) ───── */
.channel-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 18px; }
.ch-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius-pill);
  border: 1px solid var(--border-strong);
  background: transparent;
  color: var(--text-primary);
  text-decoration: none;
  font-size: 13px;
  font-weight: 500;
  transition: var(--theme-transition);
}
.ch-chip:hover { border-color: var(--accent-primary); color: var(--accent-primary); }
.ch-chip.is-active { background: var(--accent-primary); color: var(--text-on-accent); border-color: var(--accent-primary); }
.ch-chip-icon { font-size: 14px; opacity: 0.85; }

.tab.tab-urgent .tab-count { background: var(--status-danger); color: var(--text-on-accent); }
.tab.tab-urgent.is-active .tab-count { background: var(--status-danger); color: var(--text-on-accent); }

/* ───── Sources groups ───── */
.source-group { margin-bottom: 40px; }
.source-group-head { display: flex; align-items: center; gap: 14px; margin-bottom: 14px; padding-bottom: 14px; border-bottom: 1px solid var(--border-default); }
.source-group-head .ch-plate { width: 44px; height: 44px; font-size: 22px; }
.source-group-meta { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.source-group-title { font-size: 26px; margin: 0; line-height: 1; }
.source-group-count { font-size: 12px; color: var(--text-dim); letter-spacing: 0.08em; text-transform: uppercase; }

/* Большой info-card про АТС / другие пояснения групп */
.source-info-card {
  background: var(--accent-soft);
  border: 1px solid var(--accent-soft-border);
  border-radius: var(--radius-3xl);
  padding: 22px 26px;
  margin-bottom: 18px;
}
.info-card-head { display: flex; align-items: flex-start; gap: 16px; margin-bottom: 14px; }
.info-card-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-xl);
  background: var(--accent-primary);
  color: var(--text-on-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}
.info-card-title { font-size: 20px; margin: 0 0 4px; line-height: 1.2; }
.info-card-tag { font-size: 13px; color: var(--text-dim); margin: 0; }
.info-card-points { list-style: none; display: grid; grid-template-columns: 1fr 1fr; gap: 10px 22px; margin: 0; padding: 0; }
.info-card-points li {
  font-size: 13.5px;
  line-height: 1.5;
  color: var(--text-dim);
  padding-left: 18px;
  position: relative;
}
.info-card-points li::before {
  content: '';
  position: absolute;
  left: 0; top: 8px;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--accent-primary);
}
.info-card-points li strong { color: var(--text-primary); font-weight: 600; }
@media (max-width: 720px) {
  .info-card-points { grid-template-columns: 1fr; }
  .info-card-head { flex-direction: column; gap: 10px; }
}

/* Легенда типов интеграций для секции «Цифровые каналы» */
.source-types-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 12px 22px;
  padding: 14px 18px;
  margin-bottom: 18px;
  background: var(--bg-overlay-soft);
  border-radius: var(--radius-xl);
  border: 1px solid var(--border-default);
  font-size: 12.5px;
  color: var(--text-dim);
  line-height: 1.5;
}
.legend-item { display: inline-flex; align-items: flex-start; gap: 8px; max-width: 32%; min-width: 240px; flex: 1; }
.legend-item strong { color: var(--text-primary); font-weight: 600; }
.legend-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; margin-top: 6px; }
.dot-direct { background: var(--status-ok); }
.dot-aggregator { background: var(--status-warn); }
.dot-manual { background: var(--text-dim); }
@media (max-width: 720px) {
  .legend-item { max-width: 100%; }
}

/* (Дубликат удалён — основные правила .source-card / .source-stats / .source-notes — выше в SOURCES PAGE блоке) */

/* ───── Mobile adaptations для inbox ───── */
@media (max-width: 900px) {
  .inbox-row-head {
    grid-template-columns: 36px 1fr auto;
    grid-template-areas:
      "icon contact status"
      "icon preview visit"
      "icon time time";
    gap: 6px 12px;
    padding: 14px;
  }
  .inbox-row-head .ch-plate { grid-area: icon; }
  .inbox-time { grid-area: time; font-size: 11px; }
  .inbox-contact { grid-area: contact; font-weight: 500; }
  .inbox-preview { grid-area: preview; white-space: normal; text-overflow: clip; }
  .inbox-status { grid-area: status; }
  .inbox-visit-badge { grid-area: visit; justify-self: end; }
  .inbox-row-body { padding-left: 14px; }
  .inbox-actions { gap: 6px; }
  .inbox-widget { flex-direction: column; align-items: stretch; gap: 14px; }
  .iw-cta { text-align: right; }
}

/* ════════════════════════════════════════════════════════════════════════════
   MOBILE & TABLET ADAPTATIONS (добавлено в сессии #6)
   Не ломаем десктоп — все правила в @media и .table-wrap overflow-x.
   ════════════════════════════════════════════════════════════════════════════ */

/* Все таблицы скроллятся горизонтально на любом устройстве (а не обрезаются) */
.table-wrap { overflow-x: auto; -webkit-overflow-scrolling: touch; }
.table { min-width: 640px; }
.table-flat .table { min-width: 0; }
.table-wrap::-webkit-scrollbar { height: 6px; }
.table-wrap::-webkit-scrollbar-thumb { background: var(--border-strong); border-radius: var(--radius-pill); }

/* Топбар на планшете (≤960px) — nav в горизонтальный скролл, user-chip скрыт */
@media (max-width: 960px) {
  .topbar-inner { gap: 12px; }
  .nav {
    width: 100%;
    order: 3;
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    gap: 20px;
    padding-bottom: 4px;
    scrollbar-width: none;
  }
  .nav::-webkit-scrollbar { display: none; }
  .nav-item { flex-shrink: 0; white-space: nowrap; }
  .user-chip { display: none; }
}

/* Tabs (вкладки по статусу визитов) — горизонтальный скролл на узких экранах */
@media (max-width: 700px) {
  .tabs {
    flex-wrap: nowrap;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .tabs::-webkit-scrollbar { display: none; }
  .tab { white-space: nowrap; flex-shrink: 0; }
}

/* Info-list на iPad (≤900px) схлопывается в стек — было только ≤720 */
@media (max-width: 900px) {
  .info-list { grid-template-columns: 1fr; gap: 4px 0; }
  .info-list dt { color: var(--text-dim); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; margin-top: 8px; }
  .info-list dt:first-child { margin-top: 0; }
  .info-list.compact { grid-template-columns: 110px 1fr; gap: 6px 12px; }
  .info-list.compact dt { font-size: 12px; letter-spacing: normal; text-transform: none; margin-top: 0; }
}

/* Поиск, статус-кнопки, заголовки на мобиле */
@media (max-width: 600px) {
  .search-bar input[type=search] { min-width: 0; }
  .search-bar { gap: 8px; }
  .page-head { gap: 14px; padding-bottom: 16px; margin-bottom: 22px; }
  .page-title { font-size: 26px; }
  .stat-value { font-size: 36px; }
  .stat-card { padding: 18px; }
  .card { padding: 18px 20px; }
  .doc-buttons { grid-template-columns: 1fr; }
  .status-actions {
    overflow-x: auto;
    flex-wrap: nowrap;
    padding-bottom: 4px;
    scrollbar-width: none;
  }
  .status-actions::-webkit-scrollbar { display: none; }
  .status-actions > * { flex-shrink: 0; }
}

/* Карточка диалога — на мобиле боковая панель сверху */
@media (max-width: 700px) {
  .chat-wrap { grid-template-columns: 1fr; gap: 14px; }
  .chat-side { order: -1; }
  .chat-thread { padding: 16px; max-height: 65vh; }
  .msg { max-width: 92%; }
}

/* Modal — на мобиле почти fullscreen */
@media (max-width: 600px) {
  .modal { padding: 10px; }
  .modal-card { max-height: 95vh; border-radius: var(--radius-2xl); }
  .modal-head { padding: 14px 18px; }
  .modal-body { padding: 18px; }
  .doc-preview { padding: 24px 20px; min-height: 180px; }
  .doc-preview-stamp { font-size: 48px; }
}

/* Touch-устройства — увеличиваем кнопки и поля под палец (Apple HIG 44pt) */
@media (pointer: coarse) {
  .btn { min-height: 44px; padding: 12px 22px; }
  .btn-sm { min-height: 38px; padding: 10px 16px; }
  .btn-link { padding: 6px 0; min-height: 32px; display: inline-flex; align-items: center; }
  .tab { min-height: 44px; padding: 12px 16px; }
  .nav-item { min-height: 36px; padding: 8px 0; display: inline-flex; align-items: center; }
  .theme-toggle { width: 44px; height: 44px; }
  .switch { min-height: 34px; padding: 8px 14px; }
  .field input, .field select, .field textarea { min-height: 44px; padding: 12px 14px; font-size: 16px; /* 16px — чтобы iOS не зумил */ }
  .field textarea { min-height: 80px; }
  .search-bar input[type=search] { min-height: 44px; font-size: 16px; }
  .vehicle-actions .btn-link { padding: 10px 0; }
}

/* Login на мобильном — карточка занимает экран */
@media (max-width: 480px) {
  .login-card { padding: 32px 24px 28px; max-width: 100%; }
  .login-title { font-size: 26px; }
}
