/* Onest — вариативный woff2, self-host (борд для РФ: без fonts.googleapis.com — ни деградации, ни утечки IP) */
@font-face{font-family:'Onest';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('/assets/fonts/onest-cyrillic.woff2') format('woff2');
  unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}
@font-face{font-family:'Onest';font-style:normal;font-weight:100 900;font-display:swap;
  src:url('/assets/fonts/onest-latin.woff2') format('woff2');
  unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+0304,U+0308,U+0329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}
:root{
  --canvas:#f2f5fa; --ink:#0f1b2d; --muted:#46546b; --soft:#5f7090;
  --accent:#0a6cff; --accent-strong:#0a5be0; --accent-ink:#0a5be0; --accent-soft:#e7f0ff;
  --on:#12b76a; --on-soft:#e7f7ef; --on-line:#bfe9d4; --on-ink:#0c7a4b;
  --off:#94a3b8; --off-soft:#eef1f6; --off-track:#cbd5e1; --off-track-line:#a9b7ca;
  --warn:#f5a524; --warn-soft:#fdf3e0; --warn-ink:#96621a;
  --line:#e4e9f2; --glass:rgba(255,255,255,.72); --glass-line:rgba(255,255,255,.9);
  --shadow:0 1px 2px rgba(16,40,80,.05), 0 10px 28px rgba(16,40,80,.07); --shadow-sm:0 4px 12px rgba(16,40,80,.05);
  /* типошкала: 8 ступеней (было 19 кеглей) */
  --fs-tag:11px; --fs-xs:12px; --fs-sm:13.5px; --fs-body:15.5px; --fs-md:17px;
  --fs-lg:20px; --fs-num-sm:26px; --fs-num:32px;
  --lh-num:1.1; --lh-num-sm:1.15; --lh-tight:1.3; --lh-text:1.5; --lh-body:1.55;
  --ls-eyebrow:.14em; --ls-caps:.08em;
  --r-xs:6px; --r-sm:9px; --r-md:12px; --r-lg:16px; --r-pill:999px;
  /* чипы режимов: тон 8–14%; чернила — токены борда (violet своего токена не имеет) */
  --chip-blue:rgba(10,108,255,.10); --chip-violet:rgba(124,58,237,.10); --chip-violet-ink:#6d28d9;
  --chip-amber:rgba(245,165,36,.14); --chip-green:rgba(18,183,106,.11);
}
*{box-sizing:border-box} html,body{margin:0}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-xs)}
.booting{padding:60px 0;color:var(--soft);text-align:center;font-size:var(--fs-sm);font-weight:600;letter-spacing:.04em}
body{font-family:'Onest',system-ui,sans-serif;color:var(--ink);font-size:var(--fs-body);line-height:var(--lh-body);
  background:radial-gradient(1200px 600px at 85% -10%,rgba(10,108,255,.06),transparent 60%),radial-gradient(900px 500px at 0% 110%,rgba(18,183,106,.05),transparent 55%),var(--canvas);
  min-height:100vh;-webkit-font-smoothing:antialiased}
