/* ============================================================
   Поток — дизайн-система (продакшн-сборка).
   Токены + оболочка + компоненты.
   Копирует design/app.css с дополнительными секциями
   из инлайн-стилей dashboard.html.
   ============================================================ */

/* ── Шрифты ── */
@import url("/static/fonts/fonts.css");

/* ── Переменные (токены) ── */
:root{
  --f1:#2BD9A4;--f2:#38BDF8;--f3:#6366F1;
  --flow:linear-gradient(110deg,var(--f1) 0%,var(--f2) 48%,var(--f3) 100%);
  --up:#22D3A6;--down:#FF5C7A;--warn:#FBBF73;
  --r-lg:20px;--r-md:14px;--r-sm:10px;
  --ff-d:"Unbounded",sans-serif;
  --ff-g:"Golos Text",sans-serif;
  --ff-m:"JetBrains Mono",ui-monospace,monospace;
  --ease:cubic-bezier(.22,.61,.36,1);
}
[data-theme="dark"]{
  --bg:#080B11;--bg-2:#0B0F17;--surface:#10151F;--surface-2:#141A26;--surface-3:#1A2130;
  --border:#222B3A;--border-soft:#1A2130;--text:#E8ECF5;--muted:#8B95A9;--faint:#5B6678;
  --glass:rgba(255,255,255,.03);--glass-line:rgba(255,255,255,.06);
  --shadow:0 24px 60px -28px rgba(0,0,0,.85);
}
[data-theme="light"]{
  --bg:#EEF1F6;--bg-2:#F5F7FB;--surface:#FFFFFF;--surface-2:#F7F9FC;--surface-3:#EFF3F9;
  --border:#E1E7F0;--border-soft:#EAEFF6;--text:#0E1726;--muted:#5A6679;--faint:#8B97AB;
  --glass:rgba(10,20,40,.02);--glass-line:rgba(10,20,40,.05);
  --shadow:0 24px 50px -30px rgba(20,40,80,.30);
}

/* ── Сброс ── */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}

/* ── Body + фоновая аврора ── */
body{
  font-family:var(--ff-g);background:var(--bg);color:var(--text);
  -webkit-font-smoothing:antialiased;min-height:100vh;
  line-height:1.45;letter-spacing:.1px;overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(60vw 40vw at 8% -6%,rgba(43,217,164,.10),transparent 60%),
    radial-gradient(50vw 36vw at 100% 0%,rgba(99,102,241,.12),transparent 55%),
    radial-gradient(40vw 30vw at 60% 110%,rgba(56,189,248,.07),transparent 60%);
}
/* зернистость атмосферы */
body::after{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;opacity:.025;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ── Основная сетка приложения ── */
.app{position:relative;z-index:1;display:grid;grid-template-columns:248px 1fr;min-height:100vh}

/* ── Сайдбар ── */
.side{
  position:sticky;top:0;height:100vh;padding:22px 16px;
  display:flex;flex-direction:column;gap:6px;
  border-right:1px solid var(--border-soft);background:var(--bg-2);
}
.brand{display:flex;align-items:center;gap:12px;padding:6px 8px 22px}
.brand .mark{
  width:38px;height:38px;border-radius:12px;background:var(--flow);
  display:grid;place-items:center;box-shadow:0 8px 22px -8px rgba(56,189,248,.6);
  position:relative;overflow:hidden;
}
.brand .mark svg{width:23px;height:23px}
.brand .name{font-family:var(--ff-g);font-weight:800;font-size:20px;letter-spacing:.3px}
.nav-label{font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--faint);padding:14px 10px 6px}
.nav a{
  display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--r-sm);
  color:var(--muted);text-decoration:none;font-weight:500;font-size:14.5px;
  transition:.18s var(--ease);position:relative;
}
.nav a svg{width:19px;height:19px;stroke-width:1.7}
.nav a:hover{color:var(--text);background:var(--glass)}
.nav a.active{color:var(--text);background:var(--surface-2)}
.nav a.active::before{
  content:"";position:absolute;left:-16px;top:9px;bottom:9px;width:3px;
  border-radius:0 3px 3px 0;background:var(--flow);
}
.side-foot{margin-top:auto;display:flex;flex-direction:column;gap:10px;padding-top:14px}
.robot-state{
  display:flex;align-items:center;gap:10px;padding:12px;border-radius:var(--r-md);
  background:var(--surface);border:1px solid var(--border-soft);
}
.pulse{width:9px;height:9px;border-radius:50%;background:var(--up);animation:pulse 2.4s infinite}
@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(34,211,166,.45)}
  70%{box-shadow:0 0 0 9px rgba(34,211,166,0)}
  100%{box-shadow:0 0 0 0 rgba(34,211,166,0)}
}
.robot-state small{color:var(--faint);font-size:11px;display:block}
.robot-state span{font-size:13px;font-weight:600}

