/* Lumisfera HR — дизайн-система v3.
   Слои глубины (3 графита) · монохромно-зелёная аналитика · премиум-кириллица Onest ·
   лайм — только интерактивный акцент · графики — дорогой изумруд с сеткой и свечением. */
:root{
  --bg:#070809;                 /* страница — глубже всех */
  --s-deep:#0e0f12;             /* таблица / график — почти чёрный графит (контраст текста) */
  --s-card:#16181c;             /* KPI / дефолт — тёмный графит */
  --s-raised:#262931;           /* диаграмма / hero — светлый графит (верхний слой) */
  --inset:#0c0d0f;              /* поля, лунки — глубже карточки */
  --line:#2c2f35; --line2:#3a3e46;
  --line-soft:rgba(255,255,255,.055);
  --text:#f1f2f4; --muted:#9a9da3; --muted2:#686b71;
  --acc:#c8f25a; --acc-d:#b6e642; --acc-ink:#141a06;   /* лайм — только акцент */
  /* диаграммы: правило — один сегмент белый, один лайм, остальные оттенки зелёного */
  --e5:#eef0ea; --e4:#c8f25a; --e3:#8fcf5f; --e2:#5f9648; --e1:#39592e;
  --chart:#2f9a62; --chart-line:#8af0b6;               /* график — бархатный зелёный + мятная кромка */
  --up:#7fd06a; --down:#c08274;
  --r:16px; --rs:11px; --rp:999px; --sb:248px; --rr:316px;
  --sh:0 1px 2px rgba(0,0,0,.35), 0 10px 30px rgba(0,0,0,.22);
  --font-display:'Unbounded',-apple-system,sans-serif;   /* заголовки/числа/бренд */
  --font-body:'Golos Text',-apple-system,Segoe UI,Roboto,sans-serif; /* тело/таблицы */
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--bg); color:var(--text);
  font:14px/1.5 var(--font-body);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-feature-settings:"tnum","ss01";
}
a{color:inherit;text-decoration:none}
b,strong{font-weight:700}
::-webkit-scrollbar{width:9px;height:9px}
::-webkit-scrollbar-thumb{background:#22252a;border-radius:8px;border:2px solid transparent;background-clip:padding-box}
.tnum{font-variant-numeric:tabular-nums}

/* layout */
.app{display:grid;grid-template-columns:var(--sb) 1fr var(--rr);min-height:100vh}
.app.norail{grid-template-columns:var(--sb) 1fr}
.main{padding:26px 30px 48px;min-width:0}
.rail{border-left:1px solid var(--line-soft);padding:26px 20px}

/* sidebar */
.sidebar{border-right:1px solid var(--line-soft);padding:22px 16px;display:flex;flex-direction:column;gap:3px;
  position:sticky;top:0;height:100vh;align-self:start;overflow-y:auto}  /* фикс: userbox не уходит за экран */
.brand{display:flex;align-items:center;gap:11px;padding:4px 8px 20px}
.brand .logo{width:30px;height:30px;border-radius:9px;background:var(--acc);display:grid;place-items:center;color:var(--acc-ink);font-weight:800;font-size:15px}
.brand b{font-family:var(--font-display);font-weight:600;letter-spacing:-.4px;font-size:14px}
.brand .sub{color:var(--muted2);font-size:11px;margin-top:1px}
.search{display:flex;align-items:center;gap:9px;background:var(--inset);border:1px solid var(--line-soft);border-radius:var(--rs);padding:9px 12px;color:var(--muted2);margin-bottom:6px}
.search input{background:none;border:0;outline:0;color:var(--text);width:100%;font-size:13px;font-family:inherit}
.search kbd{font:11px/1 inherit;border:1px solid var(--line);border-radius:5px;padding:3px 5px;color:var(--muted2)}
.navgroup{color:var(--muted2);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;margin:18px 10px 8px;font-weight:600}
.nav{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--rs);color:#bcbfc5;cursor:pointer;font-size:13.5px;font-weight:500;transition:.14s}
.nav svg{width:18px;height:18px;flex:0 0 18px;stroke:currentColor;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.nav:hover{background:var(--s-card);color:#fff}
.nav.active{background:var(--acc);color:var(--acc-ink);font-weight:600}
.nav .tag{margin-left:auto;background:var(--s-card);color:var(--muted);border-radius:var(--rp);font-size:11px;padding:1px 8px;font-weight:600}
.nav.active .tag{background:rgba(20,26,6,.16);color:var(--acc-ink)}
.userbox{margin-top:auto;display:flex;align-items:center;gap:11px;padding:14px 8px 4px;border-top:1px solid var(--line-soft)}
.ava{border-radius:50%;background:#23262c;color:#c5c8cd;object-fit:cover;flex:0 0 auto;display:grid;place-items:center;font-weight:600;letter-spacing:-.2px}
.ava.s{width:34px;height:34px;font-size:12px} .ava.m{width:44px;height:44px;font-size:14px} .ava.l{width:66px;height:66px;font-size:21px}

/* topbar */
.topbar{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:24px}
.crumb{color:var(--muted2);font-size:12.5px}
.crumb b{color:var(--muted)}
.h1{font-family:var(--font-display);font-size:25px;font-weight:600;margin:6px 0 0;letter-spacing:0;text-transform:uppercase}
.tools{display:flex;align-items:center;gap:9px}
.icon-btn{width:38px;height:38px;border-radius:10px;border:1px solid var(--line-soft);background:transparent;display:grid;place-items:center;color:var(--muted);cursor:pointer}
.icon-btn:hover{color:#fff;background:var(--s-card)}
.datebtn{display:flex;align-items:center;gap:8px;border:1px solid var(--line-soft);background:transparent;border-radius:10px;padding:9px 13px;color:var(--muted);font-size:13px;cursor:pointer}

/* cards — три уровня глубины */
.card{background:var(--s-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:20px;box-shadow:var(--sh)}
.card.raised{background:var(--s-raised)}
.card.deep{background:var(--s-deep)}
.card-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}
.card-h h3{font-family:var(--font-display);font-size:14px;margin:0;font-weight:600;letter-spacing:.4px;text-transform:uppercase}
.dots{color:var(--muted2);cursor:pointer}
.grid{display:grid;gap:18px}
.g4{grid-template-columns:repeat(4,1fr)} .g3{grid-template-columns:repeat(3,1fr)} .g2{grid-template-columns:1fr 1fr}
.muted{color:var(--muted)} .mut2{color:var(--muted2)}

/* kpi — тёмный графит */
.kpi{background:var(--s-card);border:1px solid var(--line-soft);border-radius:var(--r);padding:18px 19px;box-shadow:var(--sh)}
.kpi .lbl{color:var(--muted);font-family:var(--font-display);font-size:11.5px;font-weight:500;text-transform:uppercase;letter-spacing:.6px;display:flex;align-items:center;gap:9px}
.kpi .lbl svg{width:15px;height:15px;stroke:var(--muted2);fill:none;stroke-width:1.6}
.kpi .num{font-family:var(--font-display);font-size:33px;font-weight:600;margin:13px 0 12px;letter-spacing:-1.4px}
.kpi .num small{font-size:14px;color:var(--muted);font-weight:500;letter-spacing:0}
.trend{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;padding:3px 9px;border-radius:var(--rp)}
.trend.up{background:rgba(127,208,106,.10);color:var(--up)}
.trend.down{background:rgba(192,130,116,.10);color:var(--down)}
.trend.flat{color:var(--muted2);padding-left:0}

/* buttons */
.btn{border:1px solid var(--line);background:transparent;color:#dfe0e3;border-radius:10px;padding:9px 15px;font:600 13px/1 inherit;cursor:pointer;display:inline-flex;align-items:center;gap:8px}
.btn:hover{background:var(--s-card);border-color:var(--line)}
.btn.primary{background:var(--acc);border-color:var(--acc);color:var(--acc-ink)}
.btn.primary:hover{background:var(--acc-d)}
.btn.ghost{border-color:transparent;color:var(--muted)}
.btn.sm{padding:7px 12px;font-size:12.5px}

/* segmented */
.seg{display:inline-flex;background:var(--inset);border:1px solid var(--line-soft);border-radius:10px;padding:3px}
.seg b{padding:6px 13px;border-radius:8px;font-size:12.5px;color:var(--muted);cursor:pointer;font-weight:500}
.seg b.on{background:var(--s-raised);color:#fff;box-shadow:0 1px 2px rgba(0,0,0,.3)}

/* badges */
.badge{display:inline-flex;align-items:center;gap:7px;border-radius:var(--rp);font-size:11.5px;font-weight:600;padding:3px 10px;background:var(--inset);color:var(--muted)}
.badge .led{width:6px;height:6px;border-radius:50%;background:var(--muted2)}
.b-act .led{background:var(--acc)} .b-act{color:#d6dccb}
.b-draft .led{background:var(--e3)}
.b-arch{color:var(--muted2)}
.dotrow{display:flex;align-items:center;gap:8px}
/* эмоции — точка (зелёная) + текст */
.emo{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--muted);font-weight:500}
.emo::before{content:'';width:8px;height:8px;border-radius:50%;background:var(--c)}
.emo.e5{--c:var(--e5)} .emo.e4{--c:var(--e4)} .emo.e3{--c:var(--e3)} .emo.e2{--c:var(--e2)} .emo.e1{--c:var(--e1)}

/* table */
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;color:var(--muted2);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.7px;padding:0 12px 12px;border-bottom:1px solid var(--line-soft)}
.tbl td{padding:14px 12px;border-bottom:1px solid var(--line-soft)}
.tbl tr:last-child td{border-bottom:0}
.tbl tr:hover td{background:#ffffff05}
.tbl .who{display:flex;align-items:center;gap:11px;font-weight:500}
.num-r{text-align:right;font-variant-numeric:tabular-nums;color:var(--muted)}

/* ring / donut — зелёный градиент; центр подстраивается под слой карточки */
.ring{width:190px;height:190px;border-radius:50%;display:grid;place-items:center;position:relative}
.ring::before{content:'';position:absolute;inset:27px;border-radius:50%;background:var(--s-card)}  /* толще «пирог» */
.card.raised .ring::before{background:var(--s-raised)}
.card.deep .ring::before{background:var(--s-deep)}
.ring .in{position:relative;text-align:center}
.ring .in b{font-family:var(--font-display);font-size:30px;font-weight:600;display:block;letter-spacing:-1px}
.ring .in span{color:var(--muted2);font-size:11px}
.legend{display:flex;flex-direction:column;gap:13px}
.legend .it{display:flex;align-items:center;gap:10px;font-size:13.5px;color:#d2d4d9}
.legend .it .led{width:9px;height:9px;border-radius:50%}
.legend .it .v{margin-left:auto;color:var(--muted2);font-variant-numeric:tabular-nums}

/* bars — зелёный градиент */
.bar{display:flex;align-items:center;gap:12px;margin:11px 0}
.bar .nm{width:160px;font-size:13px;color:#d2d4d9}
.bar .tr{flex:1;height:7px;background:var(--inset);border-radius:6px;overflow:hidden}
.bar .fl{height:100%;border-radius:6px;background:linear-gradient(90deg,#39592e,#c8f25a)}
.bar .pc{width:40px;text-align:right;color:var(--muted);font-size:12.5px;font-variant-numeric:tabular-nums}

/* chart card — глубокий чёрный + сетка + изумруд + свечение, заголовок поверх */
.chartcard{position:relative;background:var(--s-deep);border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;min-height:236px;box-shadow:var(--sh)}
.chartcard .grid{position:absolute;inset:0;
  /* ⚠️ правило: вверху линии ЯРЧЕ и толще, книзу градиентно затухают и НЕ касаются кромки графика */
  background-image:linear-gradient(rgba(255,255,255,.13) 1.4px,transparent 1.4px),linear-gradient(90deg,rgba(255,255,255,.13) 1.4px,transparent 1.4px);
  background-size:60px 60px;                       /* крупная сетка */
  -webkit-mask-image:linear-gradient(180deg,#000 0%,#000 13%,transparent 50%);
  mask-image:linear-gradient(180deg,#000 0%,#000 13%,transparent 50%)}  /* ярко сверху → гаснет, не доходя до заливки */
.chartcard .area{position:absolute;left:0;right:0;bottom:0;width:100%;height:66%;display:block}
.chartcard .area path.ln{filter:drop-shadow(0 0 7px rgba(87,226,162,.55))}
.chartcard .ov{position:absolute;top:20px;left:22px;right:22px;z-index:2;display:flex;align-items:flex-start;justify-content:space-between}
.chartcard .ov h3{font-family:var(--font-display);font-size:14px;margin:0 0 8px;font-weight:600;letter-spacing:.4px;text-transform:uppercase}
.chartcard .ov .big{font-family:var(--font-display);font-size:30px;font-weight:600;letter-spacing:-1px}

/* мини-блок (выносной, как в референсе: иконка-чип + метка + число) */
.mini{background:var(--s-card);border:1px solid var(--line-soft);border-radius:14px;padding:16px;box-shadow:var(--sh)}
.mini .ico{width:34px;height:34px;border-radius:10px;background:var(--acc);color:var(--acc-ink);display:grid;place-items:center;margin-bottom:13px}
.mini .ico svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.8}
.mini .l{font-size:10.5px;color:var(--muted2);text-transform:uppercase;letter-spacing:1px;font-weight:600}
.mini .n{font-family:var(--font-display);font-size:23px;font-weight:600;letter-spacing:-1px;margin-top:7px;display:flex;align-items:baseline;gap:8px}
.mini .n .t{font-size:12px;font-family:var(--font-body)}

/* promo (единственный лайм-блок) */
.promo{border-radius:var(--r);padding:22px;color:#141a06;position:relative;overflow:hidden;
  background:linear-gradient(135deg,#d7f56a 0%,#a9e23f 52%,#7cc24a 100%)}
.promo .k{font-size:11px;font-weight:700;letter-spacing:1px;opacity:.6;text-transform:uppercase}
.promo h3{font-family:var(--font-display);margin:8px 0 4px;font-size:30px;font-weight:700;letter-spacing:-1px}
.promo p{margin:0 0 16px;font-size:13px;opacity:.72;max-width:230px;line-height:1.5}
.promo .btn{background:#141a06;color:#d7ff66;border:0}

/* right rail */
.railsec{margin-bottom:26px}
.railsec h4{font-size:11px;margin:0 0 14px;font-weight:700;color:var(--muted);letter-spacing:1.2px;text-transform:uppercase}
.feed{display:flex;gap:12px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.feed:last-child{border-bottom:0}
.feed .ic{width:30px;height:30px;border-radius:9px;display:grid;place-items:center;flex:0 0 auto;background:var(--inset);color:var(--muted)}
.feed .ic svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.6}
.feed .t{font-size:13px;line-height:1.45;color:#d5d7db}
.feed .ts{color:var(--muted2);font-size:11px;margin-top:3px}
.contact{display:flex;align-items:center;gap:11px;padding:9px 0}
.contact .nm{font-size:13.5px}
.contact.on{background:var(--acc);color:var(--acc-ink);border-radius:12px;padding:9px 12px;margin:2px -8px}
.contact .r{margin-left:auto}

/* qa blocks */
.qa{padding:12px 16px;border-radius:12px;margin:10px 0;background:var(--inset)}
.qa.user{background:#1a2412;margin-left:24px}
.qa .role{font-size:10px;font-weight:700;letter-spacing:1px;margin-bottom:5px;text-transform:uppercase}
.qa .role.b{color:var(--muted2)} .qa .role.u{color:var(--e4)}
.qa .tx{font-weight:400;line-height:1.6;color:#dcdee2}
.audio{display:flex;align-items:center;gap:12px;background:var(--inset);border-radius:11px;padding:9px 13px;margin:9px 0;color:var(--muted)}
.audio .play{width:30px;height:30px;border-radius:50%;background:var(--acc);color:var(--acc-ink);display:grid;place-items:center;flex:0 0 auto}
.audio .play svg{width:13px;height:13px;fill:currentColor}
.audio .wave{flex:1;height:22px;background:repeating-linear-gradient(90deg,#33363c 0 2px,transparent 2px 7px);border-radius:4px;opacity:.6}

/* inputs */
.input,.select{background:var(--inset);border:1px solid var(--line);border-radius:10px;padding:11px 13px;color:var(--text);font-size:13px;width:100%;font-family:inherit}
.field{margin-bottom:14px}
.field label{display:block;color:var(--muted);font-size:12px;margin-bottom:7px}
textarea.input{min-height:120px;resize:vertical;line-height:1.6}

/* helpers */
.swatch{height:66px;border-radius:12px;border:1px solid var(--line-soft)}
.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
.spark{width:100%;height:96px;display:block}
hr.sep{border:0;border-top:1px solid var(--line-soft);margin:20px 0}
.pagehint{position:fixed;left:50%;bottom:16px;transform:translateX(-50%);background:var(--s-raised);border:1px solid var(--line);border-radius:var(--rp);padding:8px 18px;font-size:12px;color:var(--muted2);box-shadow:var(--sh);z-index:9}
.pagehint a{color:var(--text)} .pagehint a:hover{color:var(--acc)}

/* ============================================================
   v1.1 — Компактные окна (внутренний скролл + разворот в попап),
   меню «...», бенто, чат с данными, флаги, крупное фото, попап
   ============================================================ */
.bento{display:grid;grid-template-columns:1fr 1fr;gap:18px;grid-auto-rows:240px}
.w2{grid-column:span 2} .h2{grid-row:span 2}

.win{background:var(--s-card);border:1px solid var(--line-soft);border-radius:var(--r);box-shadow:var(--sh);display:flex;flex-direction:column;overflow:hidden;min-height:0}
.win.raised{background:var(--s-raised)} .win.deep{background:var(--s-deep)}
.win-h{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:15px 16px 11px;flex:0 0 auto}
.win-h h3{font-family:var(--font-display);font-size:12.5px;font-weight:600;letter-spacing:.5px;text-transform:uppercase;margin:0}
.win-tools{display:flex;align-items:center;gap:4px;position:relative}
.win-tools .ib{width:28px;height:28px;border-radius:8px;display:grid;place-items:center;color:var(--muted2);cursor:pointer}
.win-tools .ib:hover{background:var(--inset);color:var(--text)}
.win-tools .ib svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.7}
.win-body{padding:0 16px 15px;overflow:auto;flex:1 1 auto;min-height:0}
.win-body::-webkit-scrollbar{width:7px}

.menu{position:absolute;right:0;top:32px;background:var(--s-raised);border:1px solid var(--line);border-radius:11px;padding:6px;min-width:194px;box-shadow:var(--sh);display:none;z-index:8}
.menu.open{display:block}
.menu b{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:8px;font-size:12.5px;font-weight:500;color:#d8dadf;cursor:pointer}
.menu b:hover{background:var(--inset)} .menu b.acc{color:var(--acc)}
.menu b svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.7}
.menu .sep{height:1px;background:var(--line-soft);margin:5px 4px}

/* попап разворота окна */
.popov{position:fixed;inset:0;background:rgba(0,0,0,.90);display:none;place-items:center;z-index:50;padding:34px}
.popov.open{display:grid}
.popwin{background:var(--s-card);border:1px solid var(--line);border-radius:18px;width:min(940px,92vw);max-height:84vh;display:flex;flex-direction:column;box-shadow:0 36px 90px rgba(0,0,0,.6)}
.pop-h{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line-soft)}
.pop-h h3{font-family:var(--font-display);text-transform:uppercase;font-size:14.5px;letter-spacing:.5px;margin:0}
.pop-body{padding:22px;overflow:auto}

/* рельс-личность */
.photoL{width:100%;height:248px;border-radius:16px;background:#23262c;display:grid;place-items:center;color:#c5c8cd;font-family:var(--font-display);font-weight:600;font-size:50px;letter-spacing:-2px;object-fit:cover;object-position:center 22%}  /* выше рамка + не режет лица */
.tgbtn{width:100%;justify-content:center;margin-top:14px;gap:9px}
.tgbtn svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.8}
.railname{font-family:var(--font-display);text-transform:uppercase;font-size:18px;font-weight:600;letter-spacing:-.3px;margin:14px 0 3px;line-height:1.1}

/* флаги */
.flag{display:flex;gap:11px;padding:11px 0;border-bottom:1px solid var(--line-soft)}
.flag:last-child{border:0}
.flag .fi{width:27px;height:27px;border-radius:8px;display:grid;place-items:center;flex:0 0 auto;background:var(--inset)}
.flag .fi svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.7}
.flag.pos .fi{color:var(--acc)} .flag.risk .fi{color:#cd9a6e} .flag.neu .fi{color:var(--muted)}
.flag .ft{font-size:12.8px;line-height:1.42;color:#d6d8dc}
.flag .ft b{color:#fff;font-weight:600}

/* чат с данными */
.chatbox{display:flex;flex-direction:column;flex:1 1 auto;min-height:200px}
.chat-msgs{flex:1 1 auto;min-height:0;overflow:auto;display:flex;flex-direction:column;gap:9px;padding:2px 0}
/* ⚠️ ОКНО ЧАТА — ЖЁСТКОЕ ПРАВИЛО: фиксированная высота, скролл ВНУТРИ, окно НЕ растёт.
   Лента-контейнер: flex:1 + min-height:0 + overflow:auto в flex-колонке с заданной высотой. */
.chatlog{flex:1;min-height:0;overflow-y:auto}
/* Вверху ленты — тап «загрузить историю» (по 50 старых сообщений). Универсально для всех чатов. */
.loadmore{text-align:center;color:var(--muted);font-size:12px;cursor:pointer;padding:9px;border-radius:9px;transition:.14s;flex:0 0 auto}
.loadmore:hover{color:var(--acc);background:var(--inset)}
.msg{font-size:12.7px;line-height:1.45;padding:9px 12px;border-radius:12px;max-width:90%}
.msg.u{background:var(--acc);color:var(--acc-ink);align-self:flex-end;border-bottom-right-radius:4px}
.msg.a{background:var(--inset);color:#d6d8dc;align-self:flex-start;border-bottom-left-radius:4px}
.chat-in{display:flex;gap:8px;align-items:center;margin-top:10px;background:var(--inset);border:1px solid var(--line);border-radius:12px;padding:7px 9px;flex:0 0 auto}
.chat-in input{flex:1;background:none;border:0;outline:0;color:var(--text);font-family:inherit;font-size:13px}
.chat-in .send{width:30px;height:30px;border-radius:9px;background:var(--acc);color:var(--acc-ink);display:grid;place-items:center;flex:0 0 auto;cursor:pointer}
.chat-in .send svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2}

/* мини-чарт внутри окна (эмоциональная кривая) */
.curve{position:relative;height:100%;min-height:150px;border-radius:10px;overflow:hidden;background:var(--s-deep)}
.curve .grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,.13) 1.4px,transparent 1.4px),linear-gradient(90deg,rgba(255,255,255,.13) 1.4px,transparent 1.4px);background-size:58px 58px;-webkit-mask-image:linear-gradient(180deg,#000 0%,#000 13%,transparent 50%);mask-image:linear-gradient(180deg,#000 0%,#000 13%,transparent 50%)}  /* ярче/толще вверху → гаснет вниз (канон) */
.curve svg{position:absolute;inset:0;width:100%;height:100%;display:block}

/* теги-чипы */
.chips{display:flex;flex-wrap:wrap;gap:7px}
.chip{font-size:12px;font-weight:500;padding:4px 10px;border-radius:var(--rp);background:var(--inset);color:#cfd1d6}
.chip.pos{color:var(--acc-ink);background:var(--acc)}
.subh{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:var(--muted2);font-weight:600;margin:14px 0 8px}
.subh:first-child{margin-top:2px}

/* компактный донат для окна */
.ring.sm{width:130px;height:130px}
.ring.sm::before{inset:18px}
.ring.sm .in b{font-size:21px}

/* строка опроса (тап → попап с полной лентой Q&A) */
.srow{display:flex;align-items:center;gap:11px;padding:11px 12px;border-radius:11px;cursor:pointer;background:var(--inset);margin-bottom:9px}
.srow:hover{background:#1d2025}
.srow .chev{flex:0 0 auto;stroke:var(--muted2);fill:none;stroke-width:2}

/* заголовок секции рельса */
.railh{font-family:var(--font-display);font-size:11.5px;text-transform:uppercase;letter-spacing:1px;font-weight:600;color:var(--muted);margin:0 0 6px}

/* 5 KPI в ряд */
.g5{grid-template-columns:repeat(5,1fr)}
/* ПРАВИЛО: статус «активно» — зелёное кольцо/рамка, без слова (экономит место) */
.act-ring{box-shadow:inset 0 0 0 1.5px var(--acc)!important;border-color:transparent!important}

/* кружки опросов: номер + кольцо по статусу + дата активации */
.svdot{display:inline-flex;flex-direction:column;align-items:center;gap:7px;cursor:pointer;width:60px;text-align:center}
.svdot .c{width:46px;height:46px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);font-weight:600;font-size:16px;border:2px solid var(--line2);background:var(--s-card);color:var(--muted);transition:.14s}
.svdot:hover .c{color:#fff}
.svdot.active .c{border-color:var(--acc);color:#fff}          /* активный — лайм */
.svdot.done   .c{border-color:#2f9a62;color:#bfe6cc}          /* завершённый — тёмно-зелёный */
.svdot.cancel .c{border-color:#c0584e;color:#e0a39c}          /* отменённый — красный */
.svdot.stopped .c{border-color:var(--muted2);color:var(--muted)}  /* остановлен — приглушённый */
.svdot.regular .c{border-style:dashed}                         /* регулярный — пунктир (+ цвет статуса) */
.svdot.sel .c{box-shadow:0 0 0 3px rgba(200,242,90,.18)}
.svdot .dt{font-size:10.5px;color:var(--muted2)}

/* ── Окна-списки: по умолчанию тянутся до низа экрана, скролл ВНУТРИ окна ──
   Правило: длинные списки/редакторы не растят страницу — они фиксируются по высоте
   и прокручиваются внутри. Шапка окна неподвижна. Высоту строки задаёт --rows-top
   (отступ сверху до строки окон на конкретном экране). */
.vh-rows{height:calc(100vh - var(--rows-top, 210px))}
.card.scrollcard{display:flex;flex-direction:column;overflow:hidden}
.card.scrollcard>.card-h{flex:none}
.card.scrollcard>.scrollbody{overflow:auto;flex:1;min-height:0;margin:0 -6px;padding:0 6px}

/* ── Рендер markdown-текста, сгенерированного моделью (.md) ──
   Заключения/вердикты/персонажи/промты: ## заголовки, списки, выделения, разделители —
   в типографике фронта. Заголовки — дисплейный шрифт; акценты — лайм/белый. */
.md{font-size:13px;line-height:1.66;color:#ced1d6}
.md>:first-child{margin-top:0}
.md h1,.md h2{font-family:var(--font-display);font-weight:600;font-size:13.5px;letter-spacing:.2px;
  color:var(--text);margin:20px 0 9px;padding-bottom:7px;border-bottom:1px solid var(--line-soft)}
.md h3{font-family:var(--font-display);font-weight:500;font-size:12.5px;color:var(--acc);
  text-transform:uppercase;letter-spacing:.4px;margin:16px 0 7px}
.md p{margin:0 0 11px}
.md ul,.md ol{margin:0 0 11px;padding-left:2px;list-style:none}
.md ol{counter-reset:mdol}
.md li{position:relative;padding-left:22px;margin:6px 0}
.md ul>li::before{content:'';position:absolute;left:4px;top:8px;width:5px;height:5px;border-radius:50%;background:var(--acc)}
.md ol>li{counter-increment:mdol}
.md ol>li::before{content:counter(mdol);position:absolute;left:0;top:0;color:var(--acc);
  font-family:var(--font-display);font-weight:600;font-size:11px;line-height:1.9}
/* таблицы из markdown — чистая «типографская» сетка */
.md table.mdt{width:100%;border-collapse:collapse;margin:2px 0 13px;font-size:12.5px}
.md table.mdt th{text-align:left;font-family:var(--font-display);font-weight:600;font-size:10.5px;
  text-transform:uppercase;letter-spacing:.5px;color:var(--muted);padding:7px 11px;border-bottom:1px solid var(--line)}
.md table.mdt td{padding:7px 11px;border-bottom:1px solid var(--line-soft);color:#cfd1d6;vertical-align:top}
.md table.mdt tr:last-child td{border-bottom:0}
.md table.mdt tbody tr:hover td{background:rgba(255,255,255,.02)}
.md b,.md strong{color:var(--text);font-weight:700}
.md i,.md em{color:#e6e8ec;font-style:italic}
.md hr{border:0;border-top:1px solid var(--line);margin:16px 0}
.md code{background:var(--inset);border-radius:6px;padding:1px 6px;font-size:12px;color:#d7e2c4}
.md blockquote{margin:0 0 11px;padding:8px 14px;border-left:2px solid var(--acc);
  background:rgba(200,242,90,.05);border-radius:0 8px 8px 0;color:#c2c5cb}