.wrap{max-width:1320px;margin:0 auto;padding:30px 30px 60px}
.top{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:8px}
.brand{display:flex;align-items:center;gap:12px}
.brand__mark{flex:none;width:34px;height:34px;border-radius:var(--r-sm);background:linear-gradient(150deg,#0a6cff,#3b8bff);display:grid;place-items:center;box-shadow:0 6px 16px rgba(10,108,255,.32)}
.brand__mark svg{width:19px;height:19px;color:#fff}
.brand__t h1{margin:0;font-size:var(--fs-lg);font-weight:600;letter-spacing:-.01em;line-height:var(--lh-tight)}
.brand__t p{margin:1px 0 0;font-size:var(--fs-sm);color:var(--muted)}
.livedot{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-xs);color:var(--muted);white-space:nowrap;background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-pill);padding:6px 12px;box-shadow:var(--shadow-sm)}
.livedot i{flex:none;width:7px;height:7px;border-radius:50%;background:var(--on);box-shadow:0 0 0 4px var(--on-soft)}
/* правый край шапки: [имя · роль] · [обновлено] · [Выйти] — обоим вью */
.topbar{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
/* вкладки Борд|Статистика: на борде видит только РОП (клиент снимает hidden), на /stats — всегда */
.tabs{display:inline-flex;gap:4px;background:#eef2f8;border:1px solid var(--line);border-radius:var(--r-pill);padding:3px}
.tabs[hidden]{display:none} /* display:inline-flex перебивает UA-правило [hidden] — менеджер не должен видеть вкладку */
.tabs a{font-size:var(--fs-xs);font-weight:600;color:var(--muted);text-decoration:none;border-radius:var(--r-pill);padding:5px 13px;white-space:nowrap}
.tabs a.active{background:#fff;color:var(--accent);box-shadow:0 1px 3px rgba(16,40,80,.13)}
.tabs a:not(.active):hover{color:var(--ink)}
.usertag{font-size:var(--fs-xs);color:var(--muted);white-space:nowrap;background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--r-pill);padding:6px 12px;box-shadow:var(--shadow-sm)}
.usertag b{font-weight:600;color:var(--ink)}
.updated{font-size:var(--fs-xs);color:var(--soft);white-space:nowrap;font-variant-numeric:tabular-nums}
.updated.offline{color:var(--warn-ink);background:var(--warn-soft);border-radius:var(--r-pill);padding:3px 10px}
.logout{border:1px solid var(--line);background:var(--glass);color:var(--muted);font:inherit;font-size:var(--fs-xs);font-weight:600;border-radius:var(--r-pill);padding:6px 12px;cursor:pointer;box-shadow:var(--shadow-sm)}
.logout:hover{color:var(--ink);border-color:#cbd5e1}
.booting button{display:block;margin:14px auto 0;border:1px solid var(--line);background:#fff;color:var(--accent-ink);font:inherit;font-size:var(--fs-sm);font-weight:600;border-radius:var(--r-sm);padding:8px 18px;cursor:pointer}
.col-label{font-size:var(--fs-xs);font-weight:600;letter-spacing:var(--ls-eyebrow);text-transform:uppercase;color:var(--soft);margin:0 0 12px}
.glass{background:var(--glass);backdrop-filter:blur(14px) saturate(120%);-webkit-backdrop-filter:blur(14px) saturate(120%);border:1px solid var(--glass-line);border-radius:var(--r-lg);box-shadow:var(--shadow),inset 0 1px 0 rgba(255,255,255,.9)}
.mcard{padding:20px}
.mhead{display:flex;align-items:center;gap:13px}
.avatar{flex:none;width:46px;height:46px;border-radius:var(--r-md);background:#dbe6f7;display:grid;place-items:center;font-weight:600;color:#3667b8;font-size:var(--fs-md);border:1px solid #cdddf3}
.mhead h2{margin:0;font-size:var(--fs-md);font-weight:600}
.mhead p{margin:2px 0 0;font-size:var(--fs-sm);color:var(--muted)}
.tz{font-size:var(--fs-xs);color:var(--soft);display:inline-flex;gap:5px;align-items:center;margin-top:2px}
.shiftbox{margin-top:16px;border-radius:var(--r-md);padding:16px;border:1px solid var(--line);background:#f6f8fc;position:relative;overflow:hidden;transition:background .2s,border-color .2s}
.shiftbox.is-on{border-color:var(--on-line);background:linear-gradient(180deg,var(--on-soft),#f4fbf7)}
.shiftbox.is-on::after{content:"";position:absolute;inset:-40% -10% auto auto;width:200px;height:200px;background:radial-gradient(circle,rgba(18,183,106,.18),transparent 70%);pointer-events:none}
.shiftbox .st{display:flex;align-items:center;justify-content:space-between}
.shiftbox .lbl{font-size:var(--fs-sm);font-weight:600;color:var(--muted)}
.shiftbox.is-on .lbl{color:var(--on-ink)}
.shiftbox .sub{font-size:var(--fs-sm);color:var(--soft);margin-top:2px}
.shiftbox.is-on .sub{color:var(--on-ink)}
.toggle{flex:none;width:64px;height:34px;border-radius:var(--r-pill);background:var(--off-track);position:relative;cursor:pointer;box-shadow:inset 0 1px 3px rgba(0,0,0,.18);border:1px solid var(--off-track-line);transition:background .18s,border-color .18s}
.toggle.on{background:var(--on);border-color:#0ea45f}
.toggle span{position:absolute;top:2px;left:2px;width:28px;height:28px;border-radius:50%;background:#fff;box-shadow:0 2px 5px rgba(0,0,0,.2);transition:left .18s}
.toggle.on span{left:32px}
.big{font-size:var(--fs-num-sm);line-height:var(--lh-num-sm);font-weight:800;margin-top:14px;letter-spacing:-.02em}
.big em{font-style:normal;color:var(--accent)}
.mstat{display:flex;gap:12px;margin-top:16px}
.mstat .cell{flex:1;border:1px solid var(--line);border-radius:var(--r-md);padding:12px;background:rgba(255,255,255,.55)}
.mstat .n{font-size:var(--fs-num-sm);line-height:var(--lh-num-sm);font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.mstat .n--word{font-size:var(--fs-md);line-height:var(--lh-tight);font-weight:600;padding-top:6px}
.mstat .k{font-size:var(--fs-xs);color:var(--muted);margin-top:2px}
.strip{margin-top:16px}
.strip h3{margin:0 0 10px;font-size:var(--fs-xs);font-weight:600;letter-spacing:var(--ls-eyebrow);text-transform:uppercase;color:var(--soft)}
.track{position:relative;height:34px;border-radius:var(--r-sm);background:linear-gradient(90deg,#eaeef6 1px,transparent 1px) 0 0/20% 100% repeat-x,#f6f8fc;border:1px solid var(--line)}
.track .empty{position:absolute;inset:0;display:grid;place-items:center;font-size:var(--fs-xs);color:var(--soft)}
.seg{position:absolute;top:6px;height:22px;border-radius:var(--r-xs);background:linear-gradient(180deg,#37c98a,#12b76a);box-shadow:0 2px 6px rgba(18,183,106,.3)}
.ticks{position:relative;height:18px;margin-top:5px;font-size:var(--fs-xs);color:var(--soft);font-variant-numeric:tabular-nums}
.ticks span{position:absolute;top:0;transform:translateX(-50%)}
.ticks span:nth-child(1){left:0;transform:none}
.ticks span:nth-child(2){left:20%}
.ticks span:nth-child(3){left:40%}
.ticks span:nth-child(4){left:60%}
.ticks span:nth-child(5){left:80%}
.ticks span:nth-child(6){left:100%;transform:translateX(-100%)}
.tiles{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}
.tile{padding:16px}
.tile .k{font-size:var(--fs-xs);color:var(--muted);display:flex;align-items:center;gap:7px}
.tile .n{font-size:var(--fs-num);line-height:var(--lh-num);font-weight:800;letter-spacing:-.02em;margin-top:7px;font-variant-numeric:tabular-nums}
.tile .badge{font-size:var(--fs-xs);font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:var(--r-xs);padding:3px 8px;display:inline-block;margin-top:8px}
.tile .badge.warn{color:var(--warn-ink);background:var(--warn-soft)}
.tile .badge.ok{color:var(--on-ink);background:var(--on-soft)}
.modes{margin-top:24px;padding:20px}
.modes .mh{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:13px;gap:12px}
.modes .mh h3{margin:0;font-size:var(--fs-body);font-weight:600}
.modes .mh span{font-size:var(--fs-sm);color:var(--soft)}
/* режимы — карточки-витрина (мокап A): чип-иконка, название, суть; активная — рамка-акцент + чекмарка */
.mgrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}
.mode{position:relative;display:flex;flex-direction:column;align-items:flex-start;text-align:left;background:#fff;border:1px solid var(--line);border-radius:var(--r-md);padding:16px;font:inherit;color:inherit;cursor:pointer;transition:border-color .15s,box-shadow .15s,transform .15s}
.mode:hover{border-color:#c6d3e8;box-shadow:var(--shadow-sm)}
.mode:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.mode.is-active{border-color:var(--accent);box-shadow:0 2px 6px rgba(10,108,255,.10),0 12px 26px rgba(10,108,255,.13);transform:translateY(-2px)}
.mode.is-active:hover{border-color:var(--accent)}
.mcheck{position:absolute;top:12px;right:12px;width:22px;height:22px;border-radius:50%;background:var(--accent);display:grid;place-items:center;box-shadow:0 3px 8px rgba(10,108,255,.35)}
.mcheck svg{width:12px;height:12px;color:#fff}
.mchip{flex:none;width:40px;height:40px;border-radius:10px;display:grid;place-items:center;margin-bottom:12px}
.mchip svg{width:24px;height:24px}
.mchip--blue{background:var(--chip-blue);color:var(--accent-ink)}
.mchip--violet{background:var(--chip-violet);color:var(--chip-violet-ink)}
.mchip--amber{background:var(--chip-amber);color:var(--warn-ink)}
.mchip--green{background:var(--chip-green);color:var(--on-ink)}
.mode .t{font-size:var(--fs-body);font-weight:600;line-height:var(--lh-tight)}
.mode .s{font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text);margin-top:4px}
.mode .foot{font-size:var(--fs-xs);color:var(--soft);line-height:var(--lh-text);margin-top:auto;padding-top:10px}
.mode .tag{display:inline-block;vertical-align:2px;margin-left:7px;font-size:var(--fs-tag);font-weight:600;letter-spacing:.03em;background:var(--warn-soft);color:var(--warn-ink);border-radius:var(--r-xs);padding:1px 6px}
/* «скоро»: выключенная плитка — контент глушим, бейдж оставляем читаемым */
.mode.is-soon{cursor:not-allowed;background:#f8fafc}
.mode.is-soon:hover{border-color:var(--line);box-shadow:none}
.mode.is-soon .mchip{background:rgba(18,183,106,.07);color:#7ba896}
.mode.is-soon .t{color:var(--soft)}
.mode.is-soon .s,.mode.is-soon .foot{color:#93a2b8}
/* «Как работает · режим» под рядом карточек */
.how{margin-top:14px;background:#f6f8fc;border:1px solid var(--line);border-radius:var(--r-md);padding:14px 16px}
.how h4{margin:0 0 7px;font-size:var(--fs-xs);font-weight:600;letter-spacing:var(--ls-eyebrow);text-transform:uppercase;color:var(--soft)}
.how p{margin:0;font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text)}
.how p+p{margin-top:4px}
.how b{color:var(--ink);font-weight:600}
.shadowfoot{margin-top:16px;font-size:var(--fs-sm);color:var(--accent-ink);display:flex;gap:9px;align-items:flex-start;background:var(--accent-soft);border-radius:var(--r-sm);padding:10px 12px;line-height:var(--lh-text)}
.shadowfoot svg{flex:none;margin-top:2px}
.panel{padding:20px 20px 14px}
.panel h3{margin:0 0 4px;font-size:var(--fs-body);font-weight:600}
.panel .cap{font-size:var(--fs-sm);color:var(--muted);margin:0 0 12px}
.tblwrap{overflow-x:auto;min-width:0}
table{width:100%;border-collapse:collapse}
th{font-size:var(--fs-xs);font-weight:600;letter-spacing:var(--ls-caps);text-transform:uppercase;color:var(--soft);text-align:left;padding:0 10px 10px}
th.num{text-align:right}
td{padding:11px 10px;border-top:1px solid var(--line);font-size:var(--fs-sm);vertical-align:middle}
td:first-child{min-width:188px}
.who{display:flex;align-items:center;gap:11px;min-width:0}
.who .av{flex:none;width:32px;height:32px;border-radius:var(--r-sm);background:#dbe6f7;display:grid;place-items:center;font-weight:600;color:#3667b8;font-size:var(--fs-sm);border:1px solid #cdddf3}
.who .av--slot{background:#eceff4;color:#5f7090;border-color:#e0e5ee}
.who b{font-weight:600;font-size:var(--fs-body);white-space:nowrap}
.who small{display:block;color:var(--soft);font-size:var(--fs-xs);white-space:nowrap}
.chip{display:inline-flex;align-items:center;gap:6px;font-size:var(--fs-xs);font-weight:600;border-radius:var(--r-pill);padding:4px 11px;white-space:nowrap;font-variant-numeric:tabular-nums}
.chip.on{color:var(--on-ink);background:var(--on-soft);border:1px solid var(--on-line)}
.chip.off{color:#5b6b82;background:var(--off-soft);border:1px solid var(--line)}
.chip i{flex:none;width:6px;height:6px;border-radius:50%;background:currentColor}
.num{font-variant-numeric:tabular-nums;font-weight:600;text-align:right}
.num.muted{color:var(--soft)}
.forc{text-align:right}
.mini-toggle{flex:none;width:44px;height:24px;border-radius:var(--r-pill);position:relative;border:1px solid transparent;cursor:pointer;display:inline-block}
.mini-toggle::before{content:"";position:absolute;inset:-11px -8px;border-radius:var(--r-pill)}
.mini-toggle.on{background:var(--on);border-color:#0ea45f}.mini-toggle.off{background:var(--off-track);border-color:var(--off-track-line)}
.mini-toggle span{position:absolute;top:2px;width:18px;height:18px;border-radius:50%;background:#fff;box-shadow:0 1px 3px rgba(0,0,0,.25);transition:left .18s}
.mini-toggle.on span{left:22px}.mini-toggle.off span{left:2px}
.ropwrap{display:flex;flex-direction:column;gap:16px;margin-top:24px}
.col-label--top{margin-top:24px}
.tl{padding:20px;display:flex;flex-direction:column}
.tl h3{margin:0 0 15px;font-size:var(--fs-body);font-weight:600}
/* полоска активности: имя слева, трек справа, общая ось 06–21 под рядом (тот же язык, что .track менеджера) */
.tl .trows{display:flex;flex-direction:column;gap:12px}
.trow{display:grid;grid-template-columns:180px minmax(0,1fr);gap:14px;align-items:center}
.trow .tname b{display:block;font-size:var(--fs-sm);font-weight:600;line-height:var(--lh-tight);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.trow .tname small{font-size:var(--fs-xs);color:var(--soft);font-variant-numeric:tabular-nums}
.trow--axis{align-items:start}
.trow--axis .ticks{margin-top:0}
.offrow{margin-top:2px;font-size:var(--fs-sm);color:var(--soft)}
.tl .legend{display:flex;gap:14px;margin-top:16px;padding-top:12px;border-top:1px solid var(--line);font-size:var(--fs-xs);color:var(--muted)}
.tl .legend i{display:inline-block;width:10px;height:10px;border-radius:3px;vertical-align:-1px;margin-right:5px}
.tl .legend .sw-on{background:#12b76a}
.tl .legend .sw-off{background:#eef2f8;border:1px solid #e4e9f2}
/* менеджерский борд — карточка смены слева, панели-объяснялки справа */
.mgr-grid{display:grid;grid-template-columns:470px minmax(0,1fr);gap:22px;margin-top:22px;align-items:start}
.mgr-rail{display:grid;grid-template-columns:1fr;gap:16px;align-content:start}
.mgr-panel{padding:20px}
.mgr-cap{font-size:var(--fs-xs);font-weight:600;letter-spacing:var(--ls-eyebrow);text-transform:uppercase;color:var(--soft);margin:0 0 12px}
.mode-row{display:flex;align-items:center;gap:10px}
.mchip--sm{width:30px;height:30px;border-radius:8px;margin-bottom:0}
.mchip--sm svg{width:18px;height:18px}
.mode-chip{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-sm);font-weight:600;color:var(--accent-ink);background:var(--accent-soft);border-radius:var(--r-pill);padding:5px 12px}
.mode-chip i{width:7px;height:7px;border-radius:50%;background:currentColor}
.mode-say{font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text);margin:12px 0 0}
.mode-say b{color:var(--ink);font-weight:600}
.pace-n{font-size:var(--fs-num-sm);line-height:var(--lh-num-sm);font-weight:800;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.pace-n small{font-size:var(--fs-body);font-weight:600;color:var(--soft)}
.pace-bar{position:relative;height:10px;border-radius:var(--r-xs);background:#eef2f8;border:1px solid var(--line);margin:12px 0 8px;overflow:hidden}
.pace-bar__fill{position:absolute;inset:0 auto 0 0;background:linear-gradient(90deg,#7fb0ff,var(--accent));border-radius:var(--r-xs);min-width:3px}
.pace-hint{font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text)}
.shift-until{font-size:var(--fs-num-sm);line-height:var(--lh-num-sm);font-weight:800;letter-spacing:-.02em;margin-top:2px;font-variant-numeric:tabular-nums}
.shift-until.is-off{color:var(--soft)}
.shift-meta{font-size:var(--fs-sm);color:var(--muted);margin-top:6px;line-height:var(--lh-text);font-variant-numeric:tabular-nums}
.mgr-how{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:11px}
.mgr-how li{display:flex;gap:10px;font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text)}
.mgr-how svg{flex:none;margin-top:2px;color:var(--accent)}
.mgr-note{margin-top:16px;font-size:var(--fs-sm);color:var(--accent-ink);display:flex;gap:9px;align-items:flex-start;background:var(--accent-soft);border-radius:var(--r-sm);padding:10px 12px;line-height:var(--lh-text)}
.mgr-note svg{flex:none;margin-top:2px}
/* login */
.login{min-height:100vh;display:grid;place-items:center;padding:20px}
.login .card{width:100%;max-width:360px;padding:24px}
.login .brand__mark{margin-bottom:14px}
.login h1{margin:0 0 4px;font-size:var(--fs-lg);font-weight:600}
.login p{margin:0 0 20px;font-size:var(--fs-sm);color:var(--muted)}
.login label{display:block;font-size:var(--fs-xs);font-weight:600;color:var(--muted);margin:0 0 6px}
.login input{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:var(--r-md);font:inherit;font-size:var(--fs-body);margin-bottom:12px;background:#fff}
.login input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.login button{width:100%;padding:12px;border:none;border-radius:var(--r-md);background:var(--accent);color:#fff;font:inherit;font-size:var(--fs-body);font-weight:600;cursor:pointer}
.login button:hover{background:var(--accent-strong)}
.login .err{color:#c02626;font-size:var(--fs-sm);margin:0 0 10px;min-height:18px}
/* дыра адаптива 821–1100: фикс-колонка 470 душила рейл */
@media (max-width:1100px) and (min-width:821px){
  .mgr-grid{grid-template-columns:400px minmax(0,1fr)}
}
@media (max-width:820px){
  .wrap{padding:18px 15px 44px}
  .top{flex-direction:column;align-items:flex-start;gap:10px}
  .brand__t h1{font-size:var(--fs-md)}
  .mgr-grid{grid-template-columns:minmax(0,1fr);gap:16px;margin-top:16px}
  .mgr-rail{gap:16px}
  .tiles{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
  .tile{padding:12px}
  .tile .n{font-size:var(--fs-num-sm)}
  .tile .badge{display:none} /* «пул: …» не влезает в плитку 1/3 — сигнальные оставляем */
  .tile .badge.warn,.tile .badge.ok{display:inline-block}
  .modes{padding:16px}
  .modes .mh{flex-direction:column;align-items:flex-start;gap:3px}
  /* карточки режимов 2×2; .mgrid-скоуп, чтобы не задеть малый чип менеджера (.mchip--sm) */
  .mgrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
  .mode{padding:13px}
  .mgrid .mchip{width:36px;height:36px;margin-bottom:10px}
  .mgrid .mchip svg{width:22px;height:22px}
  .mcheck{top:10px;right:10px}
  .big{font-size:var(--fs-lg)}
  .trow{grid-template-columns:96px minmax(0,1fr);gap:10px}
  /* таблица должна ВМЕСТИТЬ «Сегодня» без скролла: аватар и время чипа — под нож */
  .panel{padding:16px 12px 10px}
  td:first-child{min-width:0}
  .who .av{display:none}
  .who small{display:none}
  th{padding:0 5px 10px} td{padding:11px 5px}
  .chip{padding:4px 9px;gap:5px;font-size:var(--fs-xs)}
  .chip .t{display:none}
  /* прячем «Открыто», «Пояс» и чип «Статус» (его дублирует тумблер) — «Сегодня» (ключевая цифра) остаётся */
  .col-open,.col-tz,.col-status{display:none}
  .login input{font-size:16px} /* iOS: <16px в инпуте вызывает автозум */
}

/* ── привязка Telegram: кнопка в шапке + модалка с одноразовым кодом ── */
.tgbtn{display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:var(--glass);color:var(--muted);font:inherit;font-size:var(--fs-xs);font-weight:600;border-radius:var(--r-pill);padding:6px 12px;cursor:pointer;box-shadow:var(--shadow-sm)}
.tgbtn:hover{color:var(--accent-ink);border-color:#b9cdf1}
.tgm-back{position:fixed;inset:0;background:rgba(16,32,56,.38);display:grid;place-items:center;padding:20px;z-index:50}
.tgm{width:min(400px,100%);padding:22px;background:#fff}
.tgm h3{margin:0 0 8px;font-size:var(--fs-md);font-weight:600}
.tgm p{margin:0 0 6px;font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text)}
.tgm-code{font-size:var(--fs-num);line-height:var(--lh-num);font-weight:800;letter-spacing:.14em;font-variant-numeric:tabular-nums;text-align:center;background:var(--accent-soft);color:var(--accent-ink);border-radius:var(--r-md);padding:14px 6px;margin:12px 0;user-select:all}
.tgm-link{display:block;text-align:center;background:var(--accent);color:#fff;text-decoration:none;font-weight:600;font-size:var(--fs-body);border-radius:var(--r-sm);padding:11px 16px;margin:12px 0 4px}
.tgm-link:hover{background:var(--accent-strong)}
button.tgm-link{border:none;cursor:pointer;width:100%;font:inherit;font-size:var(--fs-body);font-weight:600}
.tgm-note{font-size:var(--fs-xs);color:var(--soft);text-align:center;margin-top:8px}
.tgm-close{display:block;margin:14px auto 0;border:1px solid var(--line);background:#fff;color:var(--muted);font:inherit;font-size:var(--fs-xs);font-weight:600;border-radius:var(--r-pill);padding:7px 16px;cursor:pointer}
.tgm-close:hover{color:var(--ink);border-color:#cbd5e1}

/* ── Веха 4.6: команда — карточки менеджеров, добавление, архив ── */
.backlink{font-size:var(--fs-xs);font-weight:600;color:var(--accent-ink);text-decoration:none;border:1px solid var(--line);background:var(--glass);border-radius:var(--r-pill);padding:6px 12px;box-shadow:var(--shadow-sm);white-space:nowrap}
.backlink:hover{border-color:#b9cdf1}
/* формы-примитивы: настройки в карточке + модалка «Добавить менеджера» */
.fl{display:block;font-size:var(--fs-xs);font-weight:600;color:var(--muted);text-align:left}
.fl input,.fl select{display:block;width:100%;margin-top:6px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r-sm);font:inherit;font-size:var(--fs-body);background:#fff;color:var(--ink)}
.fl input:focus,.fl select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.fhint{display:block;margin-top:5px;font-size:var(--fs-xs);font-weight:500;color:var(--soft);line-height:var(--lh-text)}
.fsave{align-self:flex-start;border:none;border-radius:var(--r-sm);background:var(--accent);color:#fff;font:inherit;font-size:var(--fs-sm);font-weight:600;padding:10px 22px;cursor:pointer}
.fsave:hover{background:var(--accent-strong)}
.ferr{min-height:18px;margin:8px 0 0;font-size:var(--fs-sm);color:#c02626;line-height:var(--lh-text);text-align:left}
/* тост (Сохранено / ошибки API) */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:60;font-size:var(--fs-sm);font-weight:600;color:var(--on-ink);background:var(--on-soft);border:1px solid var(--on-line);border-radius:var(--r-pill);padding:10px 20px;box-shadow:var(--shadow);max-width:min(560px,calc(100vw - 30px))}
.toast--err{color:#a11f1f;background:#fdecec;border-color:#f3c2c2}
/* шапка панели «Команда сейчас» с кнопками сверки и добавления */
.phead{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.phead-actions{flex:none;display:flex;gap:8px;flex-wrap:wrap}
.addbtn{flex:none;display:inline-flex;align-items:center;gap:6px;border:1px solid var(--line);background:#fff;color:var(--accent-ink);font:inherit;font-size:var(--fs-xs);font-weight:600;border-radius:var(--r-pill);padding:7px 14px;cursor:pointer;box-shadow:var(--shadow-sm)}
.addbtn:hover{border-color:#b9cdf1;background:var(--accent-soft)}
.addbtn:disabled{opacity:.55;cursor:default}
/* имя в таблице — ссылка на карточку */
a.who{text-decoration:none;color:inherit;border-radius:var(--r-sm);margin:-4px;padding:4px}
a.who:hover{background:var(--accent-soft)}
a.who:hover b{color:var(--accent-ink)}
/* модалка добавления пошире формы */
.tgm--form{width:min(440px,100%)}
.tgm--form form{display:flex;flex-direction:column;gap:11px;margin-top:6px}
/* архив под таблицей */
.arch{margin-top:12px;border-top:1px solid var(--line);padding-top:10px}
.arch-t{display:inline-flex;align-items:center;gap:7px;border:none;background:transparent;font:inherit;font-size:var(--fs-sm);font-weight:600;color:var(--soft);cursor:pointer;padding:4px 2px}
.arch-t:hover{color:var(--ink)}
.arch-t .chev{transition:transform .15s}
.arch-t[aria-expanded="true"] .chev{transform:rotate(90deg)}
.arch-list{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.arch-list[hidden]{display:none} /* display:flex перебивает UA-правило [hidden] — свёрнутый архив должен быть скрыт */
.arch-row{display:flex;align-items:center;gap:12px;padding:7px 2px;font-size:var(--fs-sm)}
.arch-name{font-weight:600;color:var(--muted);text-decoration:none}
.arch-name:hover{color:var(--accent-ink)}
.arch-id{font-size:var(--fs-xs);color:var(--soft);font-variant-numeric:tabular-nums}
.arch-back{margin-left:auto;border:1px solid var(--line);background:#fff;color:var(--on-ink);font:inherit;font-size:var(--fs-tag);font-weight:600;border-radius:var(--r-pill);padding:5px 12px;cursor:pointer}
.arch-back:hover{border-color:var(--on)}
@media (max-width:820px){
  .fl input,.fl select{font-size:16px} /* iOS: <16px в инпуте вызывает автозум */
  .phead{flex-direction:column;align-items:stretch}
  .phead-actions{flex-direction:column}
  .addbtn{justify-content:center}
}

/* ── Веха 5: рубильник живой раздачи — плашка «Раздача» над «Режимом раздачи» ── */
.dispatch{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:16px 20px;margin-bottom:22px;flex-wrap:wrap}
.dispatch__main{min-width:min(340px,100%)}
.dispatch__state{display:flex;align-items:center;gap:9px;font-size:var(--fs-md);font-weight:600;color:var(--ink)}
.dispatch__state svg{flex:none;color:var(--soft)}
.dispatch__sub{margin:4px 0 0;font-size:var(--fs-sm);color:var(--muted);line-height:var(--lh-text)}
/* live — акцентная, заметная: янтарная рамка+свечение, «⚡ раздаём мы» */
.dispatch--live{border-color:#f2cf8d;box-shadow:0 0 0 3px var(--warn-soft),var(--shadow),inset 0 1px 0 rgba(255,255,255,.9);background:linear-gradient(120deg,rgba(245,165,36,.10),rgba(255,255,255,.72) 55%)}
.dispatch--live .dispatch__state{color:var(--warn-ink)}
.dispatch--live .dispatch__state svg{color:var(--warn)}
.dispatch__act{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.dispatch__btn{border:none;border-radius:var(--r-sm);background:var(--accent);color:#fff;font:inherit;font-size:var(--fs-sm);font-weight:600;padding:10px 18px;cursor:pointer;box-shadow:var(--shadow-sm)}
.dispatch__btn:hover{background:var(--accent-strong)}
.dispatch__btn:disabled{background:#c7d2e4;cursor:not-allowed;box-shadow:none}
.dispatch__btn--off{background:#fff;color:var(--muted);border:1px solid var(--line)}
.dispatch__btn--off:hover{background:#fff;color:var(--ink);border-color:#cbd5e1}
.dispatch__lock{font-size:var(--fs-xs);color:var(--soft)}
/* модалка подтверждения: чекбокс-чеклист + предупреждение о пустой смене */
.dispatch__check{display:flex;gap:9px;align-items:flex-start;font-size:var(--fs-sm);font-weight:500;color:var(--ink);margin:12px 0 4px;line-height:var(--lh-text);cursor:pointer;text-align:left}
.dispatch__check input{flex:none;width:16px;height:16px;margin-top:2px;accent-color:var(--accent);cursor:pointer}
.tgm p.dispatch__warn{background:var(--warn-soft);color:var(--warn-ink);border:1px solid #f2d9a6;border-radius:var(--r-sm);padding:9px 12px;margin-top:10px}
button.tgm-link:disabled{background:#c7d2e4;cursor:not-allowed}
/* шапочная плашка при live — «раздаём мы», янтарная */
.livedot--live{background:var(--warn-soft);border-color:#f2d9a6;color:var(--warn-ink);font-weight:600}
.livedot--live i{background:var(--warn);box-shadow:0 0 0 4px rgba(245,165,36,.18)}
@media (max-width:820px){
  .dispatch{flex-direction:column;align-items:stretch}
  .dispatch__act{align-items:stretch;text-align:center}
}