/* ── Topbar ── */
.main{display:flex;flex-direction:column;min-width:0}
.topbar{
  display:flex;align-items:center;gap:16px;padding:16px 28px;
  border-bottom:1px solid var(--border-soft);position:sticky;top:0;z-index:5;
  background:color-mix(in srgb,var(--bg) 78%,transparent);backdrop-filter:blur(14px);
}
.page-title{font-family:var(--ff-g);font-weight:700;font-size:18px;letter-spacing:.2px}
.page-title small{display:block;font-family:var(--ff-g);font-weight:400;font-size:12px;color:var(--faint);letter-spacing:.3px}
.spacer{flex:1}
.acct{
  display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:var(--r-md);
  background:var(--surface);border:1px solid var(--border);cursor:pointer;font-size:13.5px;font-weight:500;
}
.acct .dot{width:7px;height:7px;border-radius:50%;background:var(--f2)}
.acct svg{width:15px;height:15px;color:var(--muted)}
.badge{
  font-family:var(--ff-m);font-size:11px;font-weight:500;padding:5px 9px;border-radius:8px;
  letter-spacing:.4px;text-transform:uppercase;
}
.badge.sandbox{
  color:var(--warn);
  background:color-mix(in srgb,var(--warn) 14%,transparent);
  border:1px solid color-mix(in srgb,var(--warn) 30%,transparent);
}
/* мастер-тумблер автотрейда */
.autotrade{display:flex;align-items:center;gap:11px;padding:7px 8px 7px 14px;border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border)}
.autotrade .lbl{font-size:11px;line-height:1.2;color:var(--faint)}
.autotrade .lbl b{display:block;font-size:13px;color:var(--text);font-weight:600}
.icon-btn{
  width:38px;height:38px;display:grid;place-items:center;border-radius:11px;
  background:var(--surface);border:1px solid var(--border);
  color:var(--muted);cursor:pointer;transition:.18s;
}
.icon-btn:hover{color:var(--text);border-color:var(--border)}
.icon-btn svg{width:18px;height:18px}
.icon-btn.bell{position:relative}
.icon-btn.bell::after{
  content:"";position:absolute;top:9px;right:10px;
  width:7px;height:7px;border-radius:50%;
  background:var(--down);border:2px solid var(--surface);
}
.ava{width:38px;height:38px;border-radius:11px;background:var(--flow);display:grid;place-items:center;font-weight:700;color:#06121f;font-size:14px}

/* ── Контент + карточки ── */
.content{padding:24px 28px 48px;display:flex;flex-direction:column;gap:20px}
.reveal{opacity:0;transform:translateY(14px);animation:rise .7s var(--ease) forwards}
@keyframes rise{to{opacity:1;transform:none}}
.card{
  background:linear-gradient(180deg,var(--glass),transparent),var(--surface);
  border:1px solid var(--border-soft);border-radius:var(--r-lg);
  padding:20px;box-shadow:var(--shadow);position:relative;overflow:hidden;
}
.card .top-line{
  position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,transparent,var(--glass-line),transparent);
}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}
.card-h h3{font-family:var(--ff-g);font-weight:700;font-size:15px}
.card-h .link{color:var(--muted);font-size:12.5px;text-decoration:none;display:flex;align-items:center;gap:4px}
.card-h .link:hover{color:var(--text)}
.muted{color:var(--muted)}
.faint{color:var(--faint)}
.mono{font-family:var(--ff-m)}
.up{color:var(--up)}
.down{color:var(--down)}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}

