/* Rino Dashboard — тема (CR-065). База — макет «Rino — Панель управления». */
:root{
  --black:#0A0A0A; --ink:#0E0E0E; --panel:#141414; --panel-2:#181818; --panel-3:#1E1E1E;
  --line:#262626; --line-2:#2F2F2F;
  --txt:#FFFFFF; --txt-2:#9A9A9A; --txt-3:#6A6A6A; --txt-4:#525252;
  --accent:#FEBE03; --accent-dim:#3A2E05;
  --ok:#7CC796; --ok-dim:#16261C; --danger:#E5675A;
  --font:"Work Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
  --display:"Oswald","Work Sans",sans-serif;
  --sidebar-w:280px;
  /* CR-136: алиасы для inline-стилей разделов (sections/*.js используют var(--border)/
     var(--muted-foreground), но они НЕ были объявлены → карточки канбана/обзора/метрик
     рендерились без рамки и с невидимым подтекстом). Привязываем к существующей палитре. */
  --border:var(--line-2); --muted-foreground:var(--txt-3); --radius:8px;
}
*{ box-sizing:border-box; }
html,body{ margin:0; padding:0; background:var(--black); color:var(--txt); font-family:var(--font); -webkit-font-smoothing:antialiased; }
a{ color:inherit; }
::selection{ background:var(--accent); color:#000; }
::-webkit-scrollbar{ width:10px; height:10px; }
::-webkit-scrollbar-track{ background:transparent; }
::-webkit-scrollbar-thumb{ background:#262626; }
::-webkit-scrollbar-thumb:hover{ background:#333; }
.hidden{ display:none !important; }

.app{ display:flex; min-height:100vh; }

/* ================= SIDEBAR ================= */
.sidebar{ width:var(--sidebar-w); flex:0 0 var(--sidebar-w); background:var(--ink); border-right:1px solid var(--line); display:flex; flex-direction:column; position:sticky; top:0; height:100vh; overflow:hidden; }
.brand{ display:flex; align-items:flex-start; justify-content:space-between; padding:26px 24px 22px; border-bottom:1px solid var(--line); }
.brand .mark{ font-family:var(--display); font-weight:700; font-size:30px; letter-spacing:0.02em; line-height:.9; text-transform:lowercase; }
.brand .mark .dot{ color:var(--accent); }
.brand .sub{ display:block; font-size:9px; letter-spacing:0.34em; text-transform:uppercase; color:var(--txt-3); margin-top:8px; font-weight:600; }

.nav{ flex:1; overflow-y:auto; padding:14px 14px 8px; display:flex; flex-direction:column; gap:1px; }
.nav-item{ display:flex; align-items:center; gap:14px; padding:11px 12px; color:var(--txt-2); font-size:13.5px; font-weight:500; letter-spacing:0.06em; text-transform:uppercase; cursor:pointer; border-left:2px solid transparent; transition:background .14s, color .14s, border-color .14s; white-space:nowrap; user-select:none; }
.nav-item svg{ width:18px; height:18px; flex:0 0 18px; stroke-width:1.6; }
.nav-item:hover{ color:var(--txt); background:#161616; }
.nav-item.active{ color:var(--txt); background:#171717; border-left-color:var(--accent); }
.nav-item.active svg{ color:var(--accent); }

.sys{ border-top:1px solid var(--line); padding:16px 22px 14px; display:flex; flex-direction:column; gap:11px; background:#0C0C0C; }
.sys-head{ font-size:11px; letter-spacing:0.2em; text-transform:uppercase; color:var(--txt-4); font-weight:600; }
.sys-row{ display:flex; align-items:center; justify-content:space-between; font-size:12.5px; color:var(--txt-2); }
.sys-row .v{ color:var(--txt); font-variant-numeric:tabular-nums; }
.sys-row .dot{ display:inline-flex; align-items:center; gap:7px; }
.sys-row .dot::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--txt-3); box-shadow:0 0 0 3px rgba(150,150,150,.12); }
.sys-row.ok .dot::before{ background:var(--ok); box-shadow:0 0 0 3px rgba(124,199,150,.14); }
.sys-row.bad .dot::before{ background:var(--danger); box-shadow:0 0 0 3px rgba(229,103,90,.14); }

.acct{ display:flex; align-items:center; justify-content:space-between; padding:13px 22px; border-top:1px solid var(--line); background:#0C0C0C; }
.acct .who{ display:flex; flex-direction:column; gap:2px; }
.acct .who b{ font-size:13px; font-weight:600; }
.acct .who span{ font-size:11px; color:var(--txt-4); font-family:var(--mono); }
.ver{ display:flex; align-items:center; justify-content:space-between; padding:10px 22px; font-family:var(--mono); font-size:11px; color:var(--txt-4); border-top:1px solid var(--line); background:#080808; }

/* ================= MAIN ================= */
.main{ flex:1; min-width:0; display:flex; flex-direction:column; }
.topbar{ display:flex; align-items:center; gap:16px; padding:0 40px; height:64px; border-bottom:1px solid var(--line); position:sticky; top:0; z-index:5; background:rgba(10,10,10,.86); backdrop-filter:blur(8px); }
.topbar .crumb{ font-size:14px; letter-spacing:0.05em; text-transform:uppercase; font-weight:600; }
.topbar .crumb .pre{ color:var(--txt-4); margin-right:10px; }
.topbar .spacer{ flex:1; }
.topbar .pill{ font-family:var(--mono); font-size:12px; color:var(--txt-2); border:1px solid var(--line); padding:6px 12px; display:inline-flex; align-items:center; gap:8px; cursor:pointer; }
.topbar .pill::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--txt-3); }
.topbar .pill.ok::before{ background:var(--ok); }
.topbar .pill:hover{ border-color:var(--line-2); color:var(--txt); }

.content{ padding:48px 56px 80px; max-width:1280px; width:100%; }

.page-head{ margin-bottom:34px; }
.kicker{ display:flex; align-items:center; gap:13px; margin-bottom:18px; }
.kicker .bar{ width:34px; height:4px; background:var(--accent); }
.kicker .lbl{ font-size:12px; letter-spacing:0.28em; text-transform:uppercase; color:var(--txt-3); font-weight:600; }
.page-head h1{ font-family:var(--display); font-weight:600; font-size:44px; line-height:1.02; letter-spacing:0.01em; margin:0 0 14px; }
.page-head p{ font-size:16px; line-height:1.5; color:var(--txt-2); max-width:760px; margin:0; }
.page-head p b{ color:var(--accent); font-weight:600; }

/* ---- cards ---- */
.card{ border:1px solid var(--line); background:var(--panel); margin-bottom:26px; }
.card-head{ display:flex; align-items:center; gap:13px; padding:18px 26px; border-bottom:1px solid var(--line); background:#121212; }
.card-head .ico{ width:30px; height:30px; flex:0 0 30px; display:grid; place-items:center; border:1px solid var(--line-2); background:#0E0E0E; color:var(--accent); }
.card-head .ico svg{ width:16px; height:16px; }
.card-head h2{ font-size:14px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; margin:0; }
.card-head .tag{ margin-left:auto; font-family:var(--mono); font-size:11px; color:var(--txt-3); letter-spacing:0.04em; }
.card-body{ padding:26px; }

/* ---- form atoms ---- */
.field{ display:flex; flex-direction:column; gap:9px; }
label.flbl{ font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--txt-3); font-weight:600; }
label.flbl .opt{ color:var(--txt-4); }
.inp, .sel{ width:100%; background:#0C0C0C; border:1px solid var(--line-2); color:var(--txt); font-family:var(--font); font-size:15px; padding:13px 15px; transition:border-color .14s, background .14s; appearance:none; }
.inp::placeholder{ color:var(--txt-4); }
.inp:focus, .sel:focus{ outline:none; border-color:var(--accent); background:#0E0E0E; }
.sel{ background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236A6A6A' stroke-width='2'><path d='M6 9l6 6 6-6'/></svg>"); background-repeat:no-repeat; background-position:right 14px center; padding-right:40px; cursor:pointer; color:var(--txt-2); }

/* ---- buttons ---- */
.btn{ font-family:var(--font); font-size:13px; font-weight:600; letter-spacing:0.1em; text-transform:uppercase; padding:13px 22px; border:1px solid transparent; cursor:pointer; transition:all .14s; white-space:nowrap; display:inline-flex; align-items:center; gap:9px; background:transparent; color:var(--txt); }
.btn:disabled{ opacity:.45; cursor:not-allowed; }
.btn-primary{ background:var(--accent); color:#0A0A0A; }
.btn-primary:hover:not(:disabled){ background:#ffce3d; box-shadow:0 0 0 3px rgba(254,190,3,.16); }
.btn-ghost{ background:transparent; border-color:var(--line-2); color:var(--txt); }
.btn-ghost:hover:not(:disabled){ border-color:var(--accent); color:var(--accent); }
/* CR-136: .btn-outline используется в sections/tasks.js, но раньше не было правила
   (кнопка «+ Новая задача» рендерилась без рамки) — алиас ghost-варианта. */
.btn-outline{ background:transparent; border-color:var(--line-2); color:var(--txt); }
.btn-outline:hover:not(:disabled){ border-color:var(--accent); color:var(--accent); }
.btn-danger{ background:transparent; border-color:#3a2422; color:var(--danger); }
.btn-danger:hover:not(:disabled){ border-color:var(--danger); background:rgba(229,103,90,.08); }
.btn-sm{ padding:9px 15px; font-size:12px; }
.btn-block{ width:100%; justify-content:center; padding:16px; font-size:14px; }

.inline-create{ display:flex; align-items:flex-end; gap:18px; }
.inline-create .field{ flex:1; max-width:420px; }

/* ---- leader / employee row ---- */
.lead-row{ display:flex; align-items:center; gap:20px; padding:18px 22px; border:1px solid var(--line); background:#101010; margin-bottom:10px; flex-wrap:wrap; }
.lead-avatar{ width:46px; height:46px; flex:0 0 46px; border:1px solid var(--line-2); background:#0C0C0C; display:grid; place-items:center; font-family:var(--display); font-weight:600; font-size:20px; color:var(--accent); }
.lead-meta{ display:flex; flex-direction:column; gap:5px; min-width:0; }
.lead-meta .nm{ font-size:16px; font-weight:600; }
.lead-meta .nm .role{ color:var(--txt-3); font-weight:400; }
.lead-meta .sub{ font-family:var(--mono); font-size:12px; color:var(--txt-3); letter-spacing:0.02em; word-break:break-all; }
.lead-meta .sub b{ color:var(--txt-2); font-weight:500; }
.lead-actions{ margin-left:auto; display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end; }

.badge{ display:inline-flex; align-items:center; gap:8px; font-size:11.5px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; padding:8px 13px; border:1px solid var(--line-2); color:var(--txt-2); }
.badge.ok{ color:var(--ok); border-color:#234334; background:var(--ok-dim); }
.badge.ok::before{ content:""; width:7px; height:7px; border-radius:50%; background:var(--ok); }
.badge.warn{ color:var(--accent); border-color:var(--accent-dim); background:#1a1505; }
.badge.muted{ color:var(--txt-3); }
.badge.folder{ color:var(--txt-2); border-color:var(--line-2); background:#0E0E0E; cursor:pointer; text-transform:none; letter-spacing:0.02em; font-weight:500; text-decoration:none; }
.badge.folder:hover{ color:var(--accent); border-color:var(--accent); }
.badge.wa{ color:var(--ok); border-color:#234334; background:var(--ok-dim); cursor:pointer; text-transform:none; letter-spacing:0; }
.badge.wa:hover{ color:var(--danger); border-color:var(--danger); background:rgba(229,103,90,.08); }

.subhead{ display:flex; align-items:center; gap:13px; margin:28px 0 16px; }
.subhead .t{ font-size:12px; letter-spacing:0.2em; text-transform:uppercase; color:var(--txt-2); font-weight:600; }
.subhead .ln{ flex:1; height:1px; background:var(--line); }
.sep{ height:1px; background:var(--line); margin:26px 0; }

.dept-row{ display:flex; align-items:flex-end; gap:18px; flex-wrap:wrap; }
.dept-row .field{ flex:1 1 240px; }
.dept-row .field.narrow{ flex:0 1 220px; }
.dept-block{ border:1px solid var(--line); background:#0E0E0E; padding:16px 18px; margin-bottom:14px; }
.dept-block .dept-title{ font-size:13px; font-weight:600; letter-spacing:0.08em; text-transform:uppercase; color:var(--txt-2); margin-bottom:12px; display:flex; align-items:center; gap:10px; }
.dept-block .dept-title .ln{ flex:1; height:1px; background:var(--line); }

.emp-grid{ display:grid; grid-template-columns:1fr 1fr; gap:20px 30px; }
.emp-grid .span2{ grid-column:1 / -1; }
.muted-note{ color:var(--txt-3); font-size:13px; }
.err-banner{ border:1px solid #3a2422; background:rgba(229,103,90,.08); color:var(--danger); padding:14px 18px; margin-bottom:20px; font-size:14px; }

/* ---- tables (sessions/logs/models) ---- */
.tbl{ width:100%; border-collapse:collapse; font-size:13.5px; }
.tbl th{ text-align:left; font-size:11px; letter-spacing:0.12em; text-transform:uppercase; color:var(--txt-4); font-weight:600; padding:10px 14px; border-bottom:1px solid var(--line); }
.tbl td{ padding:12px 14px; border-bottom:1px solid var(--line); color:var(--txt-2); vertical-align:top; }
.tbl tr:hover td{ background:#101010; }
.tbl td .mono{ font-family:var(--mono); font-size:12px; color:var(--txt-3); }
.logbox{ font-family:var(--mono); font-size:12px; line-height:1.55; color:var(--txt-2); background:#080808; border:1px solid var(--line); padding:16px 18px; max-height:62vh; overflow:auto; white-space:pre-wrap; word-break:break-word; }
.logbox .lvl-err{ color:var(--danger); }
.logbox .lvl-warn{ color:var(--accent); }

/* ---- spinner / empty ---- */
.spinner{ width:18px; height:18px; border:2px solid var(--line-2); border-top-color:var(--accent); border-radius:50%; animation:spin .7s linear infinite; display:inline-block; vertical-align:middle; }
@keyframes spin{ to{ transform:rotate(360deg); } }
.loading{ color:var(--txt-3); font-size:14px; display:flex; align-items:center; gap:12px; padding:30px 0; }
.empty{ color:var(--txt-4); font-size:14px; padding:24px; text-align:center; border:1px dashed var(--line); }

/* ---- toasts ---- */
.toasts{ position:fixed; right:24px; bottom:24px; display:flex; flex-direction:column; gap:10px; z-index:50; }
.toast{ border:1px solid var(--line-2); background:#141414; color:var(--txt); padding:13px 18px; font-size:13.5px; min-width:260px; max-width:420px; box-shadow:0 8px 30px rgba(0,0,0,.5); animation:slidein .18s ease; }
.toast.ok{ border-color:#234334; } .toast.ok b{ color:var(--ok); }
.toast.err{ border-color:#3a2422; } .toast.err b{ color:var(--danger); }
.toast b{ display:block; font-size:11px; letter-spacing:0.14em; text-transform:uppercase; margin-bottom:4px; color:var(--txt-3); }
@keyframes slidein{ from{ transform:translateY(8px); opacity:0; } }

/* ---- modal (confirm) ---- */
.modal-bg{ position:fixed; inset:0; background:rgba(0,0,0,.66); display:grid; place-items:center; z-index:60; }
.modal{ border:1px solid var(--line-2); background:var(--panel); width:440px; max-width:92vw; }
.modal .mh{ padding:18px 22px; border-bottom:1px solid var(--line); font-size:13px; letter-spacing:0.14em; text-transform:uppercase; font-weight:600; }
.modal .mb{ padding:22px; font-size:14.5px; line-height:1.5; color:var(--txt-2); }
.modal .mf{ padding:16px 22px; border-top:1px solid var(--line); display:flex; gap:12px; justify-content:flex-end; }

/* ---- code / pre (reconcile report, oauth) ---- */
pre.report{ font-family:var(--mono); font-size:12px; line-height:1.5; color:var(--txt-2); background:#080808; border:1px solid var(--line); padding:14px 16px; overflow:auto; max-height:340px; white-space:pre-wrap; }
.copyrow{ display:flex; align-items:center; gap:10px; }
.copyrow .val{ flex:1; font-family:var(--mono); font-size:12px; color:var(--txt-2); background:#0C0C0C; border:1px solid var(--line-2); padding:11px 13px; overflow:auto; white-space:nowrap; }

/* ---- cabinet: nav icon wrapper (svg внутри span) ---- */
.nav-item .nav-ico{ display:inline-flex; width:18px; height:18px; flex:0 0 18px; }
.nav-item .nav-ico svg{ width:18px; height:18px; stroke-width:1.6; }

/* ---- cabinet: профиль (key/value) ---- */
.profile-grid{ display:flex; flex-direction:column; gap:1px; }
.info-row{ display:flex; align-items:center; gap:18px; padding:13px 2px; border-bottom:1px solid var(--line); }
.info-row:last-child{ border-bottom:none; }
.info-k{ flex:0 0 160px; font-size:11.5px; letter-spacing:0.16em; text-transform:uppercase; color:var(--txt-3); font-weight:600; }
.info-v{ font-size:15px; color:var(--txt); }

/* ---- cabinet: экран входа ---- */
body.login-mode .app{ filter:none; }
.login-wrap{ position:fixed; inset:0; z-index:70; display:grid; place-items:center; background:var(--black); padding:24px; }
.login-card{ width:400px; max-width:94vw; border:1px solid var(--line-2); background:var(--panel); }
.login-brand{ padding:30px 26px 22px; border-bottom:1px solid var(--line); background:#121212; }
.login-brand .mark{ font-family:var(--display); font-weight:700; font-size:34px; letter-spacing:0.02em; line-height:.9; text-transform:lowercase; }
.login-brand .mark .dot{ color:var(--accent); }
.login-brand .sub{ display:block; font-size:10px; letter-spacing:0.3em; text-transform:uppercase; color:var(--txt-3); margin-top:10px; font-weight:600; }
.login-body{ padding:26px; }

/* =========================================================================
   CR-135 — ДОСТУПНОСТЬ (a11y) + CR-136 — ПОЛИРОВКА UX (через CSS)
   ========================================================================= */

/* Видимый фокус для клавиатуры по всем интерактивам (раньше был только у .inp/.sel).
   :focus-visible — не мешает мыши, но даёт чёткую обводку при Tab. */
.nav-item:focus-visible, .btn:focus-visible, .pill:focus-visible, .badge:focus-visible,
.inp:focus-visible, .sel:focus-visible, a:focus-visible, [tabindex]:focus-visible,
select:focus-visible, button:focus-visible, .copyrow .val:focus-visible{
  outline:2px solid var(--accent); outline-offset:2px;
}
/* Размер тапа ≥40px на кликабельных элементах (мобайл/доступность). */
.nav-item{ min-height:44px; }
.btn{ min-height:42px; }
.btn-sm{ min-height:38px; }
.pill, .badge{ min-height:34px; }
/* Полировка: переполнение длинного текста — аккуратный ellipsis, без ломки сетки. */
.lead-meta .nm{ overflow:hidden; text-overflow:ellipsis; }
.info-v{ overflow-wrap:anywhere; }
.topbar .crumb{ overflow:hidden; text-overflow:ellipsis; white-space:nowrap; min-width:0; }
.card-head h2{ overflow:hidden; text-overflow:ellipsis; min-width:0; }
/* Единообразие: textarea.inp (используется в sections/skills,integrations) — как .inp. */
textarea.inp{ min-height:96px; resize:vertical; line-height:1.5; }
/* .empty внутри карточки раздела — мягче и читаемее. */
.card-body .empty{ margin:4px 0; }

/* =========================================================================
   CR-135 — АДАПТИВ: планшет / мобайл (медиазапросы)
   ========================================================================= */

/* ---- ПЛАНШЕТ (≤1080px): одна колонка в гридах форм, поджать поля ---- */
@media (max-width:1080px){
  .content{ padding:36px 32px 70px; }
  .emp-grid{ grid-template-columns:1fr; }
  .topbar{ padding:0 28px; }
  /* Канбан задач (inline grid repeat(4,1fr) в tasks.js): 2 колонки на планшете.
     Inline-стиль перебиваем по атрибутному селектору + !important (иначе не пробить). */
  .content div[style*="grid-template-columns:repeat(4"]{
    grid-template-columns:repeat(2,1fr) !important;
  }
}

/* ---- СЕРЕДИНА (≤880px): сайдбар из вертикальной колонки → верхняя нав-полоса ----
   Раньше тут было просто .sidebar{display:none} — на узких экранах навигация ПРОПАДАЛА.
   Без JS-тогглера превращаем .app в колонку, а сайдбар — в горизонтальную «топ-навигацию»
   (липкую сверху, со скроллом по X). Так разделы остаются доступны на телефоне. */
@media (max-width:880px){
  .app{ flex-direction:column; }
  .sidebar{
    width:100%; flex:0 0 auto; height:auto; position:sticky; top:0; z-index:20;
    flex-direction:column; overflow:visible;
    border-right:none; border-bottom:1px solid var(--line);
  }
  .brand{ padding:16px 20px; }
  .brand .mark{ font-size:24px; }
  /* навигация — горизонтальный скролл-ряд «таблеток» */
  .nav{
    flex:0 0 auto; flex-direction:row; gap:6px; overflow-x:auto; overflow-y:hidden;
    padding:8px 14px; border-top:1px solid var(--line); -webkit-overflow-scrolling:touch;
  }
  .nav-item{
    flex:0 0 auto; border-left:none; border-bottom:2px solid transparent;
    padding:9px 12px; letter-spacing:0.04em;
  }
  .nav-item.active{ border-left-color:transparent; border-bottom-color:var(--accent); }
  /* системный блок/аккаунт/версия в шапке мобайла лишние — прячем (логаут есть в профиле) */
  .sys, .acct, .ver{ display:none; }
  .main{ min-height:auto; }
  .topbar{ padding:0 20px; height:56px; }
  .content{ padding:28px 20px 56px; max-width:none; }
  .page-head h1{ font-size:34px; }
  .page-head p{ font-size:15px; }
  .card-body{ padding:20px; }
  .card-head{ padding:15px 20px; }
  /* карточки/строки сотрудников — в столбик, действия на всю ширину */
  .lead-row{ flex-direction:column; align-items:stretch; gap:14px; }
  .lead-actions{ margin-left:0; justify-content:flex-start; }
  .inline-create{ flex-direction:column; align-items:stretch; }
  .inline-create .field{ max-width:none; }
  /* профиль key/value — в две строки (метка над значением) */
  .info-row{ flex-direction:column; align-items:flex-start; gap:5px; }
  .info-k{ flex:0 0 auto; }
  /* канбан задач — одна колонка на узком (overview-грид auto-fill адаптируется сам) */
  .content div[style*="grid-template-columns:repeat(4"]{
    grid-template-columns:1fr !important;
  }
  /* таблицы метрик/логов — горизонтальный скролл, чтобы не ломать вёрстку */
  .tbl{ display:block; overflow-x:auto; white-space:nowrap; }
  /* модалки/тосты — по ширине экрана с отступами */
  .modal{ width:100%; }
  .toasts{ right:12px; left:12px; bottom:12px; }
  .toast{ min-width:0; max-width:none; }
}

/* ---- ТЕЛЕФОН (≤520px): максимально компактно, кнопки на всю ширину ---- */
@media (max-width:520px){
  .brand{ padding:14px 16px; }
  .nav{ padding:6px 10px; }
  .topbar{ padding:0 14px; }
  .topbar .crumb{ font-size:13px; }
  .content{ padding:22px 14px 48px; }
  .page-head{ margin-bottom:24px; }
  .page-head h1{ font-size:28px; }
  .card-body{ padding:16px; }
  .card-head{ padding:13px 16px; gap:10px; }
  /* действия в строках — в столбик и на всю ширину (тап-таргеты) */
  .lead-actions{ flex-direction:column; align-items:stretch; }
  .lead-actions .btn, .lead-actions .badge{ width:100%; justify-content:center; }
  .modal .mf{ flex-direction:column; }
  .modal .mf .btn{ width:100%; justify-content:center; }
  /* login-card адаптивна (CR-135): на узком — почти на всю ширину, поджатые отступы */
  .login-card{ width:100%; }
  .login-brand{ padding:24px 20px 18px; }
  .login-brand .mark{ font-size:28px; }
  .login-body{ padding:20px; }
}

/* Уважение к prefers-reduced-motion: гасим анимации для чувствительных пользователей. */
@media (prefers-reduced-motion:reduce){
  *, *::before, *::after{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
}
