/* Доп. стили приложения поверх iq-portal.css (общий знаковый стиль) */
/* подпись-версия внизу: мелко, тихо, по центру */
.app-foot{text-align:center;font-size:11px;line-height:1.5;color:var(--faint);
  font-weight:500;letter-spacing:.3px;padding:26px 14px 30px;
  font-variant-numeric:tabular-nums;user-select:none}
.app-foot b{font-weight:700;color:var(--muted);letter-spacing:.7px}
.app-foot .dot{margin:0 7px;opacity:.55}

.sb-foot{display:flex;flex-direction:column;gap:8px}
.sb-logout{font-size:11.5px;color:var(--muted);text-decoration:none;padding:2px 8px;font-weight:600}
.sb-logout:hover{color:var(--violet-ink)}
/* мобильный иконочный сайдбар: аватар и «Выйти» по центру */
@media (max-width:1024px){
  .sb-foot{align-items:center}
  .sb-logout{padding:2px 0;text-align:center}
}

.page-head{display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap;margin-bottom:16px}
.page-head h2{font-family:var(--font-display),sans-serif;font-weight:600;font-size:20px;color:var(--ink)}
.page-head .sub{font-size:12.5px;color:var(--muted);font-weight:500;margin-top:2px}
.toolbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap}

.card{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);padding:16px 18px;margin-bottom:14px}
.muted{color:var(--muted)}
.warn{color:#B0741E}
.right{margin-left:auto}

.tbl{width:100%;border-collapse:collapse;font-size:13px}
.tbl th{text-align:left;font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);font-weight:700;padding:8px 10px;border-bottom:1px solid var(--border)}
.tbl td{padding:8px 10px;border-bottom:1px solid var(--border-soft);color:var(--ink)}
.tbl tr:hover td{background:var(--bg-soft)}
.tbl .num{text-align:right;font-family:var(--font-mono),monospace;letter-spacing:-.3px}
.tbl .tot td{font-weight:700;background:#FCFCFD}
/* раскрытие смен по дням: скрыто, по клику на бариста (.line-head) добавляется .open */
.tbl tr.day-row{display:none}
.tbl tr.day-row.open{display:table-row}
.tbl tr.line-head .cell-name .muted{display:inline-block;transition:transform .15s}
.tbl tr.line-head.open .cell-name .muted{transform:rotate(180deg)}

.gdot.sm{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px;vertical-align:middle}
.pill{font-family:var(--font-mono);font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:6px;background:var(--violet-soft);color:var(--violet-ink)}
.pill.gray{background:var(--bg-soft);color:var(--muted)}
.pill.green{background:#E7F3DC;color:#4E7D24}
.pill.gold{background:#FBEFD0;color:#9A6E16}
.pill.red{background:#FBE3E3;color:#B0322C}
.tbl tr.warn-row td{background:#FFF7EC}
.tag{display:inline-block;font-size:9.5px;font-weight:800;padding:1px 6px;border-radius:5px;color:#fff}

input,select{font-family:var(--font-body);font-size:13.5px;color:var(--ink);background:var(--surface);border:1px solid var(--border);border-radius:9px;padding:8px 10px;outline:none}
input:focus,select:focus{border-color:var(--violet);box-shadow:0 0 0 3px var(--violet-soft)}
label.fld{display:flex;flex-direction:column;gap:5px;font-size:12px;font-weight:600;color:var(--ink-2)}

/* Плавающий переключатель стиля (theme-switch.js) убран из обеих вёрсток —
   стиль теперь выбирается в разделе «Настройки» (вход через аватар).
   Сам скрипт оставлен: он применяет сохранённую тему на загрузке (data-theme).
   Специфичность body #… (0,1,1) нужна, чтобы перебить inline display:flex из theme-switch.js. */
body #iq-theme-switch{display:none}

/* модалка */
#modal-root:empty{display:none}
.modal-bg{position:fixed;inset:0;background:rgba(20,20,40,.35);display:grid;place-items:center;z-index:50;padding:20px}
.modal{width:min(460px,94vw);background:var(--surface);border-radius:16px;border:1px solid var(--border);box-shadow:0 24px 60px -20px rgba(20,20,40,.4);padding:22px}
.modal h3{font-family:var(--font-display);font-weight:600;font-size:16px;margin-bottom:14px}
.modal .form{display:flex;flex-direction:column;gap:12px}
.modal .row{display:flex;gap:10px}
.modal .row>*{flex:1}
.modal .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:6px}
.btn-sm{padding:6px 12px;font-size:12px;border-radius:8px}
.btn-danger{background:#fff;border:1px solid #E8B4B4;color:#C0392B}
.btn-danger:hover{background:#FCEDED}
.linkbtn{background:none;border:none;color:var(--violet-ink);font-weight:600;font-size:12px;cursor:pointer;padding:2px 4px}
.iconbtn{background:none;border:none;color:var(--violet-ink);cursor:pointer;padding:5px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;line-height:0;transition:.12s}
.iconbtn:hover{background:var(--violet-soft)}
.tbl td.act{text-align:right;width:1%;white-space:nowrap}
.mnote{width:160px;max-width:100%;font-size:12px}
.ratebar{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;color:var(--ink-2);background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:9px;padding:8px 10px}

/* ── Настройки (раздел) ── */
.sb-set{display:flex;align-items:center;gap:9px;text-decoration:none;color:var(--ink-2);font-weight:600;font-size:12.5px;padding:7px 9px;border-radius:9px;transition:.14s}
.sb-set svg{width:16px;height:16px;stroke:var(--muted);flex:none}
.sb-set:hover{background:var(--bg-soft);color:var(--ink)}
.sb-set:hover svg{stroke:var(--ink-2)}

.set-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}
.set-card{margin-bottom:0}
.set-h{font-family:var(--font-display),sans-serif;font-weight:600;font-size:15px;color:var(--ink);margin-bottom:4px}
.set-sub{font-size:12px;color:var(--muted);margin:-2px 0 14px;line-height:1.5}
.set-field{display:flex;flex-direction:column;gap:5px;margin-bottom:13px}
.set-field>label{font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--faint);font-weight:700}
.set-field input{width:100%}
.set-ro{font-size:13.5px;color:var(--ink-2);font-weight:600;padding:8px 10px;background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:9px}
.set-actions{display:flex;justify-content:flex-end;margin-top:4px}
.set-foot{margin-top:16px;display:flex;justify-content:center}
.set-foot .btn{min-width:220px;justify-content:center}
.set-themes{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.set-theme{display:flex;align-items:center;gap:11px;text-align:left;cursor:pointer;background:var(--surface);border:1.5px solid var(--border);border-radius:13px;padding:10px 12px;transition:.14s}
.set-theme:hover{border-color:var(--violet)}
.set-theme.on{border-color:var(--violet);box-shadow:0 0 0 3px var(--violet-soft)}
.set-theme .st-txt{display:flex;flex-direction:column;gap:1px;min-width:0}
.set-theme .st-txt b{font-size:13px;color:var(--ink);font-weight:700}
.set-theme .st-txt span{font-size:11px;color:var(--muted)}
.st-prev{width:34px;height:34px;border-radius:9px;flex:none;border:1px solid var(--border);position:relative;overflow:hidden}
.st-prev::after{content:"";position:absolute;right:5px;bottom:5px;width:11px;height:11px;border-radius:50%;box-shadow:0 0 0 2px rgba(255,255,255,.12)}
.st-light{background:#ffffff}
.st-light::after{background:#6D5CE7}
.st-tochka1{background:#F1F0F6}
.st-tochka1::after{background:#7C5CFF}
.st-tochka2{background:#EBEBEB}
.st-tochka2::after{background:#7C5CFF}
.st-dark{background:#15151B}
.st-dark::after{background:#8B6CFF}

/* ── Меню подразделов «Настроек» ── */
.set-menu{display:flex;flex-direction:column;border:1px solid var(--border);border-radius:var(--r);background:var(--surface);overflow:hidden}
.set-row{display:flex;align-items:center;gap:12px;padding:15px 16px;text-decoration:none;border-bottom:1px solid var(--border-soft);transition:background .12s}
.set-row:last-child{border-bottom:none}
.set-row:hover{background:var(--bg-soft)}
.set-row-t{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.set-row-t b{font-size:14.5px;color:var(--ink);font-weight:600}
.set-row-t span{font-size:12px;color:var(--muted)}
.set-row-arr{flex:none;color:var(--faint);font-size:20px;line-height:1}
.set-back{display:inline-flex;align-items:center;gap:6px;text-decoration:none;color:var(--muted);font-weight:600;font-size:13px;margin-bottom:12px}
.set-back span{font-size:18px;line-height:1}
.set-back:hover{color:var(--ink)}

/* ── Экран «Ещё» (#more): сгруппированный список разделов ── */
.more-grp{margin-bottom:18px}
.more-grp:last-child{margin-bottom:0}
.more-lab{font-size:11px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);opacity:.7;padding:0 2px 7px}

/* ── Карточка-заглушка «раздел в разработке» ── */
.soon-card{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px;padding:34px 24px}
.soon-ic{color:var(--violet);opacity:.85}
.soon-ic svg{width:34px;height:34px}
.soon-card b{font-size:16px;color:var(--ink);font-weight:600;margin-top:2px}
.soon-d{font-size:13px;color:var(--ink-2);max-width:440px;line-height:1.55}
.soon-plan{font-size:11.5px;color:var(--faint);font-family:var(--font-mono),monospace;margin-top:4px}

/* ── Режим работы точек: одна карточка + переключатель ── */
.hm-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.hm-head .hm-hint{margin:0;min-width:0}
.hm-head .btn{flex:none}
.hm-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.hm-chip{display:inline-flex;align-items:center;gap:7px;padding:6px 12px;border:1px solid var(--border);
  border-radius:999px;background:transparent;color:var(--ink-2);font-weight:600;font-size:13px;cursor:pointer;
  font-family:inherit;line-height:1;white-space:nowrap;transition:border-color .12s,color .12s,background .12s}
.hm-chip:hover{border-color:var(--ink-3,var(--muted))}
.hm-chip.on{border-color:var(--ink);color:var(--ink);background:var(--accent-soft,rgba(0,0,0,.04))}
.hv-list{display:flex;flex-direction:column}
.hv-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:10px 2px;border-bottom:1px solid var(--border-soft)}
.hv-row:last-child{border-bottom:none}
.hv-d{font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);font-weight:700}
.hv-row.we .hv-d{color:var(--faint)}
.hv-row .hm-on,.hv-row .hm-off{font-family:var(--font-mono);font-size:14px}
.hm-on{color:var(--ink)}
.hm-off{color:var(--faint)}

/* премии */
.bn-scheme{display:flex;flex-direction:column;gap:16px;margin-bottom:14px}
.bn-tiers{width:100%}
.bn-tierlist{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:7px 12px}
.bn-tier{display:grid;grid-template-columns:max-content max-content;justify-content:center;
  align-items:baseline;column-gap:12px;font-family:var(--font-mono);font-size:13px;color:var(--ink-2)}
.bn-tier b{color:var(--ink);font-weight:700}
.bn-goals{display:flex;flex-wrap:wrap;gap:10px 28px}
.bn-goal{display:flex;align-items:baseline;gap:10px}
.bn-k{font-size:12px;color:var(--muted);min-width:78px}
.bn-v{font-family:var(--font-mono);font-weight:700;font-size:15px;color:var(--ink)}
.bn-list{display:flex;flex-direction:column;border-top:1px solid var(--border-soft)}
.bn-row{display:flex;align-items:flex-start;gap:12px;padding:11px 2px;border-bottom:1px solid var(--border-soft)}
.bn-row:last-child{border-bottom:none}
.bn-pt{display:flex;align-items:center;gap:7px;font-weight:600;color:var(--ink);flex:1 1 auto;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
/* жёсткая сетка: 3 колонки (метка · сумма · дата) ригидно выровнены по всем точкам, дата всегда внутри карточки */
.bn-col{display:grid;grid-template-columns:46px 78px 88px;column-gap:8px;row-gap:5px;align-items:baseline;flex:0 0 auto}
.bn-pair{display:contents}
.bn-lab{font-family:var(--font-display),sans-serif;font-size:10.5px;text-transform:uppercase;letter-spacing:.4px;color:var(--faint);font-weight:700}
.bn-val{text-align:right;font-family:var(--font-mono);font-size:13px;color:var(--ink-2);white-space:nowrap}
.bn-val b{color:var(--ink)}
.bn-date{text-align:left;font-family:var(--font-mono);font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden}
.bn-asof{margin-top:12px;color:var(--faint)}

/* тост */
#toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{background:#1B1B22;color:#fff;font-size:13px;font-weight:500;padding:10px 16px;border-radius:10px;box-shadow:0 10px 30px -10px rgba(0,0,0,.5);animation:tin .2s}
.toast.err{background:#C0392B}
.toast.ok{background:#2E7D32}
@keyframes tin{from{opacity:0;transform:translateY(8px)}to{opacity:1}}

/* ── СВОДКА (дашборд выручки) ── */
.sv-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:14px}
.sv-kpi{border:1px solid var(--border);border-radius:var(--r);background:var(--surface);padding:13px 15px}
.sv-kpi .k{font-size:10.5px;text-transform:uppercase;letter-spacing:.5px;color:var(--faint);font-weight:700;display:flex;align-items:center;gap:6px}
.sv-kpi .v{font-family:var(--font-mono);font-weight:600;font-size:clamp(15px,4.3vw,21px);color:var(--ink);margin-top:6px;letter-spacing:-.5px;white-space:nowrap}
.sv-kpi .v small{font-size:.62em;color:var(--muted);font-weight:400}
.sv-kpi.net{border-color:color-mix(in srgb,var(--violet) 35%,var(--border));background:color-mix(in srgb,var(--violet) 4%,var(--surface))}
.sv-kpi .cdot{width:9px;height:9px;border-radius:50%;flex:none}
.sv-delta{font-family:var(--font-mono);font-size:12px;font-weight:700}
.sv-delta.up{color:#2E7D32}.sv-delta.down{color:#C0392B}.sv-delta.flat{color:var(--muted)}
.sv-cols{display:grid;grid-template-columns:1.6fr 1fr;gap:14px}
@media(max-width:900px){.sv-cols{grid-template-columns:1fr}}
.sv-chart svg,.sv-donut svg{width:100%;height:auto;display:block}
.sv-donut svg{max-width:140px}
.sv-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:10px;font-size:11.5px;color:var(--ink-2)}
.sv-legend .it{display:flex;align-items:center;gap:6px}
.sv-legend .cdot{width:9px;height:9px;border-radius:50%;flex:none}
/* таблица точек: горизонтальный скролл на узких экранах вместо обрезки/переноса */
.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}
.tbl-wrap .tbl{min-width:520px}
.tbl-wrap .tbl th,.tbl-wrap .tbl td{white-space:nowrap}

.empty-cell{cursor:pointer;border-radius:7px;min-height:26px}
.empty-cell:hover{background:var(--violet-soft)}
.cell .t{cursor:pointer}
.loading{padding:40px;text-align:center;color:var(--muted)}

/* ── расписание: ячейки-кнопки, состав, пресеты ── */
.empty-cell{width:100%;border:none;background:transparent;cursor:pointer;border-radius:7px;height:30px;display:flex;align-items:center;justify-content:center}
.empty-cell:hover{background:var(--violet-soft);box-shadow:inset 0 0 0 1px var(--violet)}
.nm{position:relative}
.nm .rm{position:absolute;right:6px;top:50%;transform:translateY(-50%);border:none;background:transparent;color:var(--faint);font-size:16px;line-height:1;cursor:pointer;opacity:0;transition:.12s;padding:2px 4px;border-radius:6px}
.nm:hover .rm{opacity:1}
.nm .rm:hover{background:#FCEDED;color:#C0392B}
.loc .btn-sm{margin-left:auto}

.presets{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}
.preset{font-family:var(--font-mono);font-size:12.5px;font-weight:600;padding:7px 11px;border-radius:9px;border:1px solid var(--border);background:var(--bg-soft);color:var(--ink);cursor:pointer;transition:.12s}
.preset:hover{border-color:var(--violet);background:var(--violet-soft);color:var(--violet-ink)}
.modal h3 .sub{font-size:12px;color:var(--muted);font-weight:500}

.picklist{max-height:340px;overflow:auto;display:flex;flex-direction:column;gap:2px}
.pick{display:flex;align-items:center;gap:8px;width:100%;text-align:left;border:none;background:transparent;padding:9px 10px;border-radius:9px;cursor:pointer;font-size:13.5px;color:var(--ink)}
.pick:hover{background:var(--bg-soft)}
.pick .right{margin-left:auto}

/* ════════════════════════════════════════════════════════
   ⛔ КОНТРАКT ДВУХ ВЁРСТОК — НЕ НАРУШАТЬ (требование владельца 2026-05-31).
   У портала ВСЕГДА ровно ДВЕ раскладки, разделённые ОДНИМ брейкпоинтом — шириной 640px:
     • >640px  = КЛАССИЧЕСКАЯ (горизонтальная/десктоп/планшет/телефон-альбом):
                 боковой сайдбар слева + обычные таблицы. Это «классика на горизонтали».
     • ≤640px  = АДАПТИВНАЯ (мобильная, телефон вертикально):
                 нижняя таб-панель + карточки + верхний хедер .mtop.
   ЗАПРЕЩЕНО:
     — делать одну раскладку на все форматы;
     — добавлять в условие медиа что-либо кроме ширины (никаких orientation/max-height!).
       Ориентация/высота РОВНЯЛИ телефон-альбом под мобильную версию — это и есть «протёк адаптив
       в горизонталь». Горизонталь = ширина >640 = классика, ВСЕГДА.
   Если горизонталь «рассыпается» — причина в РАЗМЕТКЕ/специфичности, а не в брейкпоинте;
   чинить там, а не расширять медиа-условие.

   ВАЖНО про специфичность: префикс html[data-theme] (0,2,1) обязателен —
   тема theme-tochka.css задаёт [data-theme^="tochka"] .sidebar (0,2,0); без перебивания
   сайдбар остаётся вертикальным и активная вкладка растягивается.
   ════════════════════════════════════════════════════════ */
.mtop{display:none}
.sched-mobile{display:none}

/* ── Раздел «Агенты»: список-плитки → клик проваливает во внутренности ── */
.agent-list{display:grid;gap:14px;
  grid-template-columns:repeat(auto-fill,minmax(min(300px,100%),1fr))}
.agent-tile{display:block;text-decoration:none;color:inherit;cursor:pointer;
  transition:transform .12s ease,box-shadow .12s ease,border-color .12s ease}
.agent-tile:hover{transform:translateY(-2px);border-color:var(--violet);
  box-shadow:0 8px 24px rgba(20,20,26,.08)}
.at-top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.at-id{min-width:0}
.at-name{font-size:17px;margin:0}
.at-top .pill{flex:0 0 auto}
.at-foot{display:flex;flex-wrap:wrap;align-items:baseline;gap:4px 12px;margin-top:14px;font-size:12px}
.at-stat{min-width:0}
.ag-back{display:inline-block;margin-bottom:10px;font-size:13px;font-weight:600;
  color:var(--violet-ink);text-decoration:none}
.ag-back:hover{text-decoration:underline}

/* ── Зарплата: вкладки Расчёт/Ведомость ── */
.pt-tabs{display:flex;gap:6px;margin:-4px 0 14px}
.pt-tab{font-size:13px;font-weight:600;color:var(--muted);text-decoration:none;
  padding:7px 14px;border-radius:9px;border:1px solid transparent;transition:.12s}
.pt-tab:hover{color:var(--ink);background:var(--bg-soft)}
.pt-tab.on{color:var(--ink);background:var(--surface);border-color:var(--border);box-shadow:0 1px 2px rgba(20,20,40,.04)}

/* ── Ведомость: переключатели и итог «Надо» ── */
.ved-ctl{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:14px}
.seg{display:inline-flex;border:1px solid var(--border);border-radius:9px;overflow:hidden;background:var(--bg-soft)}
.seg-b{border:none;background:transparent;font-family:inherit;font-size:13px;font-weight:600;
  color:var(--muted);padding:8px 16px;cursor:pointer;transition:.12s}
.seg-b:hover{color:var(--ink)}
.seg-b.on{background:var(--surface);color:var(--ink);box-shadow:inset 0 0 0 1px var(--border)}
.ved-chk{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--ink-2);cursor:pointer}
.ved-chk input{width:16px;height:16px;padding:0;cursor:pointer}
.ved-neg{color:#B0322C}
.ved-pos{color:#4E7D24}
.ved-flag{color:#B0741E}
.tbl .ved-in{width:100%;max-width:120px;min-width:0;padding:5px 8px;font-size:13px;text-align:right;margin-left:auto;display:block}
.tbl .ved-comm{max-width:170px;text-align:left}
.ved-nado{display:flex;flex-direction:column;gap:8px;border-color:var(--violet);
  background:linear-gradient(180deg,var(--violet-soft),var(--surface))}
.vn-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px}
.vn-lab{font-size:11.5px;font-weight:700;letter-spacing:.6px;color:var(--violet-ink)}
.vn-sum{font-family:var(--font-mono),monospace;font-size:clamp(22px,5vw,30px);font-weight:700;color:var(--ink);letter-spacing:-.5px}
.vn-bills{font-family:var(--font-mono),monospace;font-size:13.5px;color:var(--ink-2);line-height:1.6}
.vn-note{font-size:11.5px}

/* Единственное условие — ширина. Никаких orientation/max-height (см. контракт выше). */
@media (max-width:640px){
  .bn-tierlist{grid-template-columns:repeat(2,minmax(0,1fr))}
  /* верхний хедер: бренд + Выйти */
  .mtop{display:flex;align-items:center;justify-content:space-between;gap:10px;
        position:sticky;top:0;z-index:45;background:var(--surface);
        border-bottom:1px solid var(--border);padding:9px 14px;
        padding-top:max(9px,env(safe-area-inset-top))}
  .mtop .mt-brand{display:flex;align-items:center;gap:8px;
        font-family:var(--font-brand),sans-serif;font-weight:600;font-size:15px;color:var(--ink);
        text-decoration:none;cursor:pointer;-webkit-tap-highlight-color:transparent}
  .mtop .mt-brand:active{opacity:.7}
  .mtop .mt-brand svg{height:26px;width:auto;display:block}
  .mtop .mt-actions{display:flex;align-items:center;gap:4px}
  .mtop .mt-ava{width:36px;height:36px;border-radius:50%;background:var(--violet-soft);
        color:var(--violet-ink);display:inline-flex;align-items:center;justify-content:center;
        font-weight:700;font-size:13.5px;line-height:1;text-transform:uppercase;flex:0 0 auto;user-select:none;
        cursor:pointer;-webkit-tap-highlight-color:transparent;transition:box-shadow .14s,transform .1s}
  .mtop .mt-ava:active{transform:scale(.94)}
  .mtop .mt-ava.on{box-shadow:0 0 0 2px var(--violet)}

  /* раздел «Настройки» в одну колонку */
  .set-grid{grid-template-columns:1fr;gap:12px}

  /* приложение в колонку. overflow-x:clip — фикс распирания вбок: нижняя панель
     (position:fixed left:0/right:0) при 7 вкладках имеет min-content шире экрана и
     растягивала ICB до ~520px (горизонтальный скролл). Клип рвёт эту петлю →
     панель садится в ширину экрана, вкладки сжимаются flex'ом. */
  html[data-theme] .app{flex-direction:column;min-height:auto;overflow-x:clip}

  /* сайдбар → фиксированная нижняя панель. Гасим темовые height/margin/radius. */
  html[data-theme] .sidebar{
    position:fixed;left:0;right:0;bottom:0;top:auto;width:auto;height:auto;min-height:0;
    margin:0;border-radius:0;align-self:auto;
    flex-direction:row;align-items:center;
    border-right:none;border-top:1px solid var(--border);
    box-shadow:0 -2px 14px -8px rgba(20,20,40,.25);
    padding:5px 4px;padding-bottom:max(5px,env(safe-area-inset-bottom));z-index:45}
  html[data-theme] .sb-brand,
  html[data-theme] .sb-foot{display:none}
  html[data-theme] .sb-nav{flex-direction:row;justify-content:space-around;align-items:center;width:100%;gap:1px;margin-top:0}
  /* группы «расплющиваются» в общий flex-ряд панели; подписи групп скрыты */
  html[data-theme] .sb-group{display:contents}
  html[data-theme] .sb-label{display:none}
  /* в нижней панели — только 4 главные вкладки (.mb): Сводка/Расписание/Зарплата/Ещё.
     Остальное (Бариста, Сеть, Отчёты, Агент) живёт на экране «Ещё» (#more). */
  html[data-theme] .sb-item{display:none}
  /* min-height на айтеме фиксирует высоту панели: иначе цепочка align-items:stretch
     (sidebar→nav→item) схлопывается в высоту паддинга (~11px) и панель исчезает. */
  html[data-theme] .sb-item.mb{flex:1;display:flex;flex-direction:column;justify-content:center;gap:3px;min-height:46px;
           padding:7px 1px;border-radius:11px;font-size:10px;min-width:0;white-space:normal}
  html[data-theme] .sb-item span{display:inline;font-size:9px;font-weight:600;line-height:1;letter-spacing:-.2px;
           white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  html[data-theme] .sb-item svg{width:21px;height:21px}

  /* контент во всю ширину + место под нижнюю панель. Гасим темовый padding/margin .wrap. */
  html[data-theme] .main{padding-bottom:62px}
  html[data-theme] .wrap{max-width:none;margin:0;padding:14px 13px 24px}

  /* ── page-head/toolbar: в колонку, кнопки на всю ширину ── */
  .page-head{flex-direction:column;align-items:stretch;gap:10px;margin-bottom:14px}
  .page-head h2{font-size:22px}
  .toolbar{width:100%;gap:8px}
  .toolbar .btn{flex:1 1 auto;min-height:44px;justify-content:center}
  .toolbar .weeknav{display:flex;width:100%;align-items:center;justify-content:space-between;gap:8px}
  .toolbar .weeknav button{min-width:44px;min-height:44px}
  .toolbar .weeknav .range{flex:1;text-align:center}

  /* ── ТАБЛИЦЫ → КАРТОЧКИ (Зарплата, Сводка) ──
     thead прячем, каждую строку делаем карточкой, ячейки — «подпись: значение».
     data-label берётся из атрибута td (см. app.js). */
  .tbl-wrap{overflow:visible;-webkit-overflow-scrolling:auto}
  .tbl-wrap .tbl{min-width:0}
  .tbl-wrap .tbl th,.tbl-wrap .tbl td{white-space:normal}
  .tbl{font-size:14px}
  .tbl thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
  .tbl,.tbl tbody{display:block;width:100%}
  .tbl tr{display:block;border:1px solid var(--border);border-radius:13px;
          background:var(--surface);padding:4px 13px;margin-bottom:10px}
  .tbl tr:hover td{background:transparent}
  .tbl tr.tot{background:var(--bg-soft);overflow:hidden}
  .tbl tr.tot td{background:transparent}
  .tbl tr.warn-row td{background:transparent}
  .tbl tr.warn-row{border-color:#F0C36D;background:#FFF7EC}
  .tbl td{display:flex;justify-content:space-between;align-items:center;gap:14px;
          padding:9px 0;border:none;border-bottom:1px solid var(--border-soft);text-align:right}
  .tbl td:last-child{border-bottom:none}
  .tbl td:empty{display:none}
  .tbl td::before{content:attr(data-label);text-align:left;flex:0 0 auto;
          font-size:11px;text-transform:uppercase;letter-spacing:.4px;color:var(--faint);font-weight:700}
  .tbl td.num{font-size:14px}
  /* строки «куда пишет модель/выводы»: длинный монопуть без дефисов не имеет точек
     переноса и уезжал за край карточки (.app{overflow-x:clip} прятал это от скролла).
     Раскладываем парой «метка сверху / путь снизу» и разрешаем перенос пути в любом месте. */
  .tbl td.path-key{display:block;text-align:left;border-bottom:none;padding-bottom:0}
  .tbl td.path-key::before{content:none}
  .tbl td.path-val{display:block;text-align:left;padding-top:2px;
          overflow-wrap:anywhere;word-break:break-all}
  .tbl td.path-val::before{content:none}
  .tbl td.cell-name{border-bottom:1px solid var(--border);font-size:16px;font-weight:700;
          justify-content:flex-start;padding:11px 0 9px}
  .tbl td.cell-name::before{content:none}
  .tbl td.cell-total{font-size:16px}
  .tbl td.cell-total::before{color:var(--violet-ink)}
  .tbl td input{width:100%;min-height:40px;font-size:14px}
  /* ── раскрытие смен по дням: тап по карточке бариста → мини-карточки дней ── */
  .tbl tr.day-row{display:none}
  .tbl tr.day-row.open{display:block;margin:-4px 0 10px;padding:4px 13px 6px;
        background:var(--bg-soft);border:1px solid var(--border-soft);border-radius:11px}
  .tbl tr.day-row td{font-size:13px;padding:7px 0}
  .tbl tr.day-row td.z{display:none}                 /* пустые премии (—) на мобиле не плодим */
  .tbl tr.day-row td.day-head{justify-content:flex-start;font-size:11px;font-weight:700;
        text-transform:uppercase;letter-spacing:.4px;color:var(--violet-ink);
        padding:4px 0 5px!important;border-bottom:1px solid var(--border-soft)}
  .tbl tr.day-row td.day-head::before{content:none}
  /* «▾» возвращаем — раскрытие снова есть; на line-head.open повернётся (базовое правило) */
  .tbl td.cell-name .muted{display:inline-block}

  /* ── РАСПИСАНИЕ: сетка 9 колонок → выбор дня + список по точкам ── */
  .board{display:none}
  .sched-mobile{display:block}
  .day-pills{display:flex;gap:6px;overflow-x:auto;padding-bottom:9px;margin-bottom:6px;-webkit-overflow-scrolling:touch}
  .day-pills .dp{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:1px;
        min-width:46px;min-height:52px;justify-content:center;border:1px solid var(--border);
        border-radius:12px;background:var(--surface);color:var(--muted);font-size:11px;font-weight:600;cursor:pointer;padding:6px 8px}
  .day-pills .dp b{font-size:16px;color:var(--ink);font-weight:700}
  .day-pills .dp.we{color:var(--faint)}
  .day-pills .dp.on{background:var(--violet);border-color:var(--violet);color:#fff}
  .day-pills .dp.on b{color:#fff}
  .dl-loc{margin-bottom:16px}
  .dl-lname{display:flex;align-items:center;gap:8px;font-weight:700;font-size:14.5px;color:var(--ink);
        padding:8px 2px;border-bottom:1px solid var(--border);margin-bottom:2px}
  .dl-lname .bar{width:4px;height:16px;border-radius:3px;background:var(--c)}
  .dl-lname .btn-sm{margin-left:auto}
  .dl-row{display:flex;align-items:center;justify-content:space-between;gap:12px;width:100%;
        min-height:48px;padding:8px 8px;border:none;border-bottom:1px solid var(--border-soft);
        background:transparent;cursor:pointer;text-align:left;font-size:14.5px;color:var(--ink)}
  .dl-row:last-child{border-bottom:none}
  .dl-row .dl-who{display:flex;align-items:center;gap:7px;font-weight:500}
  .dl-row .dl-time{font-family:var(--font-mono),monospace;font-weight:600;font-size:14px;color:var(--violet-ink);
        background:var(--violet-soft);padding:6px 11px;border-radius:9px;white-space:nowrap}
  .dl-row .dl-add{font-size:13px;color:var(--faint);font-weight:600;white-space:nowrap}
  .dl-empty{padding:10px 4px;font-size:13px}

  /* ── Фаза 4: плотность и тач-цели ──
     font-size:16px на полях ОБЯЗАТЕЛЕН — иначе Safari iOS зумит страницу при фокусе. */
  input,select{font-size:16px;min-height:44px;padding:10px 12px}
  input[type=time],input[type=date]{min-height:44px}
  .btn{min-height:42px;padding:10px 16px}
  .btn-sm{min-height:36px;padding:7px 12px;font-size:12.5px}
  .modal-bg{place-items:end center;padding:0}
  .modal{width:100%;max-width:none;border-radius:20px 20px 0 0;padding:20px 18px max(20px,env(safe-area-inset-bottom))}
  .modal h3{font-size:18px}
  .modal .row{flex-wrap:wrap}
  .modal .actions{margin-top:10px}
  .modal .actions .btn{flex:1}
  .preset{min-height:44px;font-size:14px;padding:9px 13px}
  .pick{min-height:48px;font-size:15px;padding:11px 10px}
  .picklist{max-height:60vh}
  /* панель действий ЗП: кнопка на всю ширину */
  #send,#pay,#resend{width:100%;justify-content:center}

  /* ── БАРИСТА: компактная карточка 2 строки (имя+ставка / грейд+«Изменить») ──
     перебиваем общий «столбик подписей» — у этой таблицы нет data-label. */
  .tbl-baristas tr{display:grid;grid-template-columns:1fr auto;column-gap:12px;row-gap:6px;
        grid-template-areas:"name rate" "grade edit";align-items:center;padding:12px 14px}
  .tbl-baristas tr:hover td{background:transparent}
  .tbl-baristas td{display:block;border:none;padding:0;text-align:left}
  .tbl-baristas td::before{content:none!important}
  .tbl-baristas td:nth-child(1){grid-area:name;font-weight:700;font-size:15.5px;display:flex;justify-content:flex-start;align-items:center;gap:8px}
  .tbl-baristas td:nth-child(2){grid-area:grade;font-size:12.5px;color:var(--muted);font-weight:500}
  .tbl-baristas td:nth-child(3){grid-area:rate;text-align:right;font-weight:700;font-size:15px;
        font-family:var(--font-mono),monospace;white-space:nowrap}
  .tbl-baristas td:nth-child(4){grid-area:edit;justify-self:end;width:auto}
  .tbl-baristas td.act .btn{min-height:34px;padding:6px 16px}
  .tbl-baristas tr.muted td:nth-child(1){color:var(--muted)}

  /* ── ТОЧКИ: режим работы — каждый день одной компактной строкой ──
     день | открытие – закрытие | вых. Перебиваем общий «столбик» (нет data-label):
     гасим карточку-на-строку (рамку/фон/отступ) → чистый список внутри одной карты. */
  .tbl-hours thead{display:none}
  /* minmax(0,1fr) + min-width:0 — КРИТИЧНО: иначе родная ширина time-инпутов
     распирает строку шире карточки и колонка «вых» вываливается за правый край.
     4-я колонка фиксирована (38px) и центрирована → «вых» всегда ВНУТРИ карты. */
  /* flex + space-between: поля времени УЗКИЕ и фиксированные (не тянутся 1fr),
     свободное место раздаётся равными промежутками — все элементы «воздушно» и ровно. */
  .tbl-hours tr{display:flex;align-items:center;justify-content:space-between;
        border:none;border-radius:0;background:transparent;padding:6px 2px;margin:0}
  .tbl-hours tr+tr{border-top:1px solid var(--border-soft)}
  .tbl-hours tr:hover td{background:transparent}
  .tbl-hours td{flex:0 0 auto;border:none!important;padding:0;text-align:left;min-width:0}
  .tbl-hours td::before{content:none!important}
  .tbl-hours td:nth-child(1){width:24px;font-weight:700;font-size:14px;color:var(--ink)}
  /* поле закрытия: тире-разделитель по центру перед инпутом */
  .tbl-hours td:nth-child(3){display:flex!important;align-items:center}
  .tbl-hours td:nth-child(3)::before{content:"–"!important;color:var(--muted);font-weight:600;margin-right:8px}
  .tbl-hours td:nth-child(2) input,.tbl-hours td:nth-child(3) input{width:64px;min-width:0;min-height:32px;
        font-size:14px;text-align:center;padding:2px;box-sizing:border-box}
  /* «вых»: чекбокс + подпись в строку, справа */
  .tbl-hours td:nth-child(4){display:flex}
  .tbl-hours td:nth-child(4) label{display:inline-flex;align-items:center;gap:4px;
        font-size:10px;line-height:1;color:var(--muted);white-space:nowrap}
  .tbl-hours td:nth-child(4) input[type=checkbox]{width:18px;height:18px;margin:0;flex:0 0 auto}
  .tbl-hours .t-full{display:none}
  .tbl-hours td:nth-child(4) label::after{content:"вых"}
  /* выходной: гасим пустые поля и тире, чтобы строка читалась как «не работаем» */
  .tbl-hours tr.off td:nth-child(2),.tbl-hours tr.off td:nth-child(3){opacity:.4}
  /* шапка карточки точки: глобальный mobile-page-head валит кнопку «Сохранить» во всю
     ширину/высоту (лишний ~77px). Возвращаем в строку, кнопка компактная справа. */
  .card .page-head:has(+ .tbl-hours){flex-direction:row;align-items:center;gap:8px;margin-bottom:8px}
  .card .page-head:has(+ .tbl-hours)>div:first-child{flex:1;min-width:0}
  .card .page-head:has(+ .tbl-hours) .btn{flex:0 0 auto;width:auto;min-height:34px;padding:6px 14px;font-size:13px}
}