/* ── Компоненты ── */
.btn{
  font-family:var(--ff-g);font-weight:600;font-size:13.5px;padding:10px 16px;
  border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);
  color:var(--text);cursor:pointer;transition:.18s var(--ease);
  display:inline-flex;align-items:center;gap:8px;
}
.btn:hover{border-color:var(--muted)}
.btn.primary{background:var(--flow);border:0;color:#06121f}
.btn.danger{
  color:var(--down);
  border-color:color-mix(in srgb,var(--down) 40%,transparent);
  background:color-mix(in srgb,var(--down) 10%,transparent);
}
.btn svg{width:16px;height:16px}
.seg{display:flex;gap:2px;background:var(--surface-3);padding:3px;border-radius:10px}
.seg button{
  border:0;background:transparent;color:var(--muted);font-family:var(--ff-m);
  font-size:12px;padding:6px 12px;border-radius:7px;cursor:pointer;transition:.15s;
}
.seg button.on{background:var(--surface);color:var(--text);box-shadow:0 2px 8px -4px rgba(0,0,0,.5)}
.switch{
  --w:46px;width:var(--w);height:26px;border-radius:20px;
  background:var(--surface-3);border:1px solid var(--border);
  position:relative;cursor:pointer;transition:.25s var(--ease);flex:0 0 auto;
}
.switch::after{
  content:"";position:absolute;top:2px;left:2px;
  width:20px;height:20px;border-radius:50%;background:#fff;transition:.25s var(--ease);
}
.switch.on{background:var(--flow);border-color:transparent}
.switch.on::after{left:22px;box-shadow:0 0 12px rgba(56,189,248,.7)}
.field{display:flex;flex-direction:column;gap:7px}
.field label{font-size:12.5px;color:var(--muted);font-weight:500}
.field input,.field select{
  font-family:var(--ff-g);font-size:14px;padding:11px 13px;border-radius:var(--r-md);
  background:var(--surface-2);border:1px solid var(--border);color:var(--text);
  outline:none;transition:.18s;
}
.field input:focus,.field select:focus{
  border-color:var(--f2);box-shadow:0 0 0 3px color-mix(in srgb,var(--f2) 18%,transparent);
}
.field .hint{font-size:11.5px;color:var(--faint)}
.tag{font-family:var(--ff-m);font-size:11px;font-weight:500;padding:3px 8px;border-radius:6px;display:inline-block}
.tag.long{color:var(--up);background:color-mix(in srgb,var(--up) 13%,transparent)}
.tag.short{color:var(--down);background:color-mix(in srgb,var(--down) 13%,transparent)}
.chip{font-size:12px;color:var(--faint);padding:5px 11px;border-radius:20px;background:var(--surface-2);border:1px solid var(--border-soft)}
table.tbl{width:100%;border-collapse:collapse;font-size:13px}
table.tbl th{
  text-align:left;color:var(--faint);font-weight:500;font-size:11.5px;
  text-transform:uppercase;letter-spacing:.5px;padding:0 10px 12px;
}
table.tbl td{padding:13px 10px;border-top:1px solid var(--border-soft)}
table.tbl td.num,table.tbl th.num{text-align:right;font-family:var(--ff-m)}

/* ── Мобильная навигация (нижний таб-бар) ── */
.mobnav{display:none}
.mobnav{
  position:fixed;left:0;right:0;bottom:0;z-index:40;
  background:color-mix(in srgb,var(--bg-2) 92%,transparent);
  backdrop-filter:blur(16px);border-top:1px solid var(--border);
  padding:7px 6px calc(7px + env(safe-area-inset-bottom));
}
.mobnav .row{display:flex;justify-content:space-around;align-items:stretch}
.mobnav a{
  flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;
  padding:5px 2px;color:var(--faint);text-decoration:none;
  font-size:10px;font-weight:500;border-radius:10px;
}
.mobnav a svg{width:21px;height:21px;stroke-width:1.8}
.mobnav a.active{color:var(--text)}
.mobnav a.active svg{color:var(--f2)}

/* ── Состояния, тосты, модалки ── */
.skeleton{
  background:linear-gradient(100deg,var(--surface-2) 30%,var(--surface-3) 50%,var(--surface-2) 70%);
  background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:8px;
}
@keyframes shimmer{to{background-position:-200% 0}}
.empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:40px 20px;text-align:center}
.empty .ic{
  width:54px;height:54px;border-radius:16px;background:var(--surface-2);
  border:1px solid var(--border-soft);display:grid;place-items:center;color:var(--faint);
}
.empty .ic svg{width:26px;height:26px}
.empty b{font-size:14px}
.empty p{font-size:12.5px;color:var(--faint);max-width:280px}
.offline{
  display:flex;align-items:center;gap:10px;padding:10px 16px;border-radius:var(--r-md);
  background:color-mix(in srgb,var(--warn) 12%,var(--surface));
  border:1px solid color-mix(in srgb,var(--warn) 32%,transparent);
  font-size:12.5px;color:var(--text);
}
.offline .d{width:8px;height:8px;border-radius:50%;background:var(--warn)}
.toast{
  display:flex;align-items:center;gap:11px;padding:13px 16px;border-radius:var(--r-md);
  background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);
  font-size:13px;min-width:280px;
}
.toast .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto}
.toast.ok .ic{background:color-mix(in srgb,var(--up) 14%,transparent);color:var(--up)}
.toast.err .ic{background:color-mix(in srgb,var(--down) 14%,transparent);color:var(--down)}
.toast .ic svg{width:17px;height:17px}
.modal-card{
  width:380px;max-width:92vw;border-radius:var(--r-lg);
  background:var(--surface);border:1px solid var(--border);
  box-shadow:var(--shadow);padding:22px;
}
.modal-card .mi{
  width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  margin-bottom:14px;background:color-mix(in srgb,var(--down) 13%,transparent);color:var(--down);
}
.modal-card .mi svg{width:24px;height:24px}
.modal-card h3{font-family:var(--ff-g);font-weight:700;font-size:17px;margin-bottom:6px}
.modal-card p{font-size:13px;color:var(--muted);line-height:1.5;margin-bottom:18px}
.modal-card .acts{display:flex;gap:10px;justify-content:flex-end}

