/* BorDoc — Výkazy (reports / analytics) */

.vy-shell{height:100vh;display:flex;flex-direction:column;overflow:hidden;background:var(--bg-app)}
.vy-main{flex:1;overflow-y:auto}
.vy-inner{max-width:1180px;margin:0 auto;padding:24px 32px 72px}
.vy-head{margin-bottom:18px}
.vy-head h1{font-size:24px;font-weight:500;color:var(--fg1);letter-spacing:-0.01em;margin:0 0 4px}
.vy-head .sub{font-size:13px;color:var(--fg3)}

/* period bar */
.vy-period{display:flex;align-items:center;gap:clamp(6px,0.8vw,12px);flex-wrap:wrap;padding:12px 16px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:8px}
.vy-period .lic.cal{color:var(--fg3);flex:none}
.vy-preset{height:34px;padding:0 13px;border:1px solid var(--border-strong);background:var(--bg-surface);border-radius:var(--radius-md);font-size:13px;font-weight:500;color:var(--fg2);cursor:pointer;font-family:var(--font-sans);white-space:nowrap}
.vy-preset:hover{background:var(--bg-hover);color:var(--fg1)}
.vy-preset.on{background:var(--accent-tint);border-color:var(--accent);color:var(--accent-text)}
.vy-range{display:flex;align-items:center;gap:7px;margin-left:auto;font-size:13px;color:var(--fg3)}
.vy-range input{height:34px;width:118px;padding:0 10px;border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--bg-surface);color:var(--fg1);font-family:var(--font-mono);font-size:13px;outline:none}
.vy-range input:focus{border-color:var(--accent);box-shadow:var(--ring-focus)}
.vy-curr{font-size:13px;color:var(--fg2);margin:0 0 18px;padding-left:2px}
.vy-curr b{color:var(--fg1);font-weight:500}

/* grid of widget cards */
.vy-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.vy-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 22px;min-width:0}
.vy-card.wide{grid-column:1 / -1}
.vy-card.soon{opacity:.85}
.vy-card-h{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:500;color:var(--fg1);margin:0 0 16px}
.vy-card-h .lic{width:17px;height:17px;color:var(--fg3)}
.vy-csv{margin-left:auto;font-weight:400}
.vy-cur-group{margin-top:14px}
.vy-cur-group:first-child{margin-top:0}
.vy-cur-head{font-size:12px;color:var(--fg3);margin-bottom:8px}
.vy-sum-tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.vy-sum-tile{display:flex;flex-direction:column;gap:4px;padding:14px 16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-subtle)}
.vy-sum-tile.strong{background:var(--accent-tint);border-color:var(--accent)}
.vy-sum-lab{font-size:12px;color:var(--fg3)}
.vy-sum-val{font-size:18px;font-weight:500;color:var(--fg1);font-family:var(--font-mono);font-variant-numeric:tabular-nums}
.vy-sum-tile.strong .vy-sum-val{color:var(--accent-text)}
@media (max-width:760px){.vy-sum-tiles{grid-template-columns:1fr 1fr}}
.vy-csv .lic{width:14px;height:14px;color:var(--accent-text)}
.vy-soon-badge{font-size:11px;font-weight:500;color:var(--fg3);background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-full);padding:2px 9px;margin-left:auto}

/* horizontal bar list (spend by supplier) */
.vy-bars{display:flex;flex-direction:column;gap:13px}
.vy-bar-row{display:grid;grid-template-columns:1fr;gap:5px}
.vy-bar-top{display:flex;align-items:baseline;justify-content:space-between;gap:10px}
.vy-bar-name{font-size:13.5px;color:var(--fg1)}
.vy-bar-ico{font-size:11px;color:var(--fg3);font-family:var(--font-mono);margin-left:7px}
.vy-bar-val{font-size:13.5px;font-weight:500;color:var(--fg1);font-family:var(--font-mono);white-space:nowrap}
.vy-bar-track{height:9px;border-radius:var(--radius-full);background:var(--bg-subtle);overflow:hidden}
.vy-bar-fill{height:100%;border-radius:var(--radius-full);background:var(--accent)}

