/* assets/css/charts.css — PLOTTER system. Requires base.css tokens. Square corners only. */
:root{--fc-ink:var(--red2);--fc-ink-solid:var(--red);--fc-ghost:rgba(255,255,255,.06);--fc-ghost2:rgba(255,255,255,.10);
  --fc-grid-lbl:rgba(255,255,255,.40);--fc-head:#f5325c;--fc-glow:rgba(245,50,92,.55);
  --fc-dur:900ms;--fc-ease:cubic-bezier(.22,1,.36,1);--fc-spring:cubic-bezier(.34,1.56,.64,1)}

/* wrapper + FIG-frame + readout (credibility furniture) */
.fc-chart{position:relative;margin:22px 0;background:var(--panel);border:1px solid var(--line);padding:18px 14px}
.fc-chart svg{width:100%;height:auto;display:block;overflow:visible;touch-action:pan-y}
.fc-fig{position:absolute;top:8px;left:10px;font:600 10px/1 var(--mono);letter-spacing:.12em;color:var(--muted);text-transform:uppercase;display:flex;align-items:center;gap:6px;z-index:2}
.fc-crop{width:8px;height:8px;border-top:1px solid var(--red);border-left:1px solid var(--red)}
.fc-readout{margin-top:12px;font:500 11.5px/1.5 var(--mono);color:var(--muted);letter-spacing:.02em}
.fc-readout .fc-dot{margin:0 8px;color:var(--line2)}
/* footer: readout + actions в ОДНОЙ линии (подпись слева, EMBED/PNG справа) */
.fc-foot{display:flex;align-items:center;gap:16px;margin-top:12px;flex-wrap:wrap}
.fc-foot .fc-readout{margin-top:0}
.fc-actions{display:flex;align-items:center;gap:16px;margin-left:auto}   /* margin-left:auto → всегда прижаты вправо, даже если подпись пустая */
.fc-embed{position:static;background:none;border:none;padding:0;opacity:1;
  font:600 10.5px var(--mono);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);cursor:pointer;transition:color .13s}