/* ── Анимация логотипа «поток течёт» ── */
.flow-logo path{stroke-dasharray:60;stroke-dashoffset:60;animation:flowdraw 1.6s var(--ease) forwards}
.flow-logo path:nth-child(2){animation-delay:.12s}
.flow-logo path:nth-child(3){animation-delay:.24s}
.flow-logo circle{opacity:0;animation:flowdot .5s ease 1.1s forwards}
@keyframes flowdraw{to{stroke-dashoffset:0}}
@keyframes flowdot{to{opacity:1}}
.splash{display:flex;flex-direction:column;align-items:center;gap:16px;padding:50px}
.splash .ldr{width:120px;height:3px;border-radius:3px;background:var(--surface-3);overflow:hidden}
.splash .ldr i{display:block;height:100%;width:40%;background:var(--flow);animation:load 1.4s var(--ease) infinite}
@keyframes load{0%{transform:translateX(-120%)}100%{transform:translateX(330%)}}

/* ════════════════════════════════════════════════════════════
   ДАШБОРД: дополнительные компоненты (вынесено из инлайн)
   ════════════════════════════════════════════════════════════ */

/* строка здоровья соединений */
.health{
  display:flex;align-items:center;gap:8px;padding:11px 16px;border-radius:var(--r-md);
  background:var(--surface);border:1px solid var(--border-soft);
}
.health .st{
  display:flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);
  padding-right:14px;border-right:1px solid var(--border-soft);
}
.health .st:last-of-type{border-right:0}
.health .st .d{
  width:8px;height:8px;border-radius:50%;background:var(--up);
  box-shadow:0 0 8px color-mix(in srgb,var(--up) 80%,transparent);
}
.health .st .d.warn{background:var(--warn);box-shadow:0 0 8px color-mix(in srgb,var(--warn) 80%,transparent)}
.health .st b{color:var(--text);font-weight:500}
.health .st .ms{font-family:var(--ff-m);font-size:11px;color:var(--faint)}
.kill{
  margin-left:auto;display:inline-flex;align-items:center;gap:8px;
  font-family:var(--ff-g);font-weight:600;font-size:13px;padding:9px 15px;
  border-radius:var(--r-md);cursor:pointer;color:var(--down);
  border:1px solid color-mix(in srgb,var(--down) 40%,transparent);
  background:color-mix(in srgb,var(--down) 10%,transparent);
}
.kill svg{width:16px;height:16px}

