/* ===========================================================================
   AXIOM — design system (dark luxury). Bloomberg hustota × Linear klid.
   =========================================================================== */
:root {
  --bg: #0A0B0D;
  --panel: #121417;
  --panel-2: #15181C;
  --elev: #1A1D21;
  --hairline: #262930;
  --hairline-2: #2F333B;
  --ink: #E8E9EC;
  --sub: #9AA0A8;
  --muted: #5F656D;
  --accent: #C8A96A;
  --accent-dim: #8E7846;
  --profit: #3FB68B;
  --loss: #E0556A;
  --blue: #7FA8C9;
  --purple: #9C8BC3;
  --teal: #6FB3A0;
  --radius: 10px;
  --radius-sm: 7px;
  --shadow: 0 1px 0 rgba(255,255,255,.02), 0 8px 24px rgba(0,0,0,.35);
  --sans: -apple-system, BlinkMacSystemFont, 'Segoe UI', Inter, Roboto, 'Helvetica Neue', Arial, sans-serif;
  --mono: ui-monospace, 'SF Mono', 'JetBrains Mono', 'Roboto Mono', Menlo, monospace;
}
* { box-sizing: border-box; }
html, body { margin: 0; height: 100%; }
body {
  background: radial-gradient(1200px 800px at 80% -10%, #14161b 0%, var(--bg) 55%) fixed;
  color: var(--ink);
  font-family: var(--sans);
  font-size: 13px;
  line-height: 1.45;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
.tnum, .mono { font-variant-numeric: tabular-nums; font-feature-settings: 'tnum' 1; }
.mono { font-family: var(--mono); }
.profit { color: var(--profit); }
.loss { color: var(--loss); }
.muted { color: var(--muted); }
.sub { color: var(--sub); }
.small { font-size: 11px; }
.accent { color: var(--accent); }
a { color: var(--accent); text-decoration: none; }

/* ---------- App shell ---------- */
.app { display: grid; grid-template-columns: 232px 1fr; min-height: 100vh; }
.app.collapsed { grid-template-columns: 60px 1fr; }

.sidebar {
  border-right: 1px solid var(--hairline);
  background: linear-gradient(180deg, #0d0f12, #0a0b0d);
  display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh;
}
.brand { display: flex; align-items: center; gap: 11px; padding: 18px 18px 16px; }
.brand .mark {
  width: 26px; height: 26px; border-radius: 7px; flex: 0 0 auto;
  background: linear-gradient(145deg, var(--accent), var(--accent-dim));
  display: grid; place-items: center; color: #0a0b0d; font-weight: 800; font-size: 15px;
  box-shadow: 0 0 0 1px rgba(200,169,106,.25), 0 4px 14px rgba(200,169,106,.18);
}
.brand .name { font-weight: 700; letter-spacing: .14em; font-size: 14px; }
.brand .name small { display: block; letter-spacing: .04em; font-weight: 400; color: var(--muted); font-size: 9.5px; }
.collapsed .brand .name { display: none; }

.nav { padding: 6px 10px; display: flex; flex-direction: column; gap: 2px; overflow-y: auto; flex: 1; }
.nav-item {
  display: flex; align-items: center; gap: 11px; padding: 8px 11px; border-radius: var(--radius-sm);
  color: var(--sub); cursor: pointer; font-size: 12.5px; user-select: none; position: relative;
  transition: background .12s, color .12s;
}
.nav-item:hover { background: #15181d; color: var(--ink); }
.nav-item.active { background: #181b20; color: var(--ink); }
.nav-item.active::before { content:''; position:absolute; left:-10px; top:8px; bottom:8px; width:3px; border-radius:0 3px 3px 0; background: var(--accent); }
.nav-item .ic { width: 18px; height: 18px; flex: 0 0 auto; opacity: .92; transition: color .12s; }
.nav-item .lbl { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; flex: 1; }
/* jemné barevné akcenty ikon per sekce (na hover/active přejdou do zlaté) */
.nav-item.sec-prehled .ic { color: #C8A96A; }
.nav-item.sec-denik   .ic { color: #6E9BC9; }
.nav-item.sec-analyza .ic { color: #A085CC; }
.nav-item.sec-plan    .ic { color: #5FAB8C; }
.nav-item.sec-system  .ic { color: #9AA0A8; }
.nav-item:hover .ic, .nav-item.active .ic { color: var(--accent); }
.collapsed .nav-item .lbl { display: none; }
.nav-section { color: var(--muted); font-size: 9.5px; letter-spacing: .12em; text-transform: uppercase; padding: 12px 12px 4px; }
.collapsed .nav-section { display: none; }
.sidebar-foot { padding: 12px; border-top: 1px solid var(--hairline); color: var(--muted); font-size: 10.5px; }
.collapsed .sidebar-foot { display: none; }

/* ---------- Main ---------- */
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar {
  position: sticky; top: 0; z-index: 30; display: flex; align-items: center; gap: 14px;
  padding: 11px 22px; border-bottom: 1px solid var(--hairline);
  background: rgba(10,11,13,.82); backdrop-filter: blur(12px);
}
.topbar .title { font-size: 15px; font-weight: 650; letter-spacing: .01em; }
.topbar .title small { color: var(--muted); font-weight: 400; margin-left: 8px; font-size: 11.5px; letter-spacing: 0; }
.spacer { flex: 1; }
.icon-btn { width: 30px; height: 30px; display: grid; place-items: center; border-radius: 7px; cursor: pointer; color: var(--sub); border: 1px solid transparent; }
.icon-btn:hover { background: #15181d; color: var(--ink); }

/* filter bar */
.filterbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 10px 22px; border-bottom: 1px solid var(--hairline); background: var(--panel); }
.filter-label { color: var(--muted); font-size: 10.5px; letter-spacing: .1em; text-transform: uppercase; margin-right: 2px; }
.select, .input {
  background: #0e1013; border: 1px solid var(--hairline); color: var(--ink); border-radius: 7px;
  padding: 5px 9px; font-size: 12px; font-family: var(--sans); outline: none; min-width: 0;
}
.select:focus, .input:focus { border-color: var(--accent-dim); }
.select { cursor: pointer; }
.chip { display: inline-flex; align-items: center; gap: 6px; background: #15181d; border: 1px solid var(--hairline); border-radius: 999px; padding: 3px 10px; font-size: 11.5px; color: var(--sub); }
.chip .x { cursor: pointer; color: var(--muted); }
.chip .x:hover { color: var(--loss); }
.btn { background: #15181d; border: 1px solid var(--hairline); color: var(--ink); border-radius: 7px; padding: 6px 12px; font-size: 12px; cursor: pointer; font-family: var(--sans); transition: background .12s, border-color .12s; }
.btn:hover { background: #1b1f24; border-color: var(--hairline-2); }
.btn.primary { background: linear-gradient(145deg, var(--accent), var(--accent-dim)); color: #0a0b0d; border: none; font-weight: 650; }
.btn.primary:hover { filter: brightness(1.06); }
.btn.ghost { background: transparent; }
.btn.danger { color: var(--loss); border-color: #3a2326; }
.btn.danger:hover { background: #2a1a1c; }

/* ---------- Content / grid ---------- */
.content { padding: 20px 22px 60px; }
.grid { display: grid; gap: 14px; }
.cols-12 { grid-template-columns: repeat(12, 1fr); }
.span-3 { grid-column: span 3; } .span-4 { grid-column: span 4; } .span-5 { grid-column: span 5; }
.span-6 { grid-column: span 6; } .span-7 { grid-column: span 7; } .span-8 { grid-column: span 8; }
.span-9 { grid-column: span 9; } .span-12 { grid-column: span 12; }
@media (max-width: 1100px) { .span-3,.span-4,.span-5,.span-6,.span-7,.span-8,.span-9 { grid-column: span 12; } }

/* ---------- Mobilní responzivita ---------- */
@media (max-width: 760px) {
  .app, .app.collapsed { grid-template-columns: 1fr; }
  .sidebar { position: fixed; left: 0; top: 0; z-index: 200; width: 240px; height: 100%;
    transform: translateX(-100%); transition: transform .2s ease; }
  .app.nav-open .sidebar { transform: none; box-shadow: 0 0 60px rgba(0,0,0,.6); }
  .app.nav-open::after { content: ''; position: fixed; inset: 0; background: rgba(0,0,0,.5); z-index: 150; }
  .topbar { flex-wrap: wrap; padding: 9px 12px; gap: 8px; }
  .topbar .title { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  .filterbar { padding: 8px 12px; }
  .content { padding: 14px 12px 44px; }
  .cmd-btn kbd { display: none; }
  .drawer { width: 100vw; }
}
@media (max-width: 700px) {
  .grid.cols-12 { grid-template-columns: 1fr; }
  .grid.cols-12 > * { grid-column: auto !important; }
}

.panel { background: var(--panel); border: 1px solid var(--hairline); border-radius: var(--radius); box-shadow: var(--shadow); }
.panel-h { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 13px 16px 10px; }
.panel-h h3 { margin: 0; font-size: 12.5px; font-weight: 600; letter-spacing: .02em; color: var(--ink); }
.panel-h .hint { color: var(--muted); font-size: 10.5px; }
.panel-b { padding: 6px 16px 16px; }
.panel-chart { display: flex; flex-direction: column; } /* chart-panel: panel = flex sloupec, aby panel-b vyplnil zbylou výšku panelu */
.panel-chart > .panel-b.chart-center { flex: 1 1 auto; } /* panel-b vyplní výšku → je co centrovat */
.panel-b.chart-center { display: flex; flex-direction: column; justify-content: center; } /* krátký graf/obsah se vertikálně vycentruje v panelu (panely v řádku zůstávají stejně vysoké, obsah se nelepí nahoru) */
.panel-b.tight { padding: 4px 10px 10px; }

/* KPI tiles */
.kpi { background: var(--panel); border: 1px solid var(--hairline); border-radius: var(--radius); padding: 13px 15px; display: flex; flex-direction: column; gap: 3px; min-height: 86px; }
.kpi .k-label { color: var(--muted); font-size: 10.5px; letter-spacing: .08em; text-transform: uppercase; }
.kpi .k-val { font-size: 23px; font-weight: 600; letter-spacing: -.01em; }
.kpi .k-sub { font-size: 11px; color: var(--sub); }
.kpi.big .k-val { font-size: 27px; }

/* verdict badge */
.verdict { display: inline-flex; align-items: center; gap: 8px; border-radius: 8px; padding: 7px 12px; font-size: 12px; font-weight: 600; border: 1px solid; }
.verdict .dot { width: 8px; height: 8px; border-radius: 50%; }
.v-strong { color: var(--profit); border-color: #1f3d33; background: #112019; } .v-strong .dot { background: var(--profit); }
.v-likely { color: var(--accent); border-color: #3a3120; background: #1c180e; } .v-likely .dot { background: var(--accent); }
.v-noise  { color: var(--sub); border-color: var(--hairline); background: #14161a; } .v-noise .dot { background: var(--muted); }
.v-wait   { color: var(--blue); border-color: #1f2f3d; background: #0f1820; } .v-wait .dot { background: var(--blue); }

/* tables */
.tbl-wrap { overflow: auto; border-radius: 8px; }
table.tbl { width: 100%; border-collapse: collapse; font-size: 12px; }
table.tbl th { position: sticky; top: 0; background: var(--panel-2); color: var(--muted); font-weight: 500; text-align: right; padding: 8px 12px; font-size: 10.5px; letter-spacing: .04em; text-transform: uppercase; border-bottom: 1px solid var(--hairline); cursor: pointer; white-space: nowrap; }
table.tbl th.l, table.tbl td.l { text-align: left; }
table.tbl th:hover { color: var(--sub); }
table.tbl td { padding: 6px 12px; text-align: right; border-bottom: 1px solid #16181c; white-space: nowrap; }
table.tbl tr:hover td { background: #14171b; }
table.tbl tr { cursor: pointer; }
.databar { position: relative; }
.databar > i { position: absolute; left: 0; top: 3px; bottom: 3px; border-radius: 2px; opacity: .16; }

.tag { display: inline-block; padding: 1px 7px; border-radius: 5px; font-size: 10.5px; background: #181b20; color: var(--sub); border: 1px solid var(--hairline); margin: 0 2px 2px 0; }
.dir-long { color: var(--profit); } .dir-short { color: var(--loss); }
.pill { padding: 2px 8px; border-radius: 999px; font-size: 10px; font-weight: 600; }

/* insight cards */
.insight { display: flex; gap: 11px; padding: 12px 13px; border: 1px solid var(--hairline); border-radius: 9px; background: var(--panel-2); margin-bottom: 9px; }
.insight .sev { width: 4px; border-radius: 3px; flex: 0 0 auto; }
.insight.high .sev { background: var(--loss); } .insight.med .sev { background: var(--accent); } .insight.low .sev { background: var(--blue); }
.insight h4 { margin: 0 0 3px; font-size: 12.5px; }
.insight p { margin: 0; color: var(--sub); font-size: 11.5px; line-height: 1.5; }
.insight .impact { margin-top: 5px; font-size: 11px; }

/* score */
.score-num { font-size: 46px; font-weight: 700; letter-spacing: -.02em; line-height: 1; }
.pillar-row { display: flex; align-items: center; gap: 10px; margin: 5px 0; font-size: 11.5px; }
.pillar-row .bar { flex: 1; height: 5px; border-radius: 3px; background: #1a1d22; overflow: hidden; }
.pillar-row .bar > i { display: block; height: 100%; background: linear-gradient(90deg, var(--accent-dim), var(--accent)); }
.pillar-row .pv { width: 28px; text-align: right; color: var(--sub); }
.pillar-row .pl { max-width: 130px; min-width: 90px; color: var(--sub); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

/* stat list */
.statlist { display: grid; grid-template-columns: 1fr auto; gap: 2px 14px; font-size: 12px; }
.statlist .sl-k { color: var(--sub); padding: 4px 0; border-bottom: 1px solid #16181c; }
.statlist .sl-v { text-align: right; padding: 4px 0; border-bottom: 1px solid #16181c; }
.metric-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); gap: 1px; background: var(--hairline); border-radius: 8px; overflow: hidden; }
.metric-grid .m { background: var(--panel); padding: 11px 13px; }
.metric-grid .m .mk { color: var(--muted); font-size: 10px; letter-spacing: .06em; text-transform: uppercase; }
.metric-grid .m .mv { font-size: 17px; font-weight: 600; margin-top: 2px; }
.metric-grid .m .mh { font-size: 10px; color: var(--muted); }

/* modal / drawer */
.overlay { position: fixed; inset: 0; background: rgba(5,6,8,.62); backdrop-filter: blur(3px); z-index: 90; display: flex; opacity: 0; pointer-events: none; transition: opacity .15s; }
.overlay.open { opacity: 1; pointer-events: auto; }
.drawer { margin-left: auto; width: min(720px, 94vw); height: 100%; background: var(--bg); border-left: 1px solid var(--hairline); overflow-y: auto; transform: translateX(20px); transition: transform .18s; }
.overlay.open .drawer { transform: none; }
.drawer-h { display: flex; align-items: center; justify-content: space-between; padding: 16px 20px; border-bottom: 1px solid var(--hairline); position: sticky; top: 0; background: var(--bg); z-index: 2; }
.drawer-b { padding: 18px 20px 40px; }
.modal { margin: auto; width: min(560px, 94vw); max-height: 90vh; overflow-y: auto; background: var(--panel); border: 1px solid var(--hairline); border-radius: 14px; box-shadow: var(--shadow); }

/* forms */
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.field { display: flex; flex-direction: column; gap: 4px; }
.field label { font-size: 11px; color: var(--sub); }
.field .input, .field .select { width: 100%; }
.field.full { grid-column: span 2; }
textarea.input { resize: vertical; min-height: 60px; font-family: var(--sans); }

/* SVG grafy — bez výběru textu (hover nesmí „označovat" buňky) */
.axiom-svg, .axiom-svg text { user-select: none; -webkit-user-select: none; }

/* tooltip */
.axiom-tip {
  position: fixed; z-index: 200; pointer-events: none; opacity: 0; transition: opacity .08s;
  background: #1c1f25; border: 1px solid var(--hairline-2); border-radius: 8px; padding: 8px 10px;
  font-size: 11.5px; color: var(--ink); box-shadow: 0 8px 28px rgba(0,0,0,.5); max-width: 280px; line-height: 1.5;
}
.axiom-tip b { color: #fff; }

/* loader */
.loader { position: fixed; inset: 0; display: grid; place-items: center; background: var(--bg); z-index: 300; transition: opacity .3s; }
.loader.hide { opacity: 0; pointer-events: none; }
.spin { width: 30px; height: 30px; border: 2.5px solid var(--hairline); border-top-color: var(--accent); border-radius: 50%; animation: sp 0.8s linear infinite; }
@keyframes sp { to { transform: rotate(360deg); } }

.legend { display: flex; gap: 14px; flex-wrap: wrap; font-size: 10.5px; color: var(--sub); }
.legend i { display: inline-block; width: 9px; height: 9px; border-radius: 2px; margin-right: 5px; vertical-align: middle; }
.divider { height: 1px; background: var(--hairline); margin: 14px 0; }
.row { display: flex; align-items: center; gap: 10px; }
.wrap { display: flex; flex-wrap: wrap; gap: 8px; }
.seg { display: inline-flex; background: #0e1013; border: 1px solid var(--hairline); border-radius: 8px; overflow: hidden; }
.seg button { background: transparent; border: none; color: var(--sub); padding: 5px 11px; font-size: 11.5px; cursor: pointer; font-family: var(--sans); }
.seg button.active { background: #1b1f24; color: var(--ink); }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: #1e2228; border-radius: 6px; border: 2px solid var(--bg); }
::-webkit-scrollbar-thumb:hover { background: #2a2f36; }
.empty { padding: 40px; text-align: center; color: var(--muted); }
.ss-drop { border: 1px dashed var(--hairline-2); border-radius: 8px; padding: 20px; text-align: center; color: var(--muted); cursor: pointer; font-size: 12px; outline: none; transition: border-color .12s, color .12s; }
.ss-drop:hover, .ss-drop:focus { border-color: var(--accent-dim); color: var(--sub); }
.ss-drop.over { border-color: var(--accent); color: var(--ink); background: #15181d; }
.day-row { display: flex; align-items: center; justify-content: space-between; gap: 10px; padding: 9px 12px; border-radius: 8px; cursor: pointer; border: 1px solid transparent; }
.day-row:hover { background: #14171b; }
.day-row.sel { background: #181b20; border-color: var(--hairline); }
:root[data-theme="light"] .day-row:hover { background: #efece4; }
:root[data-theme="light"] .day-row.sel { background: #ece8df; border-color: var(--hairline); }

/* ===========================================================================
   v2 — chart vars, light mode, hustota, CVD, lock, ⌘K, tisk, controls
   =========================================================================== */
:root { --chart-grid: #1B1F25; --chart-cell: #15181d; }

/* světlý režim */
:root[data-theme="light"] {
  --bg: #F4F3EF; --panel: #FFFFFF; --panel-2: #FAF9F6; --elev: #FFFFFF;
  --hairline: #E7E3DB; --hairline-2: #D9D4C9;
  --ink: #1B1C1E; --sub: #5A5F66; --muted: #8C9098;
  --accent: #9A7B36; --accent-dim: #B89A5C;
  --profit: #1F8F62; --loss: #C23A4E; --blue: #3E6E99; --purple: #6E5C99;
  --chart-grid: #ECE8E0; --chart-cell: #F1EEE7;
  --shadow: 0 1px 0 rgba(0,0,0,.02), 0 10px 26px rgba(40,34,20,.08);
}
:root[data-theme="light"] body { background: radial-gradient(1200px 800px at 80% -10%, #fbfaf7 0%, var(--bg) 55%) fixed; }
:root[data-theme="light"] .sidebar { background: linear-gradient(180deg, #fbfaf7, #f4f3ef); }
:root[data-theme="light"] .topbar { background: rgba(244,243,239,.82); }
:root[data-theme="light"] .select, :root[data-theme="light"] .input, :root[data-theme="light"] .cmd-btn kbd { background: #fbfaf7; }
:root[data-theme="light"] .nav-item:hover, :root[data-theme="light"] .nav-item.active,
:root[data-theme="light"] .icon-btn:hover, :root[data-theme="light"] table.tbl tr:hover td,
:root[data-theme="light"] .cmd-btn:hover, :root[data-theme="light"] .cmd-item.sel, :root[data-theme="light"] .btn:hover { background: #efece4; color: var(--ink); }
:root[data-theme="light"] .btn, :root[data-theme="light"] .chip, :root[data-theme="light"] .tag,
:root[data-theme="light"] .seg, :root[data-theme="light"] .metric-grid .m { background: #faf9f6; }
:root[data-theme="light"] .seg button.active { background: #ece8df; }
:root[data-theme="light"] table.tbl td { border-bottom-color: #f0ede6; }
/* světlý režim — doplňkové overridy (prvky s natvrdo tmavým hex) */
:root[data-theme="light"] .btn.danger { border-color: #e3b9bf; }
:root[data-theme="light"] .btn.danger:hover { background: #f7e6e8; }
:root[data-theme="light"] .pillar-row .bar { background: var(--chart-grid); }
:root[data-theme="light"] .ss-drop.over { background: #efece4; }
:root[data-theme="light"] .axiom-tip { background: #fff; color: var(--ink); border-color: var(--hairline-2); }
:root[data-theme="light"] .axiom-tip b { color: var(--ink); }
:root[data-theme="light"] .statlist .sl-k, :root[data-theme="light"] .statlist .sl-v { border-bottom-color: #f0ede6; }
:root[data-theme="light"] .tag { background: #f0ede6; }
:root[data-theme="light"] .v-strong { background: #e6f3ec; border-color: #bfe0cf; }
:root[data-theme="light"] .v-likely { background: #f5edd9; border-color: #e0d3a8; }
:root[data-theme="light"] .v-noise  { background: #f0eee9; border-color: var(--hairline-2); }
:root[data-theme="light"] .v-wait   { background: #e6eef5; border-color: #bcd2e3; }
:root[data-theme="light"] ::-webkit-scrollbar-thumb { background: #d9d4c9; border-color: var(--bg); }
:root[data-theme="light"] ::-webkit-scrollbar-thumb:hover { background: #c7c1b3; }
:root[data-theme="light"] .lock-input { background: #fbfaf7; }

/* hustota */
:root[data-density="comfortable"] table.tbl td { padding: 10px 14px; }
:root[data-density="comfortable"] body { font-size: 13.5px; }
:root[data-density="comfortable"] .panel-b { padding: 10px 18px 18px; }

/* colorblind-safe (modrá/oranžová) */
:root[data-cvd="on"] { --profit: #3E8FD0; --loss: #E08A2B; }

/* slidery + checkbox */
input[type=range] { -webkit-appearance: none; appearance: none; height: 4px; border-radius: 3px; background: var(--chart-grid); outline: none; margin: 8px 0; }
input[type=range]::-webkit-slider-thumb { -webkit-appearance: none; width: 15px; height: 15px; border-radius: 50%; background: var(--accent); cursor: pointer; border: 2px solid var(--bg); }
input[type=range]::-moz-range-thumb { width: 14px; height: 14px; border-radius: 50%; background: var(--accent); cursor: pointer; border: none; }
input[type=checkbox] { accent-color: var(--accent); width: 14px; height: 14px; }

/* ⌘K command palette + topbar tlačítko */
.cmd-btn { display: flex; align-items: center; gap: 7px; padding: 5px 10px; border: 1px solid var(--hairline); border-radius: 8px; color: var(--sub); cursor: pointer; }
.cmd-btn:hover { background: #15181d; color: var(--ink); }
.cmd-btn kbd { font-family: var(--mono); font-size: 10px; background: #0e1013; border: 1px solid var(--hairline); border-radius: 4px; padding: 1px 5px; color: var(--muted); }
.cmd-ov { position: fixed; inset: 0; z-index: 250; background: rgba(5,6,8,.5); backdrop-filter: blur(4px); display: flex; align-items: flex-start; justify-content: center; padding-top: 11vh; }
.cmd-box { width: min(620px, 92vw); background: var(--panel); border: 1px solid var(--hairline-2); border-radius: 14px; box-shadow: var(--shadow); overflow: hidden; }
.cmd-head { padding: 4px; border-bottom: 1px solid var(--hairline); }
.cmd-input { width: 100%; border: none; background: transparent; color: var(--ink); font-size: 15px; padding: 13px 16px; outline: none; font-family: var(--sans); }
.cmd-list { max-height: 52vh; overflow-y: auto; padding: 6px; }
.cmd-item { display: flex; align-items: center; gap: 10px; padding: 8px 12px; border-radius: 8px; cursor: pointer; }
.cmd-item.sel { background: #181b20; }
.cmd-group { font-size: 9px; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); width: 76px; flex: 0 0 auto; }
.cmd-label { flex: 1; font-size: 13px; }
.cmd-hint { color: var(--muted); font-size: 11px; }
.cmd-empty { padding: 18px; text-align: center; color: var(--muted); font-size: 12px; }

/* lock screen */
.lockscreen { position: fixed; inset: 0; z-index: 400; display: grid; place-items: center; background: radial-gradient(1000px 700px at 50% 0%, #14161b, #0a0b0d); }
.lock-card { width: 300px; text-align: center; background: var(--panel); border: 1px solid var(--hairline); border-radius: 16px; padding: 30px 26px; box-shadow: var(--shadow); }
.lock-mark { width: 46px; height: 46px; margin: 0 auto 14px; border-radius: 12px; background: linear-gradient(145deg, var(--accent), var(--accent-dim)); display: grid; place-items: center; color: #0A0B0D; font-weight: 800; font-size: 24px; }
.lock-title { font-weight: 650; font-size: 16px; }
.lock-sub { color: var(--sub); font-size: 12px; margin: 6px 0 18px; }
.lock-input { width: 100%; text-align: center; font-size: 20px; letter-spacing: .3em; padding: 11px; background: #0e1013; border: 1px solid var(--hairline); border-radius: 9px; color: var(--ink); }
.lock-input:focus { border-color: var(--accent-dim); outline: none; }
.lock-err { color: var(--loss); font-size: 11.5px; height: 16px; margin-top: 8px; }

/* tisk / PDF */
@media print {
  .sidebar, .topbar, .filterbar, #noprint-bar, .cmd-ov, .cmd-btn, .axiom-tip, .overlay { display: none !important; }
  .app, .app.collapsed { display: block; grid-template-columns: 1fr; }
  .main { display: block; }
  .content { padding: 0; }
  body { -webkit-print-color-adjust: exact; print-color-adjust: exact; }
  .panel, .kpi, .insight { break-inside: avoid; }
  .grid { gap: 10px; }
}

/* Nápověda — názorná schémata (figura blok, ne inline SVG → nerozhazuje text) */
.help-fig { display: block; margin: 16px 0; padding: 14px 16px 10px; border: 1px solid var(--hairline); border-radius: 11px; background: var(--panel); }
.help-fig svg { display: block; width: 100%; max-width: 480px; height: auto; margin: 0 auto; }
.help-fig figcaption { margin-top: 10px; font-size: 13px; line-height: 1.55; color: var(--sub); text-align: center; }