.fc-embed:hover,.fc-embed:focus-visible{color:var(--fc-ink)}
/* EMBED modal */
.fc-modal{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .18s}
.fc-modal.on{opacity:1}
.fc-modal-bd{position:absolute;inset:0;background:rgba(6,6,8,.72);backdrop-filter:blur(3px)}
.fc-modal-panel{position:relative;width:min(560px,100%);background:var(--panel);border:1px solid var(--line2);padding:22px;transform:translateY(8px);transition:transform .18s}
.fc-modal.on .fc-modal-panel{transform:none}
.fc-modal-h{display:flex;justify-content:space-between;align-items:center;font:800 16px var(--sans);color:#fff;margin-bottom:6px}
.fc-modal-x{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;line-height:1;padding:2px 6px}
.fc-modal-x:hover{color:var(--fc-ink)}
.fc-modal-note{font:400 13px/1.5 var(--serif);color:var(--muted);margin:0 0 14px}
.fc-modal-code{width:100%;height:118px;resize:vertical;background:var(--bg);border:1px solid var(--line2);color:var(--txt);font:500 12px/1.5 var(--mono);padding:10px;box-sizing:border-box}
.fc-modal-code:focus{outline:1px solid var(--fc-ink);outline-offset:1px}
.fc-modal-actions{display:flex;align-items:center;gap:12px;margin-top:14px}
.fc-modal-copy{background:var(--fc-ink-solid);border:none;color:#fff;font:700 13px var(--sans);padding:10px 18px;cursor:pointer}
.fc-modal-copy:hover{background:var(--fc-ink)}
.fc-modal-open{font:600 12px var(--mono);color:var(--muted);text-decoration:none}
.fc-modal-open:hover{color:var(--fc-ink)}
@media(pointer:fine){.fc-area,.fc-col{cursor:crosshair}}
/* убрать белую focus-рамку при тапе/клике; клавиатурный фокус оставить (focus-visible) */
.fc-chart :focus{outline:none}
.fc-chart :focus-visible{outline:1px solid var(--fc-ink);outline-offset:2px}
/* compact-колонки: значение появляется НАД колонкой при наведении */
.fc-compact.fc-col .fc-colg:hover .fc-vl{display:block}

/* shared plotter-head + grid + labels */
.fc-head rect{fill:var(--fc-head)}
.fc-head .fc-hx{stroke:var(--fc-head);stroke-width:1;vector-effect:non-scaling-stroke}
.fc-gl{stroke:var(--fc-ghost);stroke-width:1;stroke-dasharray:1 4;vector-effect:non-scaling-stroke}
.fc-base{stroke:var(--fc-ghost2);stroke-width:1;vector-effect:non-scaling-stroke}
.fc-yl{fill:var(--fc-grid-lbl);font:11px var(--mono)}
.fc-xl{fill:var(--muted);font:700 11px var(--sans)}
.fc-vl{fill:#fff;font:600 12px var(--mono);font-variant-numeric:tabular-nums}
.fc-lead{stroke:var(--fc-ink);stroke-width:1;vector-effect:non-scaling-stroke;opacity:.55}
.fc-ceil{stroke:var(--fc-ghost2);stroke-dasharray:4 5;stroke-width:1;vector-effect:non-scaling-stroke}
.fc-ceill{fill:var(--muted);font:600 10px var(--mono)}

/* AREA */
.fc-pt{fill:var(--bg);stroke:var(--fc-ink);stroke-width:2;vector-effect:non-scaling-stroke}
.fc-area:not(.is-in) .fc-line{stroke-dasharray:var(--len,2000);stroke-dashoffset:var(--len,2000)}
.fc-area.is-in .fc-line{transition:stroke-dashoffset var(--fc-dur) var(--fc-ease);stroke-dashoffset:0}
.fc-area:not(.is-in) .fc-wipe{height:0}
.fc-area.is-in .fc-wipe{transition:height 500ms ease-out .5s}
.fc-area:not(.is-in) .fc-pt,.fc-area:not(.is-in) .fc-vl{opacity:0}
.fc-area.is-in .fc-pt,.fc-area.is-in .fc-vl{transition:opacity .3s ease .6s;opacity:1}
.fc-numeral-bg{fill:rgba(245,50,92,.10);font:900 clamp(80px,15vw,200px) var(--sans);letter-spacing:-.04em;pointer-events:none}
.fc-scrub{position:absolute;top:14%;left:50%;transform:translateX(-50%);font:900 clamp(24px,4vw,58px) var(--sans);color:var(--fc-ink);pointer-events:none;opacity:0;white-space:nowrap;letter-spacing:-.02em;text-shadow:0 2px 12px rgba(10,10,11,.7)}
.fc-hero.is-scrub .fc-scrub{opacity:1}

/* BARS — editorial ranked list, единый язык с area/stat (mono, ink-дисциплина) */
.fc-bars{display:flex;flex-direction:column;gap:16px;padding:24px 14px 30px}
.fc-bar{display:flex;gap:14px;align-items:flex-start;outline:none}
.fc-bar-rank{flex:0 0 24px;align-self:stretch;writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg);font:900 20px var(--sans);letter-spacing:-.03em;color:var(--muted);display:flex;align-items:center;justify-content:center}
.fc-bar-main{flex:1;min-width:0}
.fc-bar-top{display:flex;align-items:baseline;gap:0;margin-bottom:7px}
.fc-bar-lbl{font:800 15px var(--sans);color:#fff;transition:color .12s;white-space:nowrap}
.fc-bar-dots{flex:1;border-bottom:1.5px dotted var(--line2);margin:0 12px;transform:translateY(-4px);min-width:16px}
.fc-bar-val{font:600 13px var(--mono);color:#fff;font-variant-numeric:tabular-nums;white-space:nowrap}
.fc-bar-track{height:7px;background:var(--panel2);overflow:hidden}
.fc-bar-fill{position:relative;height:100%;background:var(--fc-ink-solid);min-width:4px;transform-origin:left}
.fc-bar-edge{position:absolute;right:0;top:0;bottom:0;width:2px;background:var(--fc-ink)}
.fc-bar-sub{font:italic 12px var(--serif);color:var(--muted);white-space:nowrap;margin-left:10px;align-self:baseline}
/* #1 — акцент цветом + тонкое подчёркивание, НЕ толщиной */
.fc-bar.is-ink .fc-bar-rank,.fc-bar.is-ink .fc-bar-val{color:var(--fc-ink)}
.fc-bars:not(.is-in) .fc-bar-fill{transform:scaleX(0)}
.fc-bars.is-in .fc-bar-fill{transition:transform 700ms var(--fc-spring);transition-delay:calc(var(--i)*80ms);transform:scaleX(1)}
/* hover — только название краснеет; соседи НЕ трогаются (без моргания) */
.fc-bar:hover .fc-bar-lbl,.fc-bar:focus .fc-bar-lbl{color:var(--fc-ink)}

/* DONUT (plotter-drawn arc, self-quantifying guide) */
.fc-donut-wrap{display:flex;gap:24px;align-items:center;flex-wrap:wrap;padding-top:14px}
.fc-donut-svg{max-width:240px;flex:0 0 auto}
.fc-guide{stroke:var(--fc-ghost);stroke-width:1;vector-effect:non-scaling-stroke}
.fc-gtick{stroke:var(--line2);stroke-width:1;vector-effect:non-scaling-stroke}
.fc-gtl{fill:var(--muted);font:10px var(--mono)}
.fc-seg{stroke-linecap:butt;transition:opacity .2s}
.fc-seg.is-ink{filter:drop-shadow(0 0 4px var(--fc-glow))}
.fc-donut-num{fill:#fff;font:900 40px var(--sans);letter-spacing:-.02em}
.fc-donut-cap{fill:var(--muted);font:700 10px var(--mono);letter-spacing:.08em;text-transform:uppercase}
.fc-donut:not(.is-in) .fc-seg{stroke-dashoffset:calc(var(--c,600) * 1px)!important}
.fc-donut.is-in .fc-seg{transition:stroke-dashoffset 1s ease-out;transition-delay:calc(var(--i,0)*.12s)}
.fc-legend{flex:1;min-width:180px;font-family:var(--mono)}
.fc-leg-row{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px solid var(--line);font-size:12px;cursor:pointer}
.fc-sw{width:10px;height:10px;flex:none}.fc-leg-l{flex:1;color:#fff}.fc-leg-p{color:var(--fc-ink);font-weight:600}.fc-leg-n{color:var(--muted)}
.fc-donut.fc-focus .fc-seg:not(.is-hov){opacity:.25}
.fc-strip{display:flex;height:26px;margin-top:12px;gap:3px}
.fc-strip-seg{position:relative;min-width:2px;cursor:pointer;transition:filter .12s}.fc-strip-seg:hover{filter:brightness(1.2)}.fc-strip-seg.is-ink{outline:1px solid var(--fc-ink)}
.fc-strip-p{position:absolute;top:-16px;left:0;font:600 10px var(--mono);color:var(--muted)}

/* STAT (odometer) */
.fc-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1px;background:var(--line);border:1px solid var(--line);margin:26px 0}
.fc-stat{position:relative;background:var(--panel);padding:20px 18px}
.fc-stat.is-ink{border-top:3px solid var(--red)}
.fc-stat-tag{font:700 10px var(--mono);letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.fc-stat-num{font:900 clamp(24px,3vw,44px) var(--sans);letter-spacing:-.02em;line-height:1;color:#fff;display:flex}
.fc-stat.is-ink .fc-stat-num{color:var(--fc-ink)}
.fc-digit{display:inline-block;height:1em;overflow:hidden;vertical-align:bottom}
.fc-reel{display:block;transition:transform .6s var(--fc-ease)}
.fc-stats:not(.is-in) .fc-reel{transform:translateY(-100%)}
.fc-sep{display:inline-block}
.fc-underline{display:block;height:1px;background:var(--fc-ink);transform:scaleX(0);transform-origin:left;margin-top:6px;width:60%}
.fc-stats.is-in .fc-stat.is-ink .fc-underline{transition:transform .3s ease .5s;transform:scaleX(1)}
.fc-stat-lbl{margin-top:9px;font:700 12.5px var(--sans);text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.fc-delta{font:600 12px var(--mono);margin-top:6px;display:inline-block}
.fc-delta.fc-down{color:var(--fc-ink)}.fc-delta.fc-up{color:#4ade80}
.fc-stat:hover .fc-stat-tag{color:var(--fc-ink)}

/* COLUMN */
.fc-fold{fill:rgba(255,255,255,.02)}
.fc-col-cap{fill:var(--fc-ink)}
.fc-colg.is-ink .fc-col{filter:drop-shadow(0 0 8px var(--fc-glow))}
.fc-colg:hover .fc-col{filter:brightness(1.18)}
.fc-peak{stroke:var(--fc-ink);stroke-dasharray:4 5;stroke-width:1;vector-effect:non-scaling-stroke}
.fc-peakl{fill:var(--fc-ink);font:700 10px var(--mono)}
.fc-col rect.fc-col,.fc-col rect.fc-col-cap{transform-box:fill-box;transform-origin:bottom}
.fc-col:not(.is-in) .fc-colg .fc-col{transform:scaleY(0)}
.fc-col.is-in .fc-colg .fc-col{transition:transform 650ms var(--fc-spring);transition-delay:calc(var(--i)*60ms);transform:scaleY(1)}

/* TABLE — фирменная data-table + inline-бары */
.fc-table .fc-tscroll{overflow-x:auto;margin-top:6px}
.fc-tbl{width:100%;border-collapse:collapse;font:600 13px var(--mono);font-variant-numeric:tabular-nums;min-width:480px}
.fc-tbl th{text-align:left;font:700 10px var(--mono);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:12px 14px;border-bottom:1px solid var(--line2);white-space:nowrap}
.fc-tbl td{padding:11px 14px;border-bottom:1px solid var(--line);color:var(--txt);white-space:nowrap}
.fc-tbl .fc-tk{font:800 14px var(--sans);color:#fff}
.fc-tbl tbody tr{transition:background .1s}
.fc-tbl tbody tr:hover{background:var(--panel2)}
.fc-tbar{min-width:140px}
.fc-tbar-v{display:block;margin-bottom:5px;color:#fff}
.fc-tbar-t{display:block;height:3px;background:var(--panel2);overflow:hidden}
.fc-tbar-f{display:block;height:100%;background:var(--fc-ink)}

/* COMPACT overrides (admin dashboard) */
.fc-compact{padding:10px}.fc-compact .fc-fig{display:none}
.fc-compact.fc-bars{gap:6px}.fc-compact .fc-bar-rank{flex:0 0 22px;height:22px;font-size:12px}
.fc-compact .fc-bar-track{height:8px}.fc-compact .fc-bar-sub{display:none}
.fc-compact .fc-readout{font-size:10px;margin-top:6px}
.fc-compact .fc-stat{padding:12px}.fc-compact .fc-stat-num{font-size:clamp(24px,5vw,40px)}
/* compact column: значения над колонками наезжают → скрыть (по hover). area — оставляем только крайние с выноской (они не наезжают) */
.fc-compact.fc-col .fc-vl{display:none}
.fc-compact .fc-xl{font-size:9px}

/* shared tooltip */
#fc-tip{position:fixed;top:0;left:0;z-index:9999;pointer-events:none;background:var(--bg);border:1px solid var(--fc-ink);color:var(--txt);
  font:600 12px/1.5 var(--mono);font-variant-numeric:tabular-nums;padding:8px 10px;opacity:0;transition:opacity .09s;white-space:nowrap}
#fc-tip.on{opacity:1}
#fc-tip b{color:var(--fc-ink)}

/* MOBILE — bars: точки убрать, название/значение/recalls по своим строкам (иначе не влезает) */
@media(max-width:600px){
  .fc-bars{padding:18px 10px 24px;gap:14px}
  .fc-bar{gap:10px}
  .fc-bar-rank{flex:0 0 16px;font-size:15px}
  .fc-bar-dots{display:none}
  .fc-bar-top{flex-wrap:wrap;column-gap:8px;row-gap:2px;align-items:baseline}
  .fc-bar-lbl{order:1;flex:1 1 auto;min-width:0;white-space:normal;font-size:14.5px;line-height:1.2}
  .fc-bar-val{order:2;flex:0 0 auto;margin-left:auto;font-size:14px}
  .fc-bar-sub{order:3;flex-basis:100%;margin-left:0;margin-top:2px}
}

/* GUARDS */
@media(prefers-reduced-motion:reduce){.fc-chart *,.fc-stat *{transition:none!important;animation:none!important}
  .fc-line{stroke-dashoffset:0!important}.fc-wipe{height:auto!important}.fc-bar-fill{transform:none!important}
  .fc-reel{transform:none!important}.fc-seg{stroke-dashoffset:0!important}
  .fc-col .fc-col{transform:none!important}.fc-pt,.fc-vl{opacity:1!important}}
@media(max-width:640px){.fc-line{filter:none!important}.fc-numeral{font-size:22vw}.fc-donut-wrap{justify-content:center}}
@media print{.fc-actions{display:none}.fc-chart *{transition:none!important}.fc-line{stroke-dashoffset:0!important}}