/* unpaid block */
.vy-unpaid-total{display:flex;flex-direction:column;gap:3px;margin-bottom:16px}
.vy-unpaid-total .lab{font-size:12px;color:var(--fg3)}
.vy-unpaid-total .amt{font-size:28px;font-weight:500;color:var(--fg1);font-family:var(--font-mono);letter-spacing:-0.01em}
.vy-ulist{display:flex;flex-direction:column}
.vy-urow{display:grid;grid-template-columns:1.4fr 0.8fr auto;gap:10px;align-items:center;padding:10px 0;border-bottom:1px solid var(--border);font-size:13px}
.vy-urow:last-of-type{border-bottom:none}
.vy-urow .sup{color:var(--fg1)}
.vy-urow .num{color:var(--fg3);font-family:var(--font-mono);font-size:12px}
.vy-urow .due{font-family:var(--font-mono);color:var(--fg2)}
.vy-urow .amt{font-family:var(--font-mono);color:var(--fg1);text-align:right;font-weight:500}
.vy-urow.overdue .due{color:var(--danger)}
.vy-urow.overdue .due::after{content:" · po splatnosti";font-family:var(--font-sans);font-size:11px}
.vy-pay-btn{margin-top:16px;display:inline-flex;align-items:center;gap:8px;width:100%;justify-content:center;height:40px;border:1px solid var(--border-strong);background:var(--bg-subtle);border-radius:var(--radius-md);font-size:14px;font-weight:500;color:var(--fg3);cursor:not-allowed;font-family:var(--font-sans)}
.vy-pay-btn .vy-soon-badge{margin-left:0}

/* stacked bar chart (incoming docs by type) */
.vy-chart{display:flex;align-items:flex-end;gap:clamp(8px,2vw,22px);height:170px;padding:6px 4px 0;border-bottom:1px solid var(--border)}
.vy-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}
.vy-stack{width:100%;max-width:46px;display:flex;flex-direction:column-reverse;border-radius:var(--radius-sm);overflow:hidden}
.vy-seg{width:100%}
.vy-col-label{font-size:11.5px;color:var(--fg3);font-family:var(--font-mono)}
.vy-legend{display:flex;flex-wrap:wrap;gap:12px;margin-top:14px}
.vy-leg{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;color:var(--fg2)}
.vy-leg-dot{width:10px;height:10px;border-radius:3px;flex:none}
.vy-leg b{color:var(--fg1);font-weight:500;font-family:var(--font-mono)}

