/* ===================== ÉCLAT — cosmograph run-app clone ===================== */
:root {
  --bg: #15181e;
  --chrome: #1a1e26;
  --panel: rgba(26, 30, 38, 0.95);
  --panel-2: rgba(36, 42, 52, 0.92);
  --line: rgba(255, 255, 255, 0.08);
  --line-2: rgba(255, 255, 255, 0.045);
  --txt: #ced2da;
  --txt-2: #8a909c;
  --txt-3: #5d636e;
  --accent: #8a93ff;
  --amber: #e8a23d;
  --r: 7px;
  --ui: 'Inter', system-ui, -apple-system, sans-serif;
  --shadow: 0 8px 34px rgba(0, 0, 0, 0.5);
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html, body { height: 100%; background: var(--bg); }
body { font-family: var(--ui); color: var(--txt); overflow: hidden; -webkit-font-smoothing: antialiased; font-size: 13px; }
::selection { background: rgba(138, 147, 255, 0.35); }
button { font-family: var(--ui); }

#graph { position: fixed; inset: 0; z-index: 1; background: var(--bg); }
#graph canvas { display: block; }

/* ============ LOADING ============ */
#sim-loader { position: fixed; inset: 0; z-index: 60; display: grid; place-items: center; background: var(--bg); transition: opacity .5s ease; }
.ld-box { width: 360px; max-width: 80vw; padding: 26px 30px; background: #1d222b; border: 1px solid var(--line); border-radius: 12px; box-shadow: var(--shadow); }
.ld-ttl { font-size: 19px; font-weight: 600; color: #fff; margin-bottom: 16px; }
.ld-bar { height: 5px; border-radius: 4px; background: rgba(255,255,255,0.08); overflow: hidden; }
.ld-bar i { display: block; height: 100%; width: 40%; border-radius: 4px; background: linear-gradient(90deg, var(--accent), #b1b8ff); animation: ld 1.1s ease-in-out infinite; }
@keyframes ld { 0% { margin-left: -40%; } 100% { margin-left: 100%; } }
.ld-sub { margin-top: 12px; font-size: 12.5px; color: var(--txt-2); }
.fade { opacity: 0 !important; pointer-events: none; }

/* ============ TOP BAR ============ */
.topbar { position: fixed; top: 0; left: 0; right: 0; height: 46px; z-index: 30; display: flex; align-items: center; padding: 0 16px; background: var(--chrome); border-bottom: 1px solid var(--line); }
.topbar::before { content: ''; position: absolute; top: 0; left: 0; right: 0; height: 2px; background: linear-gradient(90deg, transparent, var(--amber) 30%, var(--amber) 70%, transparent); opacity: .85; }
.tb-logo { display: flex; align-items: center; }
.tb-title { position: absolute; left: 50%; transform: translateX(-50%); font-size: 13.5px; font-weight: 600; letter-spacing: .04em; color: #e7e9ee; }
/* (.tb-signin «Войти» и левый рейл .rail удалены — единая страница без них) */
.gtools button[data-tip]::after, .zoomctl button[data-tip]::after { content: attr(data-tip); position: absolute; left: 46px; top: 50%; transform: translateY(-50%); background: #232934; border: 1px solid var(--line); color: var(--txt); font-size: 11px; white-space: nowrap; padding: 5px 9px; border-radius: 6px; opacity: 0; pointer-events: none; transition: opacity .15s; box-shadow: var(--shadow); z-index: 40; }
.gtools button[data-tip]:hover::after { opacity: 1; }
.zoomctl button[data-tip]::after { left: auto; right: 44px; }
.zoomctl button[data-tip]:hover::after { opacity: 1; }

/* ============ INFO PANEL ============ */
.info-panel { position: fixed; left: 50px; top: 46px; bottom: 0; width: 300px; z-index: 22; background: var(--chrome); border-right: 1px solid var(--line); display: flex; flex-direction: column; transition: transform .28s ease; }
.info-panel.collapsed { transform: translateX(-100%); }
.ip-head { display: flex; align-items: center; justify-content: space-between; padding: 13px 14px 10px; }
.ip-h-l { display: flex; align-items: center; gap: 7px; font-size: 11px; letter-spacing: .12em; color: var(--txt-2); font-weight: 600; }
.ip-x { width: 24px; height: 24px; display: grid; place-items: center; background: transparent; border: none; color: var(--txt-3); cursor: pointer; border-radius: 5px; }
.ip-x:hover { background: rgba(255,255,255,0.06); color: var(--txt); }
.ip-search { display: flex; align-items: center; margin: 0 12px 4px; height: 34px; background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 6px; }
.ip-search .seg { font-size: 11.5px; color: var(--txt-2); padding: 0 9px; border-right: 1px solid var(--line); white-space: nowrap; }
.ip-search input { flex: 1; height: 100%; background: transparent; border: none; outline: none; color: var(--txt); font-size: 13px; padding: 0 10px; }
.ip-search input::placeholder { color: var(--txt-3); }
.ip-search:focus-within { border-color: rgba(138,147,255,0.5); }
.suggest { margin: 0 12px; max-height: 280px; overflow-y: auto; background: #232934; border: 1px solid var(--line); border-radius: 6px; display: none; }
.suggest.open { display: block; }
.suggest .row { display: flex; align-items: center; gap: 8px; padding: 7px 9px; cursor: pointer; }
.suggest .row:hover, .suggest .row.active { background: rgba(255,255,255,0.05); }
.suggest .row .dot { width: 8px; height: 8px; border-radius: 50%; flex: none; }
.suggest .row .nm { font-size: 12.5px; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.suggest .row .ct { font-size: 11px; color: var(--txt-3); }

.ip-body { flex: 1; min-height: 0; display: flex; flex-direction: column; overflow: hidden; padding: 12px 14px 14px; }
.ip-default { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.ip-node { flex: 1; min-height: 0; overflow-y: auto; }
.ip-title { font-size: 11px; letter-spacing: .12em; color: var(--txt-2); font-weight: 600; margin-bottom: 8px; }
.ip-desc { font-size: 12.5px; line-height: 1.6; color: var(--txt-2); }
.ip-desc b { color: var(--txt); font-weight: 600; }
.ip-sec { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; margin: 16px 0 9px; }
.chat-msgs { flex: 1; display: flex; flex-direction: column; gap: 7px; min-height: 100px; max-height: none; overflow-y: auto; margin-bottom: 10px; }
.cm { font-size: 13px; line-height: 1.55; padding: 9px 12px; border-radius: 10px; white-space: pre-wrap; }
.cm.u { background: rgba(138,147,255,0.16); color: #dfe2ff; align-self: flex-end; max-width: 92%; }
.cm.a { background: rgba(255,255,255,0.04); border: 1px solid var(--line-2); color: var(--txt); }
.cm.a.thinking { color: var(--txt-3); font-style: italic; }
.cm-cites { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
.cite-chip { font-size: 11px; padding: 3px 8px; border-radius: 6px; border: 1px solid var(--line); background: rgba(0,0,0,0.2); color: var(--txt-2); cursor: pointer; text-decoration: none; }
.cite-chip.node { border-color: rgba(138,147,255,0.5); color: #c9cdff; }
.cite-chip:hover { background: rgba(255,255,255,0.08); color: var(--txt); }
.chat-input { display: flex; gap: 6px; }
.chat-input input { flex: 1; height: 40px; background: rgba(0,0,0,0.25); border: 1px solid var(--line); border-radius: 7px; color: var(--txt); font-size: 13px; padding: 0 12px; outline: none; }
.chat-input input:focus { border-color: rgba(138,147,255,0.5); }
.chat-input button { width: 40px; height: 40px; flex: none; display: grid; place-items: center; background: var(--accent); border: none; border-radius: 7px; color: #fff; cursor: pointer; }
.chat-input button:hover { filter: brightness(1.12); }
.chat-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 9px; }
.chat-chips .chip { font-size: 11px; padding: 4px 9px; border-radius: 20px; background: rgba(255,255,255,0.05); border: 1px solid var(--line); color: var(--txt-2); cursor: pointer; }
.chat-chips .chip:hover { background: rgba(255,255,255,0.09); color: var(--txt); }

/* node detail (inside info panel) */
.nd-chip { display: inline-block; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; font-weight: 600; padding: 4px 9px; border-radius: 20px; border: 1px solid currentColor; margin-bottom: 10px; }
.nd-title { font-size: 21px; font-weight: 600; line-height: 1.12; margin-bottom: 4px; color: #eceef2; }
.nd-meta { font-size: 11.5px; color: var(--txt-3); margin-bottom: 14px; }
.nd-mom { display: flex; align-items: flex-end; gap: 12px; margin-bottom: 10px; }
.nd-mom .big { font-size: 38px; font-weight: 600; line-height: 1; font-variant-numeric: tabular-nums; }
.nd-mom .delta { font-size: 12px; font-weight: 600; padding-bottom: 6px; }
.nd-mom .delta.up { color: #5fcf7f; } .nd-mom .delta.down { color: #ff7a7a; } .nd-mom .delta.flat { color: var(--txt-2); }
.nd-status { margin-left: auto; padding-bottom: 6px; font-size: 10px; letter-spacing: .07em; text-transform: uppercase; }
.nd-status .b { padding: 3px 8px; border-radius: 20px; border: 1px solid currentColor; }
.nd-spark { width: 100%; height: 52px; display: block; margin-bottom: 14px; }
.nd-stats { display: grid; grid-template-columns: repeat(3, 1fr); gap: 7px; margin-bottom: 16px; }
.nd-stats .s { background: rgba(255,255,255,0.03); border: 1px solid var(--line-2); border-radius: 8px; padding: 8px 9px; }
.nd-stats .k { font-size: 9.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--txt-3); margin-bottom: 4px; }
.nd-stats .v { font-size: 16px; font-weight: 600; font-variant-numeric: tabular-nums; }
.nd-sec { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; margin: 2px 0 8px; }
.nd-desc { font-size: 12.5px; line-height: 1.55; color: var(--txt-2); margin-bottom: 16px; }
.nd-rels { display: flex; flex-direction: column; gap: 5px; }
.nd-rel { display: flex; align-items: center; gap: 9px; padding: 7px 9px; border-radius: 7px; background: rgba(255,255,255,0.03); border: 1px solid var(--line-2); cursor: pointer; }
.nd-rel:hover { background: rgba(255,255,255,0.06); }
.nd-rel .dot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.nd-rel .nm { font-size: 12px; flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.nd-rel .ty { font-size: 10px; color: var(--txt-3); white-space: nowrap; }
.nd-rel.mk .nm { flex: none; width: 96px; }
.nd-rel .mkbar { flex: 1; height: 4px; background: rgba(255,255,255,0.08); border-radius: 3px; overflow: hidden; }
.nd-rel .mkbar i { display: block; height: 100%; border-radius: 3px; }
.nd-back { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--accent); cursor: pointer; margin-bottom: 12px; }

/* ============ GRAPH TOOLBAR ============ */
.gtools { position: fixed; left: 364px; top: 56px; z-index: 16; display: flex; flex-direction: column; gap: 4px; background: var(--panel); backdrop-filter: blur(16px); border: 1px solid var(--line); border-radius: var(--r); padding: 4px; box-shadow: var(--shadow); }
.info-panel.collapsed ~ .gtools { left: 64px; }
.gtools button, .zoomctl button { width: 34px; height: 34px; display: grid; place-items: center; background: transparent; border: none; border-radius: 6px; color: #7f868f; cursor: pointer; transition: background .15s, color .15s; position: relative; }
.gtools button svg, .zoomctl button svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.gtools button:hover, .zoomctl button:hover { background: rgba(255,255,255,0.07); color: var(--txt); }
.gtools button.active { color: var(--accent); background: rgba(138,147,255,0.14); }

/* ============ ZOOM ============ */
.zoomctl { position: fixed; right: 14px; top: 56px; z-index: 16; display: flex; flex-direction: column; gap: 6px; }
.zoomctl > button, .zc-pair { background: var(--panel); backdrop-filter: blur(16px); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); }
.zc-pair { display: flex; flex-direction: column; }
.zc-pair button:first-child { border-bottom: 1px solid var(--line-2); }

/* ============ ACTIVE GENRES ============ */
.active-genres { position: fixed; right: 14px; top: 150px; z-index: 15; width: 218px; padding: 10px 11px 8px; background: var(--panel); backdrop-filter: blur(16px); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); }
.active-genres h4, .lg-head { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; margin-bottom: 8px; }
.active-genres h4 span { color: var(--txt-2); }
.ag-row { display: flex; align-items: center; gap: 8px; padding: 3px 4px; border-radius: 5px; cursor: default; }
.ag-row:hover { background: rgba(255,255,255,0.05); }
.ag-sw { width: 8px; height: 8px; border-radius: 2px; flex: none; }
.ag-nm { font-size: 11.5px; color: var(--txt); width: 92px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ag-bar { flex: 1; height: 4px; background: rgba(255,255,255,0.06); border-radius: 3px; overflow: hidden; }
.ag-bar i { display: block; height: 100%; border-radius: 3px; transition: width .4s ease; }
.ag-d { font-size: 11px; width: 12px; text-align: center; color: var(--txt-3); }
.ag-d.up { color: #5fcf7f; } .ag-d.down { color: #ff7a7a; }

/* ============ LEGEND ============ */
.legend { position: fixed; right: 10px; top: 56px; z-index: 19; width: 196px; max-height: 44vh; overflow-y: auto; padding: 9px 9px 8px; background: var(--panel); backdrop-filter: blur(16px); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); }
.legend .item { display: flex; align-items: center; gap: 8px; padding: 3px 5px; border-radius: 5px; cursor: pointer; user-select: none; transition: background .12s, opacity .12s; }
.legend .item:hover { background: rgba(255,255,255,0.05); }
.legend .item.off { opacity: 0.3; }
.legend .item .sw { width: 9px; height: 9px; border-radius: 50%; flex: none; }
.legend .item .nm { font-size: 12px; color: var(--txt); flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.legend .item .cn { font-size: 11px; color: var(--txt-3); font-variant-numeric: tabular-nums; }

/* ============ COUNTERS ============ */
.points-count { position: fixed; left: 364px; bottom: 80px; z-index: 14; font-size: 11.5px; color: var(--txt-2); font-variant-numeric: tabular-nums; pointer-events: none; }
.info-panel.collapsed ~ .points-count { left: 64px; }
.watermark { position: fixed; right: 16px; bottom: 80px; z-index: 14; font-size: 11px; color: var(--txt-3); letter-spacing: .08em; opacity: .7; pointer-events: none; }

/* ============ TIMELINE ============ */
.timeline { position: fixed; left: 0; right: 0; bottom: 0; height: 66px; z-index: 23; display: flex; background: var(--chrome); border-top: 1px solid var(--line); }
.timeline .play { width: 50px; flex: none; display: grid; place-items: center; border-right: 1px solid var(--line-2); cursor: pointer; color: #aeb3bc; transition: color .15s; }
.timeline .play:hover { color: var(--txt); }
.timeline .track { position: relative; flex: 1; padding: 9px 16px 4px; cursor: pointer; }
.timeline .now-readout { position: absolute; top: 7px; right: 16px; font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-2); font-variant-numeric: tabular-nums; pointer-events: none; }
.timeline canvas { width: 100%; height: 40px; display: block; }
.timeline .axis { position: absolute; left: 16px; right: 16px; bottom: 3px; height: 11px; pointer-events: none; }
.timeline .axis span { position: absolute; font-size: 9px; color: var(--txt-3); transform: translateX(-50%); white-space: nowrap; font-variant-numeric: tabular-nums; }
.timeline .playhead { position: absolute; top: 7px; bottom: 14px; width: 1px; background: #fff; box-shadow: 0 0 6px rgba(255,255,255,0.5); pointer-events: none; }
.timeline .playhead::before { content: ''; position: absolute; top: -3px; left: 50%; transform: translateX(-50%); width: 8px; height: 8px; border-radius: 50%; background: #fff; box-shadow: 0 0 8px rgba(255,255,255,0.6); }

/* ============ NODE / CLUSTER LABELS OVERLAY ============ */
#cluster-labels { position: fixed; inset: 0; z-index: 6; pointer-events: none; }
.nlabel { position: absolute; transform: translate(-50%, -50%); white-space: nowrap; font-size: 11px; color: rgba(238,240,244,0.96); background: rgba(16,19,25,0.42); padding: 1px 6px; border-radius: 4px; text-shadow: 0 1px 3px rgba(0,0,0,0.9); opacity: 0; transition: opacity .3s; }
.glabel { position: absolute; transform: translate(-50%, -50%); white-space: nowrap; font-size: 13px; font-weight: 600; text-shadow: 0 0 12px #000, 0 1px 2px #000; transition: opacity .35s; }

/* ============ HOVER TIP ============ */
.hovertip { position: fixed; z-index: 40; pointer-events: none; padding: 6px 10px; border-radius: 6px; background: #232934; border: 1px solid var(--line); font-size: 12px; box-shadow: var(--shadow); opacity: 0; transition: opacity .12s; white-space: nowrap; display: flex; align-items: center; gap: 8px; }
.hovertip.show { opacity: 1; }
.hovertip .dot { width: 7px; height: 7px; border-radius: 50%; flex: none; }
.hovertip .ct { color: var(--txt-3); font-size: 11px; }

::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 6px; border: 2px solid transparent; background-clip: padding-box; }
::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.18); background-clip: padding-box; }

/* real-data: source link in node card */
.nd-src-link{display:inline-block;margin:6px 0 2px;color:#8ab4ff;font-size:12px;text-decoration:none;border-bottom:1px solid rgba(138,180,255,.4)}
.nd-src-link:hover{color:#aecbff}

/* ============ боковая панель: конфигурация / данные / фильтр ============ */
#side-panel { position: fixed; left: 360px; top: 56px; z-index: 21; width: 270px; max-height: calc(100vh - 150px); overflow-y: auto;
  padding: 13px 14px 14px; background: var(--panel); backdrop-filter: blur(16px); border: 1px solid var(--line); border-radius: var(--r); box-shadow: var(--shadow); }
.info-panel.collapsed ~ #side-panel { left: 60px; }
.sp-head { font-size: 11px; letter-spacing: .1em; color: var(--txt-2); margin-bottom: 8px; }
.sp-sub { font-size: 11.5px; line-height: 1.5; color: var(--txt-3); margin-bottom: 11px; }
.sp-stats { display: flex; flex-direction: column; gap: 1px; }
.sp-stat { display: flex; justify-content: space-between; gap: 10px; padding: 7px 0; border-bottom: 1px solid var(--line-2); font-size: 12px; }
.sp-stat .k { color: var(--txt-2); } .sp-stat .v { color: var(--txt); font-weight: 600; text-align: right; }
.sp-toggle { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 0; font-size: 12.5px; color: var(--txt); cursor: pointer; border-bottom: 1px solid var(--line-2); }
.sp-toggle.col { flex-direction: column; align-items: stretch; gap: 7px; }
.sp-toggle input[type=range] { width: 100%; accent-color: var(--accent); }
.sp-toggle input[type=checkbox] { accent-color: var(--accent); width: 16px; height: 16px; cursor: pointer; }
.flt-list { display: flex; flex-direction: column; gap: 1px; margin-bottom: 11px; }
.flt-row { display: flex; align-items: center; gap: 8px; padding: 5px 2px; font-size: 12px; color: var(--txt); cursor: pointer; border-radius: 5px; }
.flt-row:hover { background: rgba(255,255,255,0.05); }
.flt-row.off { opacity: .42; }
.flt-row input[type=checkbox] { accent-color: var(--accent); width: 15px; height: 15px; flex: none; cursor: pointer; }
.flt-row .sw { width: 10px; height: 10px; border-radius: 3px; flex: none; }
.flt-row .nm { flex: 1; } .flt-row .cn { color: var(--txt-3); font-size: 11px; font-variant-numeric: tabular-nums; }
.sp-reset { width: 100%; padding: 8px; background: rgba(138,147,255,0.14); border: 1px solid rgba(138,147,255,0.4); border-radius: 7px; color: #c9cdff; font-size: 12px; cursor: pointer; }
.sp-reset:hover { background: rgba(138,147,255,0.22); }

/* ============ НЕЙРОКУБ — анимированный 3D-куб (компактный: высоту отдали чату) ============ */
.cube-stage { position: relative; height: 60px; flex: none; display: grid; place-items: center; margin: 2px 0 8px; perspective: 640px; }
.cube-aura { position: absolute; width: 52px; height: 52px; border-radius: 50%; background: radial-gradient(circle, rgba(138,147,255,0.40), transparent 68%); filter: blur(15px); opacity: .32; transition: opacity .5s ease; pointer-events: none; }
.cube-label { display: none; position: absolute; bottom: 2px; font-size: 9.5px; letter-spacing: .26em; color: var(--txt-3); transition: color .4s, text-shadow .4s; }
.cube { position: relative; width: 32px; height: 32px; transform-style: preserve-3d; animation: cube-spin 17s linear infinite; will-change: transform; }
.cube-face { position: absolute; width: 32px; height: 32px; background: linear-gradient(135deg, rgba(138,147,255,0.13), rgba(138,147,255,0.03));
  border: 1px solid rgba(138,147,255,0.5); box-shadow: inset 0 0 15px rgba(138,147,255,0.16);
  transition: border-color .45s ease, box-shadow .45s ease, background .45s ease; }
.cf-front  { transform: translateZ(16px); }
.cf-back   { transform: rotateY(180deg) translateZ(16px); }
.cf-right  { transform: rotateY(90deg) translateZ(16px); }
.cf-left   { transform: rotateY(-90deg) translateZ(16px); }
.cf-top    { transform: rotateX(90deg) translateZ(16px); }
.cf-bottom { transform: rotateX(-90deg) translateZ(16px); }
@keyframes cube-spin { from { transform: rotateX(-20deg) rotateY(0); } to { transform: rotateX(-20deg) rotateY(360deg); } }

/* состояние «говорит» — загорается */
.cube-stage.speaking .cube { animation-duration: 4.5s; }
.cube-stage.speaking .cube-face { border-color: rgba(176,183,255,0.95);
  background: linear-gradient(135deg, rgba(138,147,255,0.34), rgba(138,147,255,0.1));
  box-shadow: inset 0 0 22px rgba(138,147,255,0.5), 0 0 14px rgba(138,147,255,0.45); }
.cube-stage.speaking .cube-aura { opacity: 1; animation: aura-pulse 1.15s ease-in-out infinite; }
.cube-stage.speaking .cube-label { color: var(--accent); text-shadow: 0 0 10px rgba(138,147,255,0.6); }
@keyframes aura-pulse { 0%,100% { transform: scale(.82); opacity: .5; } 50% { transform: scale(1.3); opacity: 1; } }
@media (prefers-reduced-motion: reduce) { .cube { animation: none; transform: rotateX(-20deg) rotateY(-35deg); } .cube-stage.speaking .cube-aura { animation: none; } }

/* ============ инлайн-пруфы в ответе Нейрокуба ============ */
.cm.a b { color: #fff; font-weight: 600; }
.cm.a i { color: var(--txt); font-style: italic; }
.cic { cursor: pointer; transition: color .15s, background .15s, border-color .15s; }
.cic.node { color: #aab0ff; border-bottom: 1px dashed rgba(138,147,255,0.55); }
.cic.node:hover { color: #fff; background: rgba(138,147,255,0.16); }
.cic.genre { color: var(--accent); border-bottom: 1px dotted rgba(138,147,255,0.5); }
.cic.genre:hover { color: #fff; }
.cic.src { font-size: .82em; vertical-align: 1px; margin: 0 1px; padding: 1px 5px; border: 1px solid var(--line); border-radius: 4px; color: var(--txt-2); text-decoration: none; white-space: nowrap; }
.cic.src:hover { color: var(--txt); border-color: rgba(138,147,255,0.55); background: rgba(138,147,255,0.08); }
.cic.src.dead { opacity: .55; cursor: default; }
.cic.flat { color: var(--txt); font-weight: 500; }

/* ============ куб: пауза когда не виден (перф на мобиле) ============ */
.info-panel.collapsed .cube, .info-panel.collapsed .cube-aura,
body.cube-off .cube, body.cube-off .cube-aura { animation-play-state: paused !important; }

/* ============ МОБИЛА (≤640px): граф читаем, оверлеи не перекрывают ============ */
@media (max-width: 640px) {
  .info-panel { width: calc(100vw - 50px); z-index: 24; }      /* во всю ширину рядом с рейлом, поверх таймлайна, НО под рейлом */
  .info-panel.collapsed { transform: translateX(calc(-100% - 50px)); }  /* полностью за экран — не торчит поверх рейла */
  .cube-stage { height: 56px; margin: 2px 0 8px; }
  .gtools, .active-genres, .points-count, .watermark { display: none !important; }  /* плавающее — прочь */
  .legend { right: 8px; top: 54px; left: auto; bottom: auto; max-height: 44vh; z-index: 27; }
  #side-panel { left: 50px; right: 0; width: auto; top: 52px; z-index: 27; max-height: calc(100vh - 120px); }
  .info-panel.collapsed ~ #side-panel { left: 50px; }
  .zoomctl { top: auto; bottom: 78px; right: 8px; z-index: 24; }
  body.is-mobile .info-panel:not(.collapsed) ~ .zoomctl { display: none; }  /* зум не нужен поверх открытого чата */
  .tb-title { display: none; }                 /* центральный заголовок наезжает на кнопки — прячем */
  .tb-snd { margin-left: auto; }
}

/* ============ веб-картинки по жанру под ответом ============ */
.cm-imgs-cap { font-size: 10px; letter-spacing: .05em; color: var(--txt-3); margin-top: 11px; margin-bottom: 5px; text-transform: lowercase; }
.cm-imgs { display: flex; gap: 6px; overflow-x: auto; padding-bottom: 4px; scrollbar-width: thin; }
.cm-imgs a { flex: none; line-height: 0; }
.cm-imgs img { height: 86px; width: auto; max-width: 150px; object-fit: cover; border-radius: 7px; border: 1px solid var(--line); display: block; transition: border-color .15s, transform .15s; }
.cm-imgs a:hover img { border-color: rgba(138,147,255,0.6); transform: translateY(-1px); }

/* (.chat-page/.chat-only standalone-чат и .tb-link кросс-ссылки удалены — единая страница) */

/* ============ пульсация куба при ответе + кнопка звука ============ */
.cube-stage.speaking { animation: stage-pulse 1.15s ease-in-out infinite; }
@keyframes stage-pulse { 0%, 100% { transform: scale(1); } 50% { transform: scale(1.06); } }
.tb-snd { display: inline-flex; align-items: center; justify-content: center; width: 32px; height: 32px; margin-left: auto; border: 1px solid var(--line); border-radius: 7px; color: var(--txt-2); background: transparent; cursor: pointer; flex: none; }
.tb-snd svg { width: 16px; height: 16px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.tb-snd:hover { color: var(--txt); border-color: rgba(138,147,255,0.4); }
.tb-snd.on { color: var(--accent); border-color: rgba(138,147,255,0.55); background: rgba(138,147,255,0.12); }
@media (prefers-reduced-motion: reduce) { .cube-stage.speaking { animation: none; } }

/* ============ электрическое кольцо вокруг куба (думает/говорит) — ужато под компактный куб ============ */
.cube-ring { position: absolute; inset: 0; margin: auto; width: 64px; height: 64px; border-radius: 50%; opacity: 0; pointer-events: none; transition: opacity .45s ease;
  background: conic-gradient(from 0deg, transparent 0 50%, rgba(138,147,255,0) 55%, #8a93ff 64%, #c9d0ff 70%, #6fe6ff 77%, rgba(111,230,255,0) 88%, transparent 100%);
  -webkit-mask: radial-gradient(circle, transparent 26px, #000 27px, #000 31px, transparent 32px);
          mask: radial-gradient(circle, transparent 26px, #000 27px, #000 31px, transparent 32px);
  filter: drop-shadow(0 0 7px rgba(138,147,255,0.85)) drop-shadow(0 0 3px rgba(111,230,255,0.6)); }
.cube-ring.r2 { width: 76px; height: 76px;
  background: conic-gradient(from 180deg, transparent 0 56%, #6fe6ff 67%, #b9c0ff 73%, rgba(185,192,255,0) 87%, transparent 100%);
  -webkit-mask: radial-gradient(circle, transparent 32px, #000 33px, #000 37px, transparent 38px);
          mask: radial-gradient(circle, transparent 32px, #000 33px, #000 37px, transparent 38px);
  filter: drop-shadow(0 0 6px rgba(111,230,255,0.7)); }
.cube-stage.speaking .cube-ring { opacity: 1; animation: ring-spin 1.8s linear infinite, ring-flick 1.3s ease-in-out infinite; }
.cube-stage.speaking .cube-ring.r2 { animation: ring-spin-rev 2.6s linear infinite, ring-flick 1.7s ease-in-out infinite; }
@keyframes ring-spin { to { transform: rotate(360deg); } }
@keyframes ring-spin-rev { to { transform: rotate(-360deg); } }
@keyframes ring-flick { 0%, 100% { opacity: 1; } 45% { opacity: .82; } 55% { opacity: .94; } }
@media (prefers-reduced-motion: reduce) { .cube-stage.speaking .cube-ring { animation: none; opacity: .9; } }

/* ============ байер-отчёт: CTA + карточка ============ */
.chat-chips .chip.report { background: rgba(232,162,61,0.12); border-color: rgba(232,162,61,0.4); color: #f0b86a; }
.chat-chips .chip.report:hover { background: rgba(232,162,61,0.2); color: #ffcf8a; }

.report-cta { align-self: flex-start; display: inline-flex; align-items: center; gap: 7px; margin: 2px 0 4px; padding: 7px 13px; font-size: 12.5px; font-weight: 600; color: #15181e; background: linear-gradient(180deg, #f0b86a, #e8a23d); border: none; border-radius: 8px; cursor: pointer; box-shadow: 0 4px 14px rgba(232,162,61,0.28); }
.report-cta svg { stroke: #15181e; }
.report-cta:hover { filter: brightness(1.06); transform: translateY(-1px); }
.report-cta:disabled { opacity: .55; cursor: default; transform: none; }

.report-card { align-self: stretch; background: linear-gradient(180deg, #1b2028, #181c23); border: 1px solid var(--line); border-radius: 12px; padding: 16px 16px 14px; box-shadow: var(--shadow); margin: 4px 0 2px; }
.report-card.loading { display: grid; place-items: center; min-height: 120px; }
.rc-skel { display: flex; align-items: center; gap: 10px; color: var(--txt-2); font-size: 13px; }
.rc-spin { width: 18px; height: 18px; border: 2px solid rgba(255,255,255,0.15); border-top-color: var(--accent); border-radius: 50%; animation: rc-spin .8s linear infinite; }
@keyframes rc-spin { to { transform: rotate(360deg); } }
.rc-err { color: #ff9a9a; font-size: 13px; padding: 6px 2px; }

.rc-head { border-bottom: 1px solid var(--line-2); padding-bottom: 12px; margin-bottom: 12px; }
.rc-badge { display: inline-block; font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; font-weight: 600; color: var(--rc, var(--accent)); border: 1px solid currentColor; border-radius: 20px; padding: 2px 9px; margin-bottom: 9px; opacity: .92; }
.rc-title { font-size: 17px; font-weight: 600; color: #fff; line-height: 1.3; }
.rc-sub { font-size: 12.5px; color: var(--txt-2); margin-top: 4px; line-height: 1.5; }

.rc-mom { margin-bottom: 14px; }
.rc-mom-cap { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 4px; }
.rc-mom-lab { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; }
.rc-growth { font-size: 15px; font-weight: 700; font-variant-numeric: tabular-nums; color: var(--rc, #5fcf7f); }
.rc-growth.down { color: #ff7a7a; }
.report-card canvas, .rc-canvas { width: 100%; height: 80px; display: block; border-radius: 8px; background: rgba(0,0,0,0.18); }

.rc-block { margin-bottom: 14px; }
.rc-sec-h { font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; margin: 12px 0 8px; }
.rc-arch-row { display: flex; flex-wrap: wrap; gap: 6px; }
.rc-arch { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; padding: 5px 10px; border-radius: 20px; background: rgba(138,147,255,0.1); border: 1px solid rgba(138,147,255,0.28); color: var(--txt); }
.rc-arch i { font-style: normal; font-size: 10.5px; color: var(--txt-3); font-variant-numeric: tabular-nums; }

.house-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.house-table th { text-align: left; font-size: 9.5px; letter-spacing: .06em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; padding: 4px 8px 6px; border-bottom: 1px solid var(--line-2); }
.house-table td { padding: 7px 8px; border-bottom: 1px solid var(--line-2); color: var(--txt-2); vertical-align: middle; }
.house-table .ht-nm { color: var(--txt); font-weight: 600; }
.house-table .ht-num { text-align: right; font-variant-numeric: tabular-nums; }
.ht-whcell { width: 92px; }
.ht-wh { display: inline-block; vertical-align: middle; width: 56px; height: 6px; border-radius: 3px; background: rgba(255,255,255,0.08); overflow: hidden; margin-right: 6px; }
.ht-wh i { display: block; height: 100%; background: linear-gradient(90deg, var(--amber), #f0b86a); }
.ht-whn { font-size: 11px; color: var(--txt-3); font-variant-numeric: tabular-nums; }

.whitespace { margin-top: 12px; padding: 11px 12px; border-radius: 9px; background: rgba(232,162,61,0.09); border: 1px solid rgba(232,162,61,0.32); }
.ws-h { font-size: 10px; letter-spacing: .1em; text-transform: uppercase; color: #f0b86a; font-weight: 600; margin-bottom: 5px; }
.ws-rec { font-size: 12.5px; line-height: 1.55; color: var(--txt); }
.ws-rec b { color: #fff; }

.rc-section { margin-bottom: 12px; }
.rc-body { font-size: 13px; line-height: 1.6; color: var(--txt); margin-bottom: 8px; white-space: pre-wrap; }
.rc-body b { color: #fff; }

.rc-sources { margin: 6px 0 4px; }
.rc-src { display: flex; flex-direction: column; gap: 1px; padding: 6px 9px; border-radius: 7px; background: rgba(255,255,255,0.03); border: 1px solid var(--line-2); text-decoration: none; margin-bottom: 5px; }
a.rc-src:hover { border-color: rgba(138,147,255,0.5); background: rgba(138,147,255,0.07); }
.rc-src-t { font-size: 12.5px; color: var(--txt); }
.rc-src-m { font-size: 10.5px; color: var(--txt-3); }

.rc-foot { display: flex; flex-wrap: wrap; align-items: center; gap: 10px; margin-top: 12px; padding-top: 12px; border-top: 1px solid var(--line-2); }
.price-pill { display: inline-block; font-size: 11px; font-weight: 600; color: #f0b86a; background: rgba(232,162,61,0.12); border: 1px solid rgba(232,162,61,0.35); border-radius: 20px; padding: 4px 11px; }
.rc-caveat { font-size: 10.5px; color: var(--txt-3); line-height: 1.4; flex: 1; min-width: 140px; }
.report-pdf { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; color: var(--txt); background: rgba(255,255,255,0.05); border: 1px solid var(--line); border-radius: 7px; padding: 6px 12px; cursor: pointer; }
.report-pdf:hover { background: rgba(138,147,255,0.14); border-color: rgba(138,147,255,0.45); color: #fff; }

/* ============ ИНТЕЛ-ОТЧЁТ в чате (структурный, секции, пруфы) ============ */
.cm.a.intel { background: transparent; border: none; padding: 0; max-width: 100%; align-self: stretch; }
.cm.a.intel.thinking { background: rgba(255,255,255,0.04); border: 1px solid var(--line-2); padding: 11px 14px; }
.intel-report { --rc: rgb(138,147,255); background: linear-gradient(180deg, #1b2028, #181c23); border: 1px solid var(--line); border-radius: 12px; padding: 15px 16px 14px; box-shadow: var(--shadow); margin: 2px 0; position: relative; overflow: hidden; }
.intel-report::before { content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px; background: linear-gradient(180deg, var(--rc), transparent); opacity: .85; }
.intel-head { display: flex; align-items: center; gap: 9px; padding-bottom: 11px; margin-bottom: 4px; border-bottom: 1px solid var(--line-2); }
.intel-badge { font-size: 9.5px; letter-spacing: .1em; text-transform: uppercase; font-weight: 600; color: var(--rc); border: 1px solid currentColor; border-radius: 20px; padding: 2px 9px; opacity: .92; }
.intel-head-t { font-size: 12px; color: var(--txt-2); letter-spacing: .02em; }
.intel-lead { font-size: 13.5px; line-height: 1.62; color: #e7e9ef; margin: 11px 0 4px; }
.intel-lead b { color: #fff; }
.intel-sec { padding: 11px 0 2px; border-top: 1px solid var(--line-2); margin-top: 9px; }
.intel-sec:first-of-type { border-top: none; margin-top: 4px; }
.intel-h { display: flex; align-items: center; gap: 7px; font-size: 10.5px; letter-spacing: .11em; text-transform: uppercase; color: var(--txt-2); font-weight: 600; margin-bottom: 7px; }
.intel-h::before { content: ''; width: 7px; height: 7px; border-radius: 2px; background: var(--rc); opacity: .7; flex: none; }
.intel-sec[data-kind="rise"] .intel-h::before { background: #5fcf7f; opacity: .9; }
.intel-sec[data-kind="peak"] .intel-h::before { background: #f0b86a; opacity: .9; }
.intel-sec[data-kind="cool"] .intel-h::before { background: #7d8896; opacity: .9; }
.intel-sec[data-kind="rotate"] .intel-h::before { background: var(--rc); border-radius: 50%; }
.intel-sec[data-kind="early"] .intel-h::before { background: #c79bff; opacity: .95; }
.intel-sec[data-kind="src"] .intel-h::before,
.intel-sec[data-kind="img"] .intel-h::before { background: var(--txt-3); }
.intel-sec[data-kind="vector"] .intel-h::before { background: #fff; opacity: .85; }
.intel-body { font-size: 13px; line-height: 1.62; color: var(--txt); }
.intel-body b { color: #fff; font-weight: 600; }
.intel-body i { color: var(--txt); font-style: italic; }
.intel-sec[data-kind="vector"] .intel-body { font-size: 13.5px; color: #e3e6ec; }
.intel-report .cm-imgs { margin-top: 2px; }
/* dx-карточки D2–D40 (dash/) внутри текста секций отчёта — блочные, с воздухом */
.intel-report .dx-card { display: block; margin: 10px 0; }
.tldr-txt .dx-card, .twin-li .dx-card { margin: 8px 0 2px; }

/* ===== эталонный шаблон отчёта: Вердикт / Главное / Сигнал ∥ Действие / Методология ===== */
/* Вердикт — крупная шапка карточки (без мини-заголовка секции) */
.intel-sec[data-kind="verdict"] { border-top: none; margin-top: 4px; padding-top: 8px; }
.vd-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 14px; }
.vd-q { font-size: 21px; font-weight: 600; color: #fff; letter-spacing: -.01em; line-height: 1.22; }
.vd-answer { margin-top: 10px; font-size: 15.5px; line-height: 1.5; color: #e7e9ef; }
.vd-answer b { color: #fff; }
.vd-rest { margin-top: 8px; }

/* Главное — тезисы карточками-строками, цифра-герой крупно слева */
.intel-sec[data-kind="tldr"] .intel-h::before { background: #aab0ff; }
.tldr-rows { display: flex; flex-direction: column; gap: 7px; }
.tldr-row { display: flex; align-items: baseline; gap: 13px; padding: 9px 12px;
  background: rgba(255,255,255,0.03); border: 1px solid var(--line-2); border-radius: 10px; }
.tldr-num { flex: none; min-width: 72px; font-size: 19px; font-weight: 700; letter-spacing: -.01em;
  color: #fff; font-variant-numeric: tabular-nums; line-height: 1.15; }
.tldr-num.pos { color: #5fcf7f; }
.tldr-num.neg { color: #ff7a7a; }
.tldr-txt { font-size: 13px; line-height: 1.55; color: var(--txt); min-width: 0; }
.tldr-txt b { color: #fff; }

/* Сигнал ∥ Действие — twin boxes: 2 колонки, на узкой карточке схлопываются в одну */
.intel-sec[data-kind="action"] .intel-h::before { background: #5fcf7f; border-radius: 50%; }
.twin-lead { font-size: 13px; line-height: 1.55; color: var(--txt); margin-bottom: 10px; }
.twin-tail { margin-top: 10px; }
.twin-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 10px; }
.twin-box { border: 1px solid var(--line-2); border-left-width: 3px; border-radius: 10px;
  padding: 11px 13px 9px; background: rgba(255,255,255,0.03); min-width: 0; }
.twin-box.sig { border-left-color: rgba(138,147,255,0.55); }
.twin-box.act { border-left-color: rgba(95,207,127,0.6); }
.twin-h { font-size: 10px; letter-spacing: .13em; text-transform: uppercase; font-weight: 700;
  color: var(--txt-2); margin-bottom: 8px; }
.twin-box.act .twin-h { color: #8fdfa8; }
.twin-li { position: relative; padding-left: 14px; font-size: 12.5px; line-height: 1.52; color: var(--txt); margin-bottom: 7px; }
.twin-li:last-child { margin-bottom: 2px; }
.twin-li::before { content: ''; position: absolute; left: 0; top: .5em; width: 5px; height: 5px; border-radius: 50%; background: rgba(138,147,255,0.8); }
.twin-box.act .twin-li::before { background: #5fcf7f; }
.twin-li b { color: #fff; }

/* Методология — мелкий приглушённый футер карточки */
.intel-sec[data-kind="method"] { padding-bottom: 0; }
.intel-sec[data-kind="method"] .intel-h { color: var(--txt-3); }
.intel-sec[data-kind="method"] .intel-h::before { background: var(--txt-3); }
.intel-sec[data-kind="method"] .intel-body { font-size: 11px; line-height: 1.6; color: var(--txt-3); }
.intel-sec[data-kind="method"] .intel-body b { color: var(--txt-2); font-weight: 600; }

/* =====================================================================
   BI-КАРТОЧКИ ОТЧЁТА ÉCLAT (Stripe/Linear, чистый HTML/CSS, НЕ canvas)
   ВЕРДИКТ → ТРЕНД · РЫНОК · ДЕНЬГИ → ИСТОЧНИКИ
   ===================================================================== */
.bcards { --rc: var(--accent); --buy: #1f9d57; --hold: #d98a00; --exit: #d64242;
  display: flex; flex-direction: column; gap: 14px; font-feature-settings: 'tnum' 1; }

.bc-card { background: linear-gradient(180deg, #1b1f27, #181b22); border: 1px solid var(--line);
  border-radius: 14px; padding: 18px 20px; box-shadow: 0 1px 0 rgba(255,255,255,0.02), 0 10px 30px rgba(0,0,0,0.35); }
.bc-h { font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: var(--txt-3);
  font-weight: 600; margin-bottom: 16px; }
.bc-block { margin-top: 16px; }
.bc-mini-lab { display: block; font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase;
  color: var(--txt-3); font-weight: 600; margin-bottom: 9px; }
.bc-empty { font-size: 13px; color: var(--txt-3); }

/* ---------- ВЕРДИКТ ---------- */
.bc-verdict { padding: 22px 22px 20px; background: linear-gradient(180deg, #1d222b, #191d25); }
.bc-verdict-top { display: flex; align-items: center; justify-content: space-between; gap: 16px; }
.bc-genre { font-size: 26px; font-weight: 600; color: #fff; letter-spacing: -.01em; line-height: 1.1; }
.bc-badge { flex: none; font-size: 14px; font-weight: 700; letter-spacing: .04em; padding: 9px 18px;
  border-radius: 10px; color: #fff; }
.bc-badge.buy  { background: var(--buy);  box-shadow: 0 6px 18px rgba(31,157,87,0.32); }
.bc-badge.hold { background: var(--hold); box-shadow: 0 6px 18px rgba(217,138,0,0.30); }
.bc-badge.exit { background: var(--exit); box-shadow: 0 6px 18px rgba(214,66,66,0.30); }
.bc-verdict-line { margin-top: 14px; font-size: 15px; line-height: 1.55; color: #d8dbe3; }

/* ---------- проза-лид ---------- */
.bc-prose { font-size: 14px; line-height: 1.65; color: #ccd0d9; }
.bc-prose p { margin: 0 0 10px; } .bc-prose p:last-child { margin-bottom: 0; }
.bc-prose b { color: #fff; font-weight: 600; }

/* ---------- ТРЕНД: трекер-стадия ---------- */
.bc-track { display: flex; align-items: center; gap: 0; margin-bottom: 6px; }
.bc-step { display: flex; flex-direction: column; align-items: center; gap: 7px; flex: 1 1 0; min-width: 0; }
.bc-step-dot { width: 13px; height: 13px; border-radius: 50%; background: #2c313b;
  border: 2px solid #3a404c; transition: .2s; }
.bc-step-lab { font-size: 9.5px; letter-spacing: .05em; color: var(--txt-3); font-weight: 600; white-space: nowrap; }
.bc-step-sep { flex: 0 0 auto; width: 18px; height: 2px; background: #2c313b; margin-bottom: 19px; }
.bc-step.done .bc-step-dot { background: var(--rc); border-color: var(--rc); opacity: .55; }
.bc-step.on .bc-step-dot { background: var(--rc); border-color: var(--rc);
  box-shadow: 0 0 0 5px color-mix(in srgb, var(--rc) 22%, transparent); }
.bc-step.on .bc-step-lab { color: #fff; }

.bc-bignum { margin-top: 18px; font-size: 38px; font-weight: 600; letter-spacing: -.02em; line-height: 1;
  display: flex; align-items: baseline; gap: 12px; }
.bc-bignum.pos { color: var(--buy); } .bc-bignum.neg { color: var(--exit); }
.bc-bignum-cap { font-size: 12px; font-weight: 500; letter-spacing: 0; color: var(--txt-3); }

.bc-forecast { margin-top: 16px; font-size: 13.5px; line-height: 1.55; color: #d3d7df; }
.bc-forecast .bc-mini-lab { margin-bottom: 6px; }

/* ---------- РЫНОК: светофор-бар ---------- */
.bc-traffic { display: flex; align-items: center; gap: 14px; }
.bc-traffic-bar { flex: 1 1 auto; height: 12px; border-radius: 7px; background: #23272f; overflow: hidden; }
.bc-traffic-bar i { display: block; height: 100%; border-radius: 7px; transition: width .4s ease; }
.bc-traffic.hot  i { background: linear-gradient(90deg, #b53a3a, var(--exit)); }
.bc-traffic.warm i { background: linear-gradient(90deg, #b87400, var(--hold)); }
.bc-traffic.open i { background: linear-gradient(90deg, #167a44, var(--buy)); }
.bc-traffic-val { flex: none; font-size: 20px; font-weight: 600; color: #fff; }
.bc-traffic-val span { font-size: 11px; font-weight: 500; color: var(--txt-3); margin-left: 4px; }
.bc-sat-verdict { margin-top: 12px; font-size: 13.5px; line-height: 1.5; color: #d3d7df; }

.bc-flow { display: flex; flex-direction: column; gap: 8px; }
.bc-flow-row { display: flex; align-items: center; gap: 10px; font-size: 13.5px; }
.bc-flow-arr { color: var(--rc); font-weight: 700; }
.bc-flow-nm { color: #e3e6ec; }
.bc-flow-pct { margin-left: auto; font-weight: 600; color: var(--txt-2); }

/* ---------- чипы ---------- */
.bc-chips { display: flex; flex-wrap: wrap; gap: 7px; }
.bc-chip { font-size: 12.5px; padding: 5px 12px; border-radius: 20px; background: rgba(255,255,255,0.05);
  border: 1px solid var(--line); color: #d3d7df; }

/* ---------- ДЕНЬГИ: ранг-бары ---------- */
.bc-rank { display: grid; grid-template-columns: minmax(0,1fr) 88px auto; align-items: center;
  gap: 12px; margin-bottom: 9px; font-size: 13.5px; }
.bc-rank:last-child { margin-bottom: 0; }
.bc-rank-nm { color: #e3e6ec; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.bc-rank-track { height: 8px; border-radius: 5px; background: #23272f; overflow: hidden; }
.bc-rank-track i { display: block; height: 100%; border-radius: 5px; }
.bc-rank.up   .bc-rank-track i { background: var(--buy); }
.bc-rank.down .bc-rank-track i { background: var(--exit); }
.bc-rank-pct { font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; }
.bc-rank.up   .bc-rank-pct { color: var(--buy); }
.bc-rank.down .bc-rank-pct { color: var(--exit); }

.bc-stats { display: flex; gap: 28px; margin-top: 18px; flex-wrap: wrap; }
.bc-stat { display: flex; flex-direction: column; gap: 4px; }
.bc-stat-lab { font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; color: var(--txt-3); font-weight: 600; }
.bc-stat b { font-size: 19px; font-weight: 600; color: #fff; }

.bc-checklist { display: flex; flex-direction: column; gap: 8px; }
.bc-check { display: flex; align-items: center; gap: 10px; font-size: 13.5px; color: #e3e6ec; }
.bc-check-box { flex: none; width: 19px; height: 19px; border-radius: 6px; display: grid; place-items: center;
  font-size: 12px; font-weight: 700; color: var(--buy); background: rgba(31,157,87,0.14); border: 1px solid rgba(31,157,87,0.4); }

/* ---------- ИСТОЧНИКИ ---------- */
.bc-sources { padding: 16px 20px; }
.bc-src-line { font-size: 13.5px; color: var(--txt-2); }
.bc-src-line b { font-size: 19px; font-weight: 600; color: #fff; margin-right: 4px; }

/* ============ печать отчёта: только карточка, во всю ширину ============ */
@media print {
  html, body.printing-report { height: auto !important; overflow: visible !important; background: #fff !important; }
  /* карточка вынесена в <body> (см. report.js / attachIntelPdf в chat.js): соседей прячем display:none,
     карточка — в обычном потоке (position:static) → надёжная пагинация на ВСЕ страницы, не только первую */
  body.printing-report > *:not(.report-card.printing):not(.intel-report.printing) { display: none !important; }
  body.printing-report .report-card.printing {
    position: static !important; width: 100%; max-width: 100%; margin: 0; padding: 2mm 0;
    background: #fff !important; color: #111 !important; border: none; box-shadow: none; border-radius: 0;
    max-height: none !important; overflow: visible !important;
  }
  .report-card.printing .rc-title, .report-card.printing .rc-body b, .report-card.printing .house-table .ht-nm, .report-card.printing .ws-rec b { color: #000 !important; }
  .report-card.printing .rc-sub, .report-card.printing .rc-body, .report-card.printing .house-table td, .report-card.printing .ws-rec, .report-card.printing .rc-src-t { color: #222 !important; }
  .report-card.printing .rc-sec-h, .report-card.printing .rc-mom-lab, .report-card.printing .rc-caveat, .report-card.printing .rc-src-m, .report-card.printing .house-table th { color: #666 !important; }
  .report-card.printing .rc-canvas, .report-card.printing canvas { background: #f3f3f5 !important; }
  .report-card.printing .report-cta, .report-card.printing .report-pdf, .report-card.printing .qmark { display: none !important; }
  .report-card.printing .rc-section, .report-card.printing .rc-block, .report-card.printing .rc-mom, .report-card.printing .whitespace, .report-card.printing .house-table tr, .report-card.printing .cm-imgs { break-inside: avoid; page-break-inside: avoid; }
  .report-card.printing .cm-imgs { flex-wrap: wrap; overflow: visible; }
  .report-card.printing .cm-imgs img { height: 110px; max-width: 180px; }

  /* ---- интел-отчёт (карточка .intel-report из чата): светлая тема для бумаги ---- */
  body.printing-report .intel-report.printing {
    position: static !important; width: 100%; max-width: 100%; margin: 0; padding: 2mm 0;
    background: #fff !important; color: #111 !important; border: none; box-shadow: none; border-radius: 0;
    max-height: none !important; overflow: visible !important;
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }
  .intel-report.printing::before { display: none !important; }
  /* весь текст тёмный поверх белого; акценты ниже уточняют оттенки */
  .intel-report.printing, .intel-report.printing * { color: #222 !important; text-shadow: none !important; }
  .intel-report.printing .vd-q, .intel-report.printing .tldr-num,
  .intel-report.printing b, .intel-report.printing .intel-lead { color: #000 !important; }
  .intel-report.printing .intel-h, .intel-report.printing .twin-h,
  .intel-report.printing .intel-head-t, .intel-report.printing .rp-cut-note,
  .intel-report.printing .intel-sec[data-kind="method"] .intel-body { color: #555 !important; }
  /* карточки-подложки: светло-серые с тонкой рамкой */
  .intel-report.printing .intel-sec, .intel-report.printing .intel-head { border-color: #ddd !important; }
  .intel-report.printing .tldr-row, .intel-report.printing .twin-box,
  .intel-report.printing .dx-card, .intel-report.printing .dx-desc,
  .intel-report.printing .rp-tk { background: #f6f6f8 !important; border-color: #ddd !important; }
  /* канвасы печатаются растром со светлыми штрихами — оставляем им тёмный фон */
  .intel-report.printing canvas { background: #1b2028 !important; border-color: #ccc !important; }
  /* интерактив/хром на бумаге не нужен */
  .intel-report.printing .qmark, .intel-report.printing .rp-anchors,
  .intel-report.printing .rp-cut-reset, .intel-report.printing .rp-click-cap,
  .intel-report.printing .intel-pdf, .intel-report.printing button,
  .intel-report.printing .rp-prog, .intel-report.printing .rp-prog-done { display: none !important; }
  /* карточки и графики не рвём между страницами */
  .intel-report.printing .tldr-row, .intel-report.printing .twin-box,
  .intel-report.printing .dx-card, .intel-report.printing .dx-desc,
  .intel-report.printing .rp-mom-sec, .intel-report.printing .rp-cut-sec,
  .intel-report.printing .rp-dash-sec, .intel-report.printing .rp-life-sec,
  .intel-report.printing .cm-imgs { break-inside: avoid; page-break-inside: avoid; }
  .intel-report.printing .cm-imgs { flex-wrap: wrap; overflow: visible; }
  .intel-report.printing .cm-imgs img { height: 110px; max-width: 180px; }
  @page { margin: 12mm; }
}

/* кнопка «Скачать PDF» в шапке интел-отчёта (паттерн .report-pdf) */
.intel-pdf { margin-left: auto; display: inline-flex; align-items: center; gap: 6px; flex: none;
  font-size: 11.5px; font-weight: 600; color: var(--txt); background: rgba(255,255,255,0.05);
  border: 1px solid var(--line); border-radius: 7px; padding: 5px 10px; cursor: pointer; }
.intel-pdf:hover { background: rgba(138,147,255,0.14); border-color: rgba(138,147,255,0.45); color: #fff; }
.intel-pdf:disabled { opacity: .55; cursor: default; }

/* =====================================================================
   ОТЧЁТ В ПОТОКЕ ЧАТА (правая панель .ws/.rp-toc/.rp-empty удалена —
   отчёт-разведка рендерится широкой карточкой-сообщением в #chat-msgs)
   ===================================================================== */
.rp-err { color: #ff9a9a; font-size: 13px; padding: 14px; background: rgba(255,90,90,0.06); border: 1px solid rgba(255,90,90,0.25); border-radius: 10px; }

/* отчёт-разведка как широкая карточка-сообщение в потоке чата */
.cm.a.report-flow { background: transparent; border: none; padding: 0; align-self: stretch; max-width: 100%; }

/* компактная якорь-навигация по секциям отчёта (чипы сверху карточки) */
.rp-anchors { display: flex; flex-wrap: wrap; gap: 5px; margin: 10px 0 0; }
.rp-anchor { display: inline-flex; align-items: center; gap: 6px; font-size: 11px; color: var(--txt-2);
  padding: 4px 9px; border: 1px solid var(--line-2); border-radius: 14px; cursor: pointer; line-height: 1.3; }
.rp-anchor::before { content: ''; width: 6px; height: 6px; border-radius: 2px; background: var(--txt-3); flex: none; opacity: .8; }
.rp-anchor[data-kind="rise"]::before { background: #5fcf7f; }
.rp-anchor[data-kind="peak"]::before { background: #f0b86a; }
.rp-anchor[data-kind="cool"]::before { background: #7d8896; }
.rp-anchor[data-kind="rotate"]::before { border-radius: 50%; background: var(--accent); }
.rp-anchor[data-kind="early"]::before { background: #c79bff; }
.rp-anchor[data-kind="vector"]::before { background: #fff; opacity: .85; }
.rp-anchor[data-kind="img"]::before { background: var(--txt-3); }
.rp-anchor[data-kind="verdict"]::before { background: #fff; }
.rp-anchor[data-kind="tldr"]::before { background: #aab0ff; }
.rp-anchor[data-kind="action"]::before { background: #5fcf7f; border-radius: 50%; }
.rp-anchor[data-kind="method"]::before { background: var(--txt-3); }
.rp-anchor:hover { color: var(--txt); border-color: rgba(138,147,255,0.5); }

/* скелетон-загрузка отчёта (стрим ~30-40с) */
.rp-skeleton { padding: 4px 2px; }
.rp-sk-head { display: flex; align-items: center; gap: 10px; color: var(--txt-2); font-size: 13px; margin-bottom: 18px; }
.rp-sk-spin { width: 16px; height: 16px; border: 2px solid rgba(255,255,255,0.15); border-top-color: var(--accent); border-radius: 50%; animation: rc-spin .8s linear infinite; flex: none; }
.rp-sk-bar { height: 12px; border-radius: 6px; margin-bottom: 12px; background: linear-gradient(90deg, rgba(255,255,255,0.04), rgba(255,255,255,0.09), rgba(255,255,255,0.04)); background-size: 200% 100%; animation: rp-sheen 1.4s ease-in-out infinite; }
.rp-sk-bar.w90 { width: 90%; } .rp-sk-bar.w80 { width: 80%; } .rp-sk-bar.w75 { width: 75%; } .rp-sk-bar.w70 { width: 70%; } .rp-sk-bar.w60 { width: 60%; } .rp-sk-bar.w50 { width: 50%; }
.rp-sk-chart { height: 96px; border-radius: 10px; margin: 18px 0; background: linear-gradient(90deg, rgba(255,255,255,0.04), rgba(255,255,255,0.08), rgba(255,255,255,0.04)); background-size: 200% 100%; animation: rp-sheen 1.4s ease-in-out infinite; }
@keyframes rp-sheen { 0% { background-position: 200% 0; } 100% { background-position: -200% 0; } }

/* прогресс-карточка долгого отчёта: стадия + секундомер + оценка (спиннер = .rp-sk-spin) */
.rp-prog { display: flex; align-items: center; gap: 11px; padding: 11px 13px; margin-bottom: 12px;
  background: rgba(255,255,255,0.04); border: 1px solid var(--line-2); border-radius: 10px; }
.rp-prog-main { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.rp-prog-stage { font-size: 12.5px; color: var(--txt); line-height: 1.35; }
.rp-prog-est { font-size: 10.5px; color: var(--txt-3); }
.rp-prog-time { font-size: 13px; font-weight: 600; color: var(--txt-2); font-variant-numeric: tabular-nums; letter-spacing: .03em; flex: none; }
.rp-prog.err { border-color: rgba(255,90,90,0.3); background: rgba(255,90,90,0.05); }
.rp-prog.err .rp-sk-spin { animation: none; border-color: rgba(255,90,90,0.35); border-top-color: #ff7a7a; }
.rp-prog.err .rp-prog-stage { color: #ff9a9a; }
/* по завершении карточка сворачивается в строку */
.rp-prog-done { font-size: 11px; color: var(--txt-3); margin-bottom: 10px; }
/* прогресс внутри байер-карточки (.report-card.loading = grid place-items:center) */
.report-card.loading .rp-prog { width: 100%; margin: 0; }
.report-card .rp-prog-done { margin-bottom: 8px; }
/* подсказка-сообщение после отчёта: «спрашивайте по нему прямо здесь» */
.cm.a.rp-hint { font-size: 12.5px; color: var(--txt-2); border-left: 2px solid rgba(138,147,255,0.5); background: rgba(138,147,255,0.05); }

/* блок графиков импульса в отчёте */
.rp-mom-sec .intel-h { position: relative; }
.rp-mom-growth { margin-left: auto; font-size: 13px; font-weight: 700; font-variant-numeric: tabular-nums; color: #5fcf7f; letter-spacing: 0; text-transform: none; }
.rp-mom-growth.down { color: #ff7a7a; }
.rp-mom-canvas { width: 100%; height: 132px; display: block; border-radius: 10px; background: rgba(0,0,0,0.2); border: 1px solid var(--line-2); }
.rp-mom-legend { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 9px; }
.rp-leg { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; color: var(--txt-2); }
.rp-leg.lead { color: var(--txt); font-weight: 600; }
.rp-leg i { width: 16px; height: 3px; border-radius: 2px; display: inline-block; }
.rp-leg.lead i { height: 4px; }

/* блок «вырезка из графа» — интерактивный мини-граф */
.rp-cut-note { font-size: 11px; color: var(--txt-3); margin-bottom: 9px; line-height: 1.5; }
.rp-cut-lg { white-space: nowrap; margin-left: 6px; }
.rp-cut-lg.fash { color: rgba(206,210,218,0.85); }
.rp-cut-lg.nonf { color: var(--txt-3); }
.rp-cut-stage { position: relative; }
.rp-cut-canvas { width: 100%; height: 260px; display: block; border-radius: 10px; background: radial-gradient(120% 120% at 50% 30%, rgba(138,147,255,0.05), rgba(0,0,0,0.22)); border: 1px solid var(--line-2); cursor: grab; }
.rp-cut-canvas:active { cursor: grabbing; }
.rp-cut-reset { position: absolute; top: 8px; right: 8px; width: 26px; height: 26px; border-radius: 7px; border: 1px solid var(--line); background: rgba(20,24,30,0.8); color: var(--txt-2); font-size: 14px; line-height: 1; cursor: pointer; display: grid; place-items: center; }
.rp-cut-reset:hover { color: #fff; border-color: rgba(138,147,255,0.5); }
.rp-cut-tip { position: absolute; min-width: 150px; max-width: 200px; padding: 9px 11px; background: #1d222b; border: 1px solid var(--line); border-radius: 9px; box-shadow: var(--shadow); z-index: 4; pointer-events: auto; }
.rp-tip-lab { font-size: 12.5px; font-weight: 600; color: #fff; line-height: 1.3; margin-bottom: 5px; }
.rp-tip-meta { display: flex; align-items: center; gap: 7px; font-size: 10.5px; color: var(--txt-2); margin-bottom: 3px; }
.rp-tip-dot { padding: 1px 7px; border-radius: 10px; border: 1px solid rgba(95,207,127,0.5); color: #7fe0a0; font-size: 9.5px; }
.rp-tip-dot.nonf { border-color: var(--line); color: var(--txt-3); }
.rp-tip-reach { font-size: 11px; color: var(--txt-2); margin-bottom: 7px; font-variant-numeric: tabular-nums; }
.rp-tip-open { display: inline-block; font-size: 11px; color: var(--accent); text-decoration: none; }
.rp-tip-open:hover { color: #fff; }

/* универсальные дашборд-блоки в отчёте */
.rp-dash-canvas { width: 100%; display: block; border-radius: 10px; background: rgba(0,0,0,0.2); border: 1px solid var(--line-2); }
.rp-dash-legend { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 8px; }

/* часы жизненного цикла / биржа */
.rp-life-canvas { width: 100%; height: 300px; display: block; border-radius: 10px; background: radial-gradient(120% 120% at 50% 50%, rgba(138,147,255,0.05), rgba(0,0,0,0.22)); border: 1px solid var(--line-2); }
.rp-ticker { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; max-height: 96px; overflow-y: auto; }
.rp-tk { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--txt-2); padding: 3px 8px; border: 1px solid var(--line-2); border-radius: 14px; background: rgba(255,255,255,0.02); cursor: pointer; transition: border-color .15s, background .15s; }
.rp-tk:hover { border-color: rgba(138,147,255,0.5); background: rgba(138,147,255,0.07); }
.rp-tk i { width: 7px; height: 7px; border-radius: 2px; flex: none; }
.rp-tk b { color: #5fcf7f; font-variant-numeric: tabular-nums; }
.rp-tk.down b { color: #ff7a7a; }
.rp-tk-st { font-style: normal; font-size: 9px; letter-spacing: .04em; color: var(--txt-3); }
.rp-tk-st.rising { color: #5fcf7f; }
.rp-tk-st.peak { color: #f0b86a; }
.rp-tk-st.cooling { color: #7d8896; }

/* affordance-подпись под кликабельными графиками отчёта */
.rp-click-cap { margin-top: 6px; font-size: 10px; color: var(--txt-3); letter-spacing: .03em; }

/* follow-up ответ в левом чате — компактный, со ссылкой «про этот отчёт» */
.cm.a.followup { border-left: 2px solid rgba(138,147,255,0.5); background: rgba(138,147,255,0.05); }
.cm.a.followup::before { content: 'про отчёт'; display: block; font-size: 9px; letter-spacing: .1em; text-transform: uppercase; color: var(--accent); margin-bottom: 5px; opacity: .85; }

/* =====================================================================
   ЧАТ-ПАНЕЛЬ СЛЕВА (единая страница): режимы через --chatw на body.
   body[data-chat] есть только на index.html — легаси-страницы не задеты.
   collapsed (таб у края) / normal 400px / wide 70vw / full 100vw.
   .dash/.timeline/.legend позиционируются через var(--chatw) (см. index.html).
   ===================================================================== */
body[data-chat] { --chatw: 400px; }
body[data-chat="collapsed"] { --chatw: 0px; }
body[data-chat="wide"] { --chatw: 70vw; }
body[data-chat="full"] { --chatw: 100vw; }

body[data-chat] .info-panel { left: 0; top: 46px; bottom: 0; width: var(--chatw); z-index: 24;
  transition: width .3s ease, transform .3s ease; }
body[data-chat="collapsed"] .info-panel { width: 400px; transform: translateX(-101%); pointer-events: none; }
body[data-chat="collapsed"] .info-panel .cube,
body[data-chat="collapsed"] .info-panel .cube-aura { animation-play-state: paused !important; }  /* перф: куб не виден */

/* шапка панели: «НЕЙРОКУБ» + Новый диалог + кнопки режимов */
.ip-actions { margin-left: auto; display: flex; align-items: center; gap: 3px; }
.ip-actions .ip-x { width: 26px; height: 26px; }
.ip-actions .ip-x.on { color: var(--accent); background: rgba(138,147,255,0.12); }
.ip-newdlg { height: 26px; padding: 0 10px; margin-right: 5px; font-size: 11.5px; color: #c9cdff;
  background: rgba(138,147,255,0.12); border: 1px solid rgba(138,147,255,0.4); border-radius: 7px; cursor: pointer; }
.ip-newdlg:hover { background: rgba(138,147,255,0.2); color: #fff; }

/* свёрнутая панель → узкий вертикальный таб «НЕЙРОКУБ» у левого края */
.chat-tab { position: fixed; left: 0; top: 50%; transform: translateY(-50%); z-index: 26; display: none;
  writing-mode: vertical-rl; padding: 16px 7px; font-size: 10px; font-weight: 600; letter-spacing: .24em;
  color: var(--txt-2); background: var(--chrome); border: 1px solid var(--line); border-left: none;
  border-radius: 0 9px 9px 0; cursor: pointer; box-shadow: var(--shadow); }
.chat-tab:hover { color: var(--accent); background: #232934; }
body[data-chat="collapsed"] .chat-tab { display: block; }

/* мобила (≤640px): панель = оверлей на всю ширину, дашборд под ней */
@media (max-width: 640px) {
  body[data-chat] { --chatw: 0px; }
  body[data-chat] .info-panel { width: 100vw; z-index: 28; }
  body[data-chat="collapsed"] .info-panel { transform: translateX(-101%); }
}

/* ============ ИНТРО-ГЕРОЙ (Нейрокуб) — полноэкранный оверлей при входе ============ */
.hero { position: fixed; inset: 0; z-index: 60; display: flex; flex-direction: column;
  align-items: center; justify-content: center; gap: 40px; padding: 24px;
  background: radial-gradient(circle at 50% 36%, #12141f 0%, #07080e 72%);
  transition: opacity .7s ease, transform .7s ease; }
body.hero-done .hero { opacity: 0; transform: translateY(-46px); pointer-events: none; }
/* scale не раздвигает layout-бокс — компенсируем отступами, чтобы текст не налезал на куб */
.hero-cubewrap { transform: scale(3.5); transform-origin: center; margin: 11vh 0 21vh; }
@media (max-width: 640px) { .hero-cubewrap { transform: scale(2.3); margin: 8vh 0 13vh; } .hero-type { font-size: 18px !important; } }
.hero .cube-stage { height: 132px; margin: 0; }
.hero .cube-aura { opacity: .55; width: 108px; height: 108px; }
.hero .cube { animation: cube-spin 14s linear infinite; }
.hero .cube-label { display: none; }
/* интро-куб остаётся крупным: базовый куб панели ужат до 32px, здесь возвращаем 58px */
.hero .cube, .hero .cube-face { width: 58px; height: 58px; }
.hero .cf-front  { transform: translateZ(29px); }
.hero .cf-back   { transform: rotateY(180deg) translateZ(29px); }
.hero .cf-right  { transform: rotateY(90deg) translateZ(29px); }
.hero .cf-left   { transform: rotateY(-90deg) translateZ(29px); }
.hero .cf-top    { transform: rotateX(90deg) translateZ(29px); }
.hero .cf-bottom { transform: rotateX(-90deg) translateZ(29px); }
.hero-type { min-height: 3.4em; max-width: 680px; text-align: center; font-size: 23px;
  line-height: 1.5; font-weight: 500; color: #e9ebf6; letter-spacing: .005em; }
.hero-type .red { color: #ff5b67; text-shadow: 0 0 18px rgba(255,91,103,.35); }
.hero-caret { display: inline-block; width: 2px; height: 1.05em; margin-left: 3px;
  background: var(--accent, #8a93ff); vertical-align: -3px; animation: hero-blink 1.05s steps(1) infinite; }
@keyframes hero-blink { 50% { opacity: 0; } }
.hero-cta { display: inline-flex; flex-direction: column; align-items: center; gap: 6px;
  background: none; border: 0; cursor: pointer; color: var(--accent, #8a93ff);
  font-size: 15px; font-weight: 600; letter-spacing: .12em; text-transform: uppercase;
  opacity: 0; transform: translateY(8px); transition: opacity .6s ease, transform .6s ease; }
.hero-cta.show { opacity: 1; transform: translateY(0); }
.hero-cta:hover { color: #aab0ff; }
.hero-arrow { font-size: 22px; line-height: 1; animation: hero-bounce 1.6s ease-in-out infinite; }
@keyframes hero-bounce { 0%,100% { transform: translateY(0); } 50% { transform: translateY(7px); } }
@media (prefers-reduced-motion: reduce) {
  .hero .cube { animation: none; transform: rotateX(-20deg) rotateY(-35deg); }
  .hero-arrow { animation: none; } .hero-caret { animation: none; }
}

/* ============ «?»-подсказки (help.js): серый кружок + поповер-объяснение ============ */
.qmark { display: inline-flex; align-items: center; justify-content: center; width: 14px; height: 14px;
  margin-left: 6px; padding: 0; flex: none; vertical-align: middle; border-radius: 50%;
  border: 1px solid currentColor; background: transparent; color: var(--txt-3);
  font-size: 9px; line-height: 1; font-weight: 600; font-family: var(--ui); cursor: pointer;
  pointer-events: auto;                 /* кликабелен даже внутри .plabel{pointer-events:none} */
  text-transform: none; letter-spacing: 0; transition: color .15s; }
.qmark:hover, .qmark.on { color: var(--txt); }
.qpop { position: fixed; z-index: 90; max-width: 280px; padding: 10px 12px; background: #232934;
  border: 1px solid var(--line); border-radius: 9px; box-shadow: var(--shadow);
  font-size: 12px; line-height: 1.55; color: var(--txt);
  text-transform: none; letter-spacing: normal; font-weight: 400; }
.qpop-h { font-size: 10.5px; font-weight: 600; letter-spacing: .08em; text-transform: uppercase;
  color: var(--txt-2); margin-bottom: 5px; }
.qpop-b b { color: #aab0ff; }
/* «?» на таймлайне — правый верхний угол трека, рядом с readout (он кончается на right:16px) */
.timeline .track .qmark { position: absolute; top: 5px; right: 1px; z-index: 2; }
/* строка-пояснение над чипами примеров */
.chips-cap { display: flex; align-items: center; font-size: 11px; color: var(--txt-3); margin-top: 10px; }
.chips-cap + .chat-chips { margin-top: 6px; }