/* KPI-плитки */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.kpi h4{font-size:12.5px;font-weight:500;color:var(--muted);display:flex;align-items:center;gap:7px;margin-bottom:12px}
.kpi h4 svg{width:15px;height:15px;opacity:.8}
.kpi .val{font-family:var(--ff-m);font-size:26px;font-weight:500;letter-spacing:-.5px}
.kpi .sub{margin-top:7px;font-size:12.5px;color:var(--faint);font-family:var(--ff-m)}
.chg{font-family:var(--ff-m);font-size:12.5px;font-weight:500;padding:2px 7px;border-radius:7px}
.chg.up{color:var(--up);background:color-mix(in srgb,var(--up) 13%,transparent)}
.chg.down{color:var(--down);background:color-mix(in srgb,var(--down) 13%,transparent)}

/* P&L */
.pnl-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:6px}
.pnl-head .big{font-family:var(--ff-m);font-size:38px;font-weight:500;letter-spacing:-1px;line-height:1}
.pnl-head .big.up{color:var(--up)}
.chart{margin-top:10px}
.chart svg{width:100%;height:160px;display:block}

/* Donut-распределение */
.donut-wrap{display:flex;align-items:center;gap:22px}
.donut{
  width:148px;height:148px;border-radius:50%;flex:0 0 auto;position:relative;
  background:conic-gradient(var(--f3) 0 33.33%,var(--f1) 33.33% 66.66%,var(--surface-3) 66.66% 100%);
}
.donut::after{content:"";position:absolute;inset:18px;border-radius:50%;background:var(--surface)}
.donut .c{position:absolute;inset:0;display:grid;place-content:center;text-align:center;z-index:1}
.donut .c b{font-family:var(--ff-m);font-size:20px}
.donut .c small{font-size:11px;color:var(--faint)}
.legend{display:flex;flex-direction:column;gap:11px;font-size:13px;flex:1}
.legend .row{display:flex;align-items:center;gap:9px}
.legend .sw{width:10px;height:10px;border-radius:3px}
.legend .row span{color:var(--muted)}
.legend .row b{margin-left:auto;font-family:var(--ff-m);font-weight:500}

/* Слоты активных позиций */
.slots{display:flex;flex-direction:column;gap:10px}
.slot{
  display:grid;grid-template-columns:36px 1.4fr 1fr 1fr auto;
  align-items:center;gap:14px;padding:13px 14px;
  border-radius:var(--r-md);background:var(--surface-2);border:1px solid var(--border-soft);
  transition:.18s var(--ease);
}
.slot:hover{border-color:var(--border);transform:translateX(2px)}
.slot .who{
  width:36px;height:36px;border-radius:10px;display:grid;place-items:center;
  font-weight:700;font-size:14px;color:#06121f;font-family:var(--ff-d);
}
.slot .name{font-weight:600;font-size:14px}
.slot .name small{display:block;color:var(--faint);font-size:11.5px;font-weight:400;font-family:var(--ff-m)}
.slot .pnl{font-family:var(--ff-m);font-size:14px;text-align:right}
.slot .pnl.up{color:var(--up)}
.slot .pnl.down{color:var(--down)}
.slot .time{font-family:var(--ff-m);font-size:12px;color:var(--faint);text-align:right}
.idle{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.chip::before{content:"○ "}

/* Лента сделок */
.feed{display:flex;flex-direction:column}
.fr{
  display:grid;grid-template-columns:30px 1.3fr 1fr 1.4fr auto;
  gap:12px;align-items:center;padding:13px 4px;
  border-bottom:1px solid var(--border-soft);font-size:13px;
}
.fr:last-child{border-bottom:0}
.fr .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center}
.fr .ic.up{background:color-mix(in srgb,var(--up) 13%,transparent);color:var(--up)}
.fr .ic.down{background:color-mix(in srgb,var(--down) 13%,transparent);color:var(--down)}
.fr .ic svg{width:15px;height:15px}
.fr .t b{font-weight:600}
.fr .t small{display:block;color:var(--faint);font-size:11.5px;font-family:var(--ff-m)}
.fr .meta{font-family:var(--ff-m);font-size:11.5px;color:var(--faint)}
.fr .res{text-align:right;font-family:var(--ff-m);font-weight:500}
.fr .res.up{color:var(--up)}
.fr .res.down{color:var(--down)}
.fr .res small{display:block;color:var(--faint);font-weight:400;font-size:11px}