/* type colors */
.t-fakt{background:#1D73BE}.t-uct{background:#0E7C86}.t-nab{background:#C2410C}.t-obj{background:#6D28D9}
[data-theme="dark"] .t-fakt{background:#5AA6E8}[data-theme="dark"] .t-uct{background:#5BC6CE}[data-theme="dark"] .t-nab{background:#FF9442}[data-theme="dark"] .t-obj{background:#B79CF2}

/* top suppliers by count (toggle docs/items) */
.vy-seg-toggle{display:inline-flex;gap:3px;background:var(--bg-subtle);border:1px solid var(--border);border-radius:var(--radius-md);padding:3px;margin-left:auto}
.vy-seg-toggle button{height:28px;padding:0 12px;border:none;background:none;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--fg2);cursor:pointer;font-family:var(--font-sans)}
.vy-seg-toggle button.on{background:var(--bg-surface);color:var(--accent-text);box-shadow:var(--shadow-xs)}

/* soon stub */
.vy-stub{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:32px 20px;text-align:center;color:var(--fg3)}
.vy-stub .lic{width:30px;height:30px;color:var(--fg3)}
.vy-stub p{font-size:13px;margin:0;line-height:1.5;max-width:340px}

@media (max-width:820px){ .vy-grid{grid-template-columns:1fr} }

/* ── category analytics (line trend + share doughnut + toggles + drill-down) ── */
.ca-curtabs{font-family:var(--font-mono)}
.ca-charts{display:grid;grid-template-columns:1fr 220px;gap:22px;align-items:start}
@media (max-width:760px){.ca-charts{grid-template-columns:1fr}}
.ca-sub{font-size:12px;color:var(--fg3);margin:0 0 8px}
.ca-linewrap{min-width:0}
.ca-svg{width:100%;height:auto;display:block}
.ca-grid{stroke:var(--border);stroke-width:1}
.ca-axis{fill:var(--fg3);font-size:10px;font-family:var(--font-mono)}
.ca-line{stroke-width:2;stroke-linejoin:round;stroke-linecap:round}
.ca-hint{font-size:12.5px;color:var(--fg3);padding:40px 8px;text-align:center}
.ca-sidewrap{display:flex;flex-direction:column;align-items:center}
.ca-donut{width:184px;height:184px}
.ca-donut-val{fill:var(--fg1);font-size:20px;font-weight:500;font-family:var(--font-mono)}
.ca-donut-cur{fill:var(--fg3);font-size:12px;font-family:var(--font-mono)}

/* toggle list */
.ca-toggles{margin-top:18px;display:grid;grid-template-columns:1fr 1fr;gap:6px 22px}
@media (max-width:760px){.ca-toggles{grid-template-columns:1fr}}
.ca-tog{display:flex;align-items:center;gap:9px;padding:5px 6px;border-radius:var(--radius-sm)}
.ca-tog:hover{background:var(--bg-hover)}
.ca-tog-vis{display:inline-flex;align-items:center;gap:7px;cursor:pointer;flex:none}
.ca-tog-vis input{cursor:pointer;accent-color:var(--accent)}
.ca-dot{width:11px;height:11px;border-radius:3px;flex:none}
.ca-tog-name{flex:1;min-width:0;text-align:left;border:none;background:none;cursor:pointer;font-family:var(--font-sans);font-size:13px;color:var(--fg1);padding:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ca-tog-name:hover{color:var(--accent-text);text-decoration:underline}
.ca-ucet{font-size:11px;color:var(--fg3);font-family:var(--font-mono);margin-left:7px}
.ca-tog-share{font-size:12px;color:var(--fg3);font-family:var(--font-mono);flex:none;width:40px;text-align:right}
.ca-tog-amt{font-size:12.5px;color:var(--fg2);font-family:var(--font-mono);flex:none;text-align:right;white-space:nowrap}

/* drill-down table */
.ca-drill{margin-top:16px;border:1px solid var(--border);border-radius:var(--radius-md);background:var(--bg-subtle);padding:14px 16px}
.ca-drill-head{display:flex;align-items:center;justify-content:space-between;gap:10px;font-size:13px;color:var(--fg2);margin-bottom:10px}
.ca-drill-head b{color:var(--fg1);font-weight:500}
.ca-drill-close{border:none;background:none;cursor:pointer;color:var(--fg3);display:inline-flex;padding:2px;border-radius:var(--radius-sm)}
.ca-drill-close:hover{background:var(--bg-hover);color:var(--fg1)}
.ca-table{width:100%;border-collapse:collapse;font-size:13px}
.ca-table th{text-align:left;font-weight:500;color:var(--fg3);font-size:11.5px;padding:6px 10px;border-bottom:1px solid var(--border);white-space:nowrap}
.ca-table td{padding:8px 10px;border-bottom:1px solid var(--border);color:var(--fg1)}
.ca-table tr:last-child td{border-bottom:none}
.ca-table .r{text-align:right;font-family:var(--font-mono)}
.ca-table .ca-sup{color:var(--fg3)}
.ca-table .ca-amt{font-weight:500}