/* ── Адаптив ── */
@media(max-width:1100px){
  .grid-2,.grid-3{grid-template-columns:1fr}
  .kpis{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:760px){
  .app{grid-template-columns:1fr}
  .side{display:none}
  .mobnav{display:block}
  .content{padding:16px 16px 92px}
  .topbar{padding:14px 16px}
  .hide-mobile{display:none!important}
  table.tbl{display:block;overflow-x:auto;white-space:nowrap}
  .grid-2,.grid-3{gap:14px}
  .kpis{grid-template-columns:1fr 1fr}
}

/* ════════════════════════════════════════════════════════════
   AUTH-КАРКАС: центрированная карточка, без сайдбара.
   Используется страницами login, otp, change_password, setup_totp.
   ════════════════════════════════════════════════════════════ */

/* Обёртка на всю высоту с центрированием */
.auth-wrap{
  position:relative;z-index:1;
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  padding:24px 16px;
}

/* Карточка формы */
.auth-card{
  width:100%;max-width:420px;
  background:linear-gradient(180deg,var(--glass),transparent),var(--surface);
  border:1px solid var(--border-soft);border-radius:var(--r-lg);
  padding:36px 32px 32px;box-shadow:var(--shadow);
  position:relative;overflow:hidden;
}
.auth-card::before{
  content:"";position:absolute;inset:0 0 auto 0;height:1px;
  background:linear-gradient(90deg,transparent,var(--glass-line),transparent);
}

/* Широкая карточка для setup_totp с QR */
.auth-card--wide{max-width:520px}

/* Логотип-шапка */
.auth-brand{display:flex;justify-content:center;margin-bottom:24px}
.auth-brand .brand{justify-content:center}
.auth-brand .brand .name{font-size:22px}

/* Заголовок страницы */
.auth-title{
  font-family:var(--ff-g);font-weight:700;font-size:20px;
  text-align:center;margin-bottom:8px;
}

/* Подсказка под заголовком */
.auth-hint{
  font-size:13.5px;color:var(--muted);text-align:center;
  margin-bottom:20px;line-height:1.5;
}

/* Блок ошибки */
.auth-error{
  background:color-mix(in srgb,var(--down) 12%,var(--surface));
  border:1px solid color-mix(in srgb,var(--down) 36%,transparent);
  border-radius:var(--r-md);padding:11px 14px;margin-bottom:16px;
  font-size:13.5px;color:var(--down);line-height:1.4;
}

/* Блок нарушений политики пароля */
.auth-violations{
  background:color-mix(in srgb,var(--warn) 10%,var(--surface));
  border:1px solid color-mix(in srgb,var(--warn) 32%,transparent);
  border-radius:var(--r-md);padding:11px 14px;margin-bottom:16px;
  font-size:13.5px;color:var(--warn);line-height:1.6;
}
.auth-violations strong{display:block;margin-bottom:6px}
.auth-violations ul{margin-left:16px}

/* Кнопка отправки формы */
.auth-submit{width:100%;justify-content:center;margin-top:8px}

/* Блок подсказки о политике паролей */
.auth-policy{
  margin-top:18px;padding-top:14px;
  border-top:1px solid var(--border-soft);
  font-size:12.5px;color:var(--faint);
}
.auth-policy-title{font-weight:600;color:var(--muted);margin-bottom:6px}
.auth-policy ul{margin-left:16px;line-height:1.8}

/* TOTP QR-блок */
.totp-setup{
  display:flex;gap:20px;align-items:flex-start;
  margin-bottom:20px;padding:16px;
  background:var(--surface-2);border:1px solid var(--border-soft);
  border-radius:var(--r-md);
}
.totp-qr{
  flex:0 0 auto;width:148px;height:148px;
  background:#fff;border-radius:12px;padding:8px;
  display:flex;align-items:center;justify-content:center;
}
.totp-qr img{width:100%;height:100%;display:block;border-radius:4px}
.totp-manual{flex:1;min-width:0}

/* Секрет TOTP — моноширный блок */
.totp-secret{
  font-family:var(--ff-m);font-size:13px;letter-spacing:1.5px;
  padding:10px 13px;border-radius:var(--r-md);
  background:var(--surface-3);border:1px solid var(--border);
  color:var(--text);word-break:break-all;line-height:1.6;
  margin-top:6px;
}

/* Адаптив для auth-wrap */
@media(max-width:500px){
  .auth-card,.auth-card--wide{padding:28px 20px 24px}
  .totp-setup{flex-direction:column;align-items:center}
  .totp-manual{width:100%}
}
