/* =========================================================================
   Google Ads – správa konverzí · vizuální styl
   Cíl: přehledný, profesionální nástroj pro PPC. Čistá hierarchie, klidné
   barvy s Google-modrým akcentem, plně responzivní (mobil = karty).
   ========================================================================= */
:root {
  --modra: #1a73e8;
  --modra-tmava: #1557b0;
  --modra-svetla: #e8f0fe;
  --bg: #f6f7f9;
  --bg-tmava: #eef0f3;
  --plocha: #ffffff;
  --ram: #e3e6ea;
  --ram-svetly: #eef0f3;
  --text: #1f2329;
  --dim: #6b7280;
  --dim-svetly: #9aa1ab;
  --zelena: #137333;
  --zelena-bg: #e6f4ea;
  --cervena: #c5221f;
  --cervena-bg: #fce8e6;
  --zluta-bg: #fef7e0;
  --zluta-text: #8a6d00;
  --stin: 0 1px 2px rgba(16, 24, 40, .06), 0 1px 3px rgba(16, 24, 40, .04);
  --stin-zvyrazneny: 0 4px 12px rgba(16, 24, 40, .08), 0 2px 4px rgba(16, 24, 40, .04);
  --r: 12px;
  --r-male: 8px;
}

* { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; }

body {
  margin: 0;
  font-family: -apple-system, "Segoe UI", Roboto, Arial, sans-serif;
  color: var(--text);
  background: var(--bg);
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}

/* ---------- Hlavička ---------- */
.hlavicka {
  position: sticky;
  top: 0;
  z-index: 20;
  display: flex;
  justify-content: space-between;
  align-items: center;
  background: rgba(255, 255, 255, .92);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--ram);
  padding: 12px 28px;
}
.logo {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 700;
  color: var(--text);
  text-decoration: none;
  font-size: 17px;
  letter-spacing: -.01em;
}
.logo:hover { color: var(--modra-tmava); }
.odhlasit {
  color: var(--dim);
  text-decoration: none;
  font-size: 14px;
  padding: 6px 12px;
  border-radius: var(--r-male);
  transition: background .15s, color .15s;
}
.odhlasit:hover { color: var(--cervena); background: var(--cervena-bg); }

.obsah { max-width: 1080px; margin: 28px auto; padding: 0 24px; }
.paticka { text-align: center; color: var(--dim-svetly); font-size: 13px; padding: 28px; }

/* ---------- Typografie ---------- */
h1 { font-size: 26px; margin: 8px 0 18px; letter-spacing: -.02em; }
h2 { font-size: 19px; margin: 28px 0 12px; letter-spacing: -.01em; }
h3 { font-size: 16px; margin: 20px 0 10px; }

a { color: var(--modra); text-decoration-color: rgba(26, 115, 232, .3); text-underline-offset: 2px; }
a:hover { color: var(--modra-tmava); }

.drobecky { font-size: 14px; margin: 0 0 6px; color: var(--dim); }
.drobecky a { text-decoration: none; }
.drobecky a:hover { text-decoration: underline; }
.dim { color: var(--dim); }
.mono { font-family: ui-monospace, "SF Mono", Menlo, monospace; font-size: 13px; }
.prazdne {
  color: var(--dim);
  font-style: italic;
  background: var(--plocha);
  border: 1px dashed var(--ram);
  border-radius: var(--r);
  padding: 18px;
  text-align: center;
}

/* ---------- Tlačítka ---------- */
.tlacitko {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 8px 15px;
  border: 1px solid var(--ram);
  border-radius: var(--r-male);
  background: var(--plocha);
  color: var(--text);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: background .15s, border-color .15s, box-shadow .15s, transform .05s;
}
.tlacitko:hover { background: var(--bg-tmava); border-color: var(--dim-svetly); }
.tlacitko:active { transform: translateY(1px); }
.tlacitko.hlavni {
  background: var(--modra);
  color: #fff;
  border-color: var(--modra);
  box-shadow: 0 1px 2px rgba(26, 115, 232, .35);
}
.tlacitko.hlavni:hover { background: var(--modra-tmava); border-color: var(--modra-tmava); }

/* Přístupnost: jasný focus pro klávesnici. */
:focus-visible {
  outline: 2px solid var(--modra);
  outline-offset: 2px;
  border-radius: 4px;
}

/* ---------- Tabulky ---------- */
.tabulka {
  width: 100%;
  border-collapse: collapse;
  background: var(--plocha);
  border: 1px solid var(--ram);
  border-radius: var(--r);
  overflow: hidden;
  box-shadow: var(--stin);
}
.tabulka th, .tabulka td { text-align: left; padding: 12px 16px; border-bottom: 1px solid var(--ram-svetly); }
.tabulka th {
  background: #fafbfc;
  font-size: 12px;
  color: var(--dim);
  text-transform: uppercase;
  letter-spacing: .04em;
  font-weight: 600;
}
.tabulka tbody tr { transition: background .12s; }
.tabulka tbody tr:hover { background: #fafbfd; }
.tabulka tr:last-child td { border-bottom: none; }
.tabulka td .tlacitko { margin-right: 4px; }
/* Číselné sloupce zarovnat doprava + tabulkové číslice (zarovnané řády). */
.cislo-bunka { text-align: right; font-variant-numeric: tabular-nums; white-space: nowrap; }

/* ---------- Stavové štítky ---------- */
.stav {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--bg-tmava);
  color: var(--dim);
}
.stav::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.stav.enabled { background: var(--zelena-bg); color: var(--zelena); }
.stav.paused, .stav.removed { background: var(--cervena-bg); color: var(--cervena); }

/* ---------- Karty s metrikami ---------- */
.karty { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 14px; }
.karta {
  background: var(--plocha);
  border: 1px solid var(--ram);
  border-radius: var(--r);
  padding: 16px 18px;
  box-shadow: var(--stin);
  position: relative;
  overflow: hidden;
}
.karta::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--modra);
  opacity: .85;
}
.karta .cislo { font-size: 23px; font-weight: 700; font-variant-numeric: tabular-nums; letter-spacing: -.02em; }
.karta .popis { color: var(--dim); font-size: 12px; margin-top: 3px; text-transform: uppercase; letter-spacing: .03em; font-weight: 600; }

/* ---------- Doporučení ---------- */
.doporuceni { list-style: none; padding: 0; }
.doporuceni li {
  background: var(--plocha);
  border: 1px solid var(--ram);
  border-radius: var(--r-male);
  padding: 11px 14px;
  margin-bottom: 8px;
  box-shadow: var(--stin);
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
}
.badge { background: var(--modra-svetla); color: var(--modra-tmava); padding: 3px 10px; border-radius: 6px; font-size: 13px; font-weight: 600; }

/* ---------- Formuláře ---------- */
.dva-sloupce { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; margin-top: 12px; align-items: start; }
.panel {
  background: var(--plocha);
  border: 1px solid var(--ram);
  border-radius: var(--r);
  padding: 18px 20px;
  box-shadow: var(--stin);
}
.panel h2 { margin-top: 0; }
form label { display: block; font-size: 14px; font-weight: 600; margin: 12px 0 0; }
form input, form select {
  display: block;
  width: 100%;
  margin-top: 6px;
  padding: 10px 12px;
  border: 1px solid var(--ram);
  border-radius: var(--r-male);
  font-size: 14px;
  font-weight: 400;
  font-family: inherit;
  color: var(--text);
  background: var(--plocha);
  transition: border-color .15s, box-shadow .15s;
}
form input:focus, form select:focus {
  outline: none;
  border-color: var(--modra);
  box-shadow: 0 0 0 3px rgba(26, 115, 232, .15);
}
.radek { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.napoveda { font-size: 12.5px; color: var(--dim); margin-top: 12px; line-height: 1.55; }
form .tlacitko { margin-top: 16px; }

/* ---------- Flash zprávy ---------- */
.flash { padding: 12px 16px; border-radius: var(--r-male); margin-bottom: 14px; font-size: 14px; border: 1px solid transparent; }
.flash.ok { background: var(--zelena-bg); color: var(--zelena); border-color: #b7e1c2; }
.flash.chyba { background: var(--cervena-bg); color: var(--cervena); border-color: #f4c7c3; }
.flash.mock { background: var(--zluta-bg); color: var(--zluta-text); border-color: #f5e3a3; }

/* ---------- Login ---------- */
.login-box {
  max-width: 380px;
  margin: 8vh auto 0;
  background: var(--plocha);
  border: 1px solid var(--ram);
  border-radius: var(--r);
  padding: 32px;
  box-shadow: var(--stin-zvyrazneny);
}
.login-box h1 { margin-top: 0; }
.login-box .tlacitko { width: 100%; margin-top: 18px; padding: 11px; font-size: 15px; }

/* ---------- Hlavička stránky (název + akce) ---------- */
.stranka-hlava { display: flex; align-items: baseline; flex-wrap: wrap; gap: 10px; }
.akce-tlacitka { display: flex; gap: 8px; flex-wrap: wrap; margin: 4px 0 8px; }

/* ---------- Vyhledávání (seznam klientů) ---------- */
.nastroje-radek { display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; margin-bottom: 14px; }
.hledani { position: relative; flex: 1; min-width: 240px; }
.hledani input {
  width: 100%;
  padding: 11px 14px 11px 40px;
  border: 1px solid var(--ram);
  border-radius: var(--r-male);
  font-size: 14px;
  font-family: inherit;
  background: var(--plocha);
  transition: border-color .15s, box-shadow .15s;
}
.hledani input:focus { outline: none; border-color: var(--modra); box-shadow: 0 0 0 3px rgba(26, 115, 232, .15); }
.hledani::before {
  content: "🔍";
  position: absolute;
  left: 13px; top: 50%;
  transform: translateY(-50%);
  font-size: 14px;
  opacity: .55;
  pointer-events: none;
}
.pocet { color: var(--dim); font-size: 14px; white-space: nowrap; }
.bez-vysledku { display: none; }

/* Filtr kampaní podle stavu (chips) */
.filtr-kampani { display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 14px; }
.chip {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 14px;
  border: 1px solid var(--ram);
  border-radius: 20px;
  background: var(--plocha);
  color: var(--text);
  font-size: 13px;
  font-weight: 500;
  font-family: inherit;
  cursor: pointer;
  transition: background .15s, border-color .15s, color .15s;
}
.chip:hover { border-color: var(--dim-svetly); background: var(--bg-tmava); }
.chip.aktivni { background: var(--modra); color: #fff; border-color: var(--modra); }
.pocet-chip {
  font-size: 12px;
  font-weight: 700;
  background: var(--bg-tmava);
  color: var(--dim);
  padding: 1px 7px;
  border-radius: 10px;
  min-width: 20px;
  text-align: center;
}
.chip.aktivni .pocet-chip { background: rgba(255, 255, 255, .25); color: #fff; }

/* ---------- Optimalizace účtu ---------- */
/* Výběr typů ve formuláři */
.typy-volba { display: flex; flex-wrap: wrap; gap: 10px; margin: 4px 0 4px; }
.typ-check {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 8px 13px; margin: 0;
  border: 1px solid var(--ram); border-radius: var(--r-male);
  background: var(--plocha); font-size: 14px; font-weight: 500; cursor: pointer;
}
.typ-check:hover { border-color: var(--dim-svetly); background: var(--bg-tmava); }
.typ-check input { width: 18px; height: 18px; margin: 0; flex: none; accent-color: var(--modra); }

/* Badge typu návrhu */
.badge-typ { display: inline-block; padding: 3px 10px; border-radius: 6px; font-size: 12.5px; font-weight: 600; white-space: nowrap; }
.badge-vyloucit_placement { background: var(--cervena-bg); color: var(--cervena); }
.badge-negativni_kw { background: var(--zluta-bg); color: var(--zluta-text); }
.badge-nove_kw { background: var(--zelena-bg); color: var(--zelena); }
.badge-pozastavit_kw { background: var(--bg-tmava); color: var(--dim); }

/* Hromadný výběr návrhů */
.hromadny-vyber { font-size: 13px; color: var(--dim); margin: 0 0 8px; }
.link-btn { background: none; border: none; color: var(--modra); font-size: 13px; font-family: inherit; cursor: pointer; padding: 0; }
.link-btn:hover { color: var(--modra-tmava); text-decoration: underline; }

/* Poznámka o souvisejícím (překrývajícím se) návrhu */
.navrh-souvisi { display: block; margin-top: 3px; font-size: 12.5px; color: var(--zluta-text); }

/* Dopad návrhu */
.dopad-uspora { color: var(--zelena); font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; }
.dopad-prilezitost { color: var(--modra); font-weight: 600; font-variant-numeric: tabular-nums; white-space: nowrap; }

/* Dry-run seznam */
.dryrun-seznam { list-style: none; padding: 0; margin: 0 0 18px; }
.dryrun-polozka {
  background: var(--plocha); border: 1px solid var(--ram); border-radius: var(--r-male);
  padding: 11px 14px; margin-bottom: 8px; box-shadow: var(--stin);
  border-left: 3px solid var(--zelena);
}
.dryrun-polozka.chyba { border-left-color: var(--cervena); }
.dryrun-polozka > div { display: flex; align-items: center; gap: 8px; }
.dryrun-chyba { color: var(--cervena); font-size: 13px; margin-top: 6px; }

/* Potvrzovací box před ostrým zápisem */
.potvrzeni-box {
  background: #fff8e6; border: 1px solid #f5e3a3; border-radius: var(--r);
  padding: 18px 20px; margin-top: 8px;
}
.potvrzeni-box .akce-tlacitka { margin-top: 14px; }

/* ---------- Znalostní báze ---------- */
.hlavni-nav { display: flex; align-items: center; gap: 18px; }
.nav-odkaz { color: var(--text); text-decoration: none; font-size: 14px; font-weight: 500; }
.nav-odkaz:hover { color: var(--modra); }

.filtr-radek { display: flex; align-items: center; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
.filtr-label { font-size: 13px; color: var(--dim); font-weight: 600; min-width: 96px; }
.chip.mini { padding: 4px 11px; font-size: 12.5px; }

.znalosti-seznam { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; margin-top: 16px; }
.znalost-karta { background: var(--plocha); border: 1px solid var(--ram); border-radius: var(--r); padding: 16px 18px; box-shadow: var(--stin); }
.znalost-hlava { display: flex; justify-content: space-between; align-items: flex-start; gap: 10px; }
.znalost-hlava h3 { margin: 0 0 6px; font-size: 16px; }
.smazat-btn { background: none; border: none; color: var(--dim-svetly); font-size: 16px; cursor: pointer; padding: 0 4px; line-height: 1; }
.smazat-btn:hover { color: var(--cervena); }
.znalost-spoustec { font-size: 13px; margin: 6px 0; }
.znalost-akce { margin: 8px 0; padding-left: 20px; font-size: 13.5px; }
.znalost-akce li { margin-bottom: 3px; }
.znalost-varovani { background: var(--zluta-bg); color: var(--zluta-text); border: 1px solid #f5e3a3; border-radius: var(--r-male); padding: 8px 11px; font-size: 13px; margin: 8px 0; }
.znalost-dimenze { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.badge-dim { font-size: 11.5px; font-weight: 600; padding: 2px 9px; border-radius: 20px; }
.badge-oblast { background: var(--modra-svetla); color: var(--modra-tmava); }
.badge-kampane { background: var(--bg-tmava); color: var(--dim); }
.badge-klienta { background: var(--zelena-bg); color: var(--zelena); }
.znalost-zdroj { font-size: 12px; color: var(--dim); margin: 10px 0 0; }
.navrh-poznatek { margin-bottom: 12px; }
.navrh-poznatek .navrh-popis { display: flex; align-items: center; gap: 10px; cursor: pointer; margin: 0 0 4px; }
.navrh-poznatek .navrh-popis input[type="checkbox"] { width: 18px; height: 18px; flex: none; accent-color: var(--modra); }

/* Doporučené postupy z báze na stránce optimalizace */
.postupy-baze { background: var(--modra-svetla); border: 1px solid #cfe0ff; border-radius: var(--r-male); padding: 12px 16px; margin-bottom: 16px; }
.postupy-baze summary { font-weight: 600; color: var(--modra-tmava); }
.postupy-seznam { margin: 10px 0 6px; padding-left: 20px; font-size: 13.5px; }
.postupy-seznam li { margin-bottom: 7px; }
.postup-varovani { display: block; color: var(--zluta-text); font-size: 12.5px; margin-top: 2px; }

/* ---------- Rada PPC expertů (verdikty) ---------- */
.verdikt { margin-bottom: 12px; border-left: 4px solid var(--dim-svetly); }
.verdikt-provest { border-left-color: var(--zelena); }
.verdikt-neprovest { border-left-color: var(--cervena); }
.verdikt-sporne { border-left-color: var(--zluta-text); }
.verdikt-hlava { display: flex; justify-content: space-between; align-items: flex-start; gap: 14px; }
.verdikt-hlava .navrh-popis { display: flex; align-items: center; gap: 10px; margin: 0; cursor: pointer; }
.verdikt-hlava .navrh-popis input[type="checkbox"] { width: 18px; height: 18px; flex: none; accent-color: var(--modra); }
.verdikt-skore { text-align: right; white-space: nowrap; line-height: 1; }
.skore-cislo { font-size: 26px; font-weight: 700; font-variant-numeric: tabular-nums; }
.skore-max { font-size: 14px; color: var(--dim); }
.verdikt-meta { display: flex; align-items: center; gap: 12px; margin: 8px 0; font-size: 13px; }
.badge-doporuceni { font-size: 12.5px; font-weight: 600; padding: 3px 10px; border-radius: 20px; }
.badge-provest { background: var(--zelena-bg); color: var(--zelena); }
.badge-neprovest { background: var(--cervena-bg); color: var(--cervena); }
.badge-sporne { background: var(--zluta-bg); color: var(--zluta-text); }
.verdikt-souhrn { font-size: 14px; margin: 6px 0; }
.verdikt-hlasy summary { font-size: 13px; color: var(--modra); cursor: pointer; }
.verdikt-hlasy ul { margin: 8px 0 0; padding-left: 20px; font-size: 13px; }
.verdikt-hlasy li { margin-bottom: 5px; }
.hlas-skore { font-weight: 600; font-variant-numeric: tabular-nums; color: var(--dim); }

/* Log "co rada zkoumala" (agentní dotazy do API) */
.rada-log { background: var(--bg-tmava); border-radius: var(--r-male); padding: 10px 14px; margin-bottom: 16px; }
.rada-log summary { font-size: 13px; color: var(--dim); cursor: pointer; font-weight: 500; }
.rada-log ul { margin: 8px 0 0; padding-left: 18px; font-size: 12.5px; }
.rada-log li { margin-bottom: 4px; }
.log-expert { display: inline-block; font-size: 11px; font-weight: 600; padding: 1px 7px; border-radius: 10px; background: var(--modra-svetla); color: var(--modra-tmava); }

/* Overlay „rada pracuje" (agentní posouzení trvá 1-3 min) */
.rada-overlay { position: fixed; inset: 0; z-index: 100; display: flex; align-items: center; justify-content: center; background: rgba(31, 35, 41, .55); backdrop-filter: blur(2px); padding: 20px; }
.rada-overlay-box { background: var(--plocha); border-radius: var(--r); padding: 28px 32px; max-width: 420px; text-align: center; box-shadow: var(--stin-zvyrazneny); }
.rada-overlay-box strong { display: block; margin: 14px 0 6px; font-size: 16px; }
.spinner { width: 38px; height: 38px; margin: 0 auto; border: 4px solid var(--ram); border-top-color: var(--modra); border-radius: 50%; animation: spin .8s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }

/* Znalosti o klientovi (RAG – poznatky vázané na účet) */
.znalosti-klienta { list-style: none; padding: 0; margin: 0 0 12px; }
.znalosti-klienta li { display: flex; justify-content: space-between; align-items: flex-start; gap: 12px; padding: 10px 0; border-bottom: 1px solid var(--ram); }
.zk-text { font-size: 14px; }
.zk-akce, .zk-spoustec { display: block; font-size: 12px; color: var(--dim); margin-top: 3px; }
.zk-spoustec { font-style: italic; }
.link-btn.smazat { color: #c0392b; font-size: 12px; background: none; border: none; cursor: pointer; }
.pridat-znalost { margin-top: 10px; }
.pridat-znalost summary { cursor: pointer; color: var(--modra); font-weight: 500; font-size: 14px; }
.pridat-znalost label { display: block; margin: 10px 0; font-size: 13px; font-weight: 500; }
.pridat-znalost input, .pridat-znalost textarea { width: 100%; margin-top: 4px; }

/* ---------- Návrh konverzí z webu ---------- */
.hledat-web { display: flex; gap: 12px; align-items: flex-end; flex-wrap: wrap; }
.hledat-web label { flex: 1; min-width: 220px; margin: 0; }
.hledat-web .tlacitko { white-space: nowrap; margin-top: 0; }
.navrh-duvod { font-size: 13px; margin-top: 3px; }
.badge-exist { display: inline-block; background: var(--zluta-bg); color: var(--zluta-text); border: 1px solid #f5e3a3; padding: 1px 8px; border-radius: 6px; font-size: 12px; font-weight: 600; margin-left: 6px; }
.existujici-seznam { list-style: none; padding: 0; margin: 0 0 8px; }
.existujici-seznam li { background: var(--plocha); border: 1px solid var(--ram); border-radius: var(--r-male); padding: 9px 12px; margin-bottom: 6px; display: flex; gap: 10px; align-items: center; flex-wrap: wrap; box-shadow: var(--stin); }
.gtm-volba { display: flex; gap: 10px; align-items: center; font-size: 14px; margin: 16px 0; padding: 13px 15px; background: var(--modra-svetla); border: 1px solid #cfe0ff; border-radius: var(--r-male); }
.gtm-volba input[type="checkbox"] { width: 20px; height: 20px; flex: none; accent-color: var(--modra); }
.gtm-stav { font-size: 13px; margin: 8px 0 0; padding: 9px 13px; border-radius: var(--r-male); }
.gtm-ok { background: var(--zelena-bg); color: var(--zelena); border: 1px solid #b7e1c2; }
.gtm-chyba { background: var(--zluta-bg); color: var(--zluta-text); border: 1px solid #f5e3a3; }
.hodnota-input { max-width: 130px; margin-top: 0 !important; }
.odeslat-navrh { margin-top: 16px; }
/* Řádek návrhu: zaškrtávátko hned u názvu konverze, celý popis klikací. */
.navrh-radek { display: flex; gap: 11px; align-items: flex-start; }
.navrh-radek input[type="checkbox"] { margin-top: 2px; flex: none; }
.navrh-popis { cursor: pointer; margin: 0; font-weight: 400; }
.navrh-nazev { font-weight: 600; }
.navrh-radek .navrh-duvod { display: block; }
.vysledek-konverze { margin-bottom: 14px; }
.vysledek-konverze h3 { margin: 0 0 8px; }
.tabulka input[type="checkbox"] { width: 20px; height: 20px; cursor: pointer; accent-color: var(--modra); }

/* ---------- Kód (snippety) + kopírování ---------- */
details { margin: 8px 0; }
summary { cursor: pointer; color: var(--modra); font-size: 14px; font-weight: 500; }
summary:hover { color: var(--modra-tmava); }
.kod-blok { position: relative; }
.kod {
  background: #1f2329; color: #e6e8eb; border-radius: var(--r-male);
  padding: 14px 14px; font-family: ui-monospace, "SF Mono", Menlo, monospace;
  font-size: 12.5px; line-height: 1.5; overflow-x: auto; white-space: pre-wrap;
  word-break: break-word; margin: 6px 0 12px;
}
.kopirovat {
  position: absolute;
  top: 12px; right: 10px;
  padding: 4px 10px;
  font-size: 12px;
  font-weight: 600;
  color: #e6e8eb;
  background: rgba(255, 255, 255, .12);
  border: 1px solid rgba(255, 255, 255, .18);
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s;
}
.kopirovat:hover { background: rgba(255, 255, 255, .22); }
.kopirovat.hotovo { color: #9ae6b4; border-color: rgba(154, 230, 180, .4); }

/* =========================================================================
   Mobil / úzké obrazovky
   ========================================================================= */
@media (max-width: 760px) {
  .dva-sloupce, .radek { grid-template-columns: 1fr; }

  .hlavicka { padding: 11px 16px; }
  .logo { font-size: 15px; }
  .obsah { margin: 16px auto; padding: 0 14px; }
  h1 { font-size: 21px; }
  h2 { font-size: 17px; }

  /* Statistické karty: 2 sloupce (3 byly úzké, dlouhá čísla se ořezávala). */
  .karty { grid-template-columns: 1fr 1fr; gap: 10px; }
  .karta { padding: 13px 14px; }
  .karta .cislo { font-size: 20px; }

  .nastroje-radek { flex-direction: column; align-items: stretch; }

  /* Obecné tabulky se mění na karty (každý řádek = jedna karta). */
  .tabulka { border: none; background: transparent; border-radius: 0; overflow: visible; box-shadow: none; }
  .tabulka thead { display: none; }
  .tabulka tr {
    display: block;
    background: var(--plocha);
    border: 1px solid var(--ram);
    border-radius: var(--r);
    padding: 4px 14px 8px;
    margin-bottom: 10px;
    box-shadow: var(--stin);
  }
  .tabulka tbody tr:hover { background: var(--plocha); }
  .tabulka td {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 14px;
    padding: 9px 0;
    border-bottom: 1px solid var(--ram-svetly);
    text-align: right;
  }
  .tabulka td:last-child { border-bottom: none; }
  .tabulka td::before {
    content: attr(data-label);
    color: var(--dim);
    font-size: 12px;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .03em;
    text-align: left;
    white-space: nowrap;
  }
  .cislo-bunka { text-align: right; }
  /* První buňka = titulek karty (název klienta / konverze / kampaně). */
  .tabulka td:first-child {
    display: block;
    text-align: left;
    font-size: 16px;
    font-weight: 600;
    padding: 10px 0;
    border-bottom: 1px solid var(--ram);
  }
  .tabulka td:first-child::before { content: none; }
  /* Buňka s akčními tlačítky přes celou šířku karty. */
  .tabulka td.akce { display: flex; gap: 8px; padding-top: 12px; }
  .tabulka td.akce::before { content: none; }
  .tabulka td.akce .tlacitko { flex: 1; margin: 0; }

  /* Tabulka NÁVRHU konverzí: titulková buňka = checkbox + název + důvod. */
  .tabulka-navrh td:first-child { padding: 12px 0; font-weight: 400; }
  .tabulka-navrh .navrh-nazev { font-size: 16px; }
  .tabulka-navrh .navrh-duvod { font-weight: 400; }
  /* Hodnota (input/„dynamická") zarovnat doleva pod popisek. */
  .tabulka-navrh td[data-label="Hodnota"] { justify-content: space-between; }

  /* Znalostní báze: karty pod sebe, filtr-label na vlastní řádek. */
  .znalosti-seznam { grid-template-columns: 1fr; }
  .filtr-label { min-width: 100%; margin-bottom: 2px; }
  .hlavni-nav { gap: 12px; }
}

/* ===== Dedup / pročištění znalostní báze ===== */
.dedup-info { font-size: 13.5px; padding: 8px 12px; border-radius: var(--r-male); margin: 10px 0; }
.dedup-info.ok { background: var(--modra-svetla); color: var(--modra-tmava); }
.dedup-info.upozorneni { background: var(--zluta-bg); color: var(--zluta-text); }
.dedup-prah { display: flex; align-items: center; flex-wrap: wrap; gap: 12px; margin: 14px 0;
  padding: 12px 14px; background: var(--plocha); border: 1px solid var(--ram); border-radius: var(--r); }
.dedup-prah input[type=range] { flex: 1; min-width: 160px; max-width: 320px; accent-color: var(--modra); }
.dedup-prah .dim { font-size: 12.5px; }

.dedup-skupina { border: 1px solid var(--ram); border-radius: var(--r); margin-bottom: 16px;
  overflow: hidden; box-shadow: var(--stin); }
.dedup-skupina-hlava { background: var(--bg-tmava); padding: 8px 14px; font-size: 13px;
  color: var(--dim); border-bottom: 1px solid var(--ram); }

.dedup-karta { display: flex; gap: 12px; align-items: flex-start; padding: 14px;
  border-bottom: 1px solid var(--ram-svetly); cursor: pointer; background: var(--plocha); }
.dedup-karta:last-child { border-bottom: none; }
.dedup-karta:hover { background: var(--bg); }
.dedup-karta.nechat { background: var(--zelena-bg); }
.dedup-karta.nechat:hover { background: #d5ecdc; }
.dedup-karta.oznaceno-smazat { background: var(--cervena-bg); }
.dedup-check { margin-top: 3px; width: 17px; height: 17px; accent-color: var(--cervena); flex-shrink: 0; }
.dedup-telo { flex: 1; min-width: 0; }
.dedup-karta-hlava { display: flex; align-items: center; flex-wrap: wrap; gap: 8px; }
.dedup-nazev { font-size: 14.5px; }
.dedup-nazev.tucne { font-weight: 700; }
.dedup-shrnuti { margin: 4px 0; font-size: 13px; }
.dedup-meta { display: flex; flex-wrap: wrap; gap: 12px; font-size: 12px; color: var(--dim); margin-top: 4px; }
.dedup-meta .chybi { color: var(--dim-svetly); font-style: italic; }
.dedup-id { font-family: ui-monospace, monospace; color: var(--dim-svetly); }

.dedup-znacka { font-size: 10.5px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em;
  padding: 2px 8px; border-radius: 20px; }
.dedup-znacka.nechat { background: var(--zelena); color: #fff; }
.dedup-znacka.smazat { background: var(--cervena-bg); color: var(--cervena); }
.dedup-znacka.schvaleno { background: var(--modra-svetla); color: var(--modra-tmava); }

.dedup-lista { position: sticky; bottom: 0; display: flex; align-items: center; justify-content: space-between;
  gap: 14px; flex-wrap: wrap; padding: 12px 16px; margin-top: 8px; background: var(--plocha);
  border: 1px solid var(--ram); border-radius: var(--r); box-shadow: var(--stin-zvyrazneny); }
.dedup-lista #dedup-pocet { font-size: 13.5px; color: var(--dim); }
.dedup-lista .tlacitko { margin-top: 0; }

/* ===== Systém úkolů ===== */
.upozorneni-mock { background: var(--zluta-bg); color: var(--zluta-text); font-size: 13px;
  padding: 8px 12px; border-radius: var(--r-male); margin: 10px 0; }

.ukol-zadani { margin: 16px 0; padding: 16px; background: var(--modra-svetla);
  border: 1px solid var(--ram); border-radius: var(--r); }
.ukol-zadani-radek { display: flex; gap: 8px; margin-top: 6px; }
.ukol-zadani-radek input { flex: 1; padding: 10px 12px; border: 1px solid var(--ram);
  border-radius: var(--r-male); font-size: 14px; }
.ukol-zadani-radek .tlacitko { margin-top: 0; white-space: nowrap; }
.ukol-napoveda { margin: 8px 0 0; font-size: 12.5px; }

.ukol-formular { margin: 16px 0; padding: 16px; background: var(--plocha);
  border: 1px solid var(--ram); border-radius: var(--r); box-shadow: var(--stin); }
.ukol-pole-mriz { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
  gap: 12px; margin-bottom: 14px; }
.ukol-pole-mriz label { display: flex; flex-direction: column; gap: 4px; font-size: 13px;
  font-weight: 600; color: var(--dim); }
.ukol-pole-mriz select, .ukol-pole-mriz input { padding: 8px 10px; border: 1px solid var(--ram);
  border-radius: var(--r-male); font-size: 14px; font-weight: 400; color: var(--text); background: var(--plocha); }

.ukol-navrh { margin-top: 24px; }
.ukol-navrh h2 { font-size: 18px; margin-bottom: 8px; }
.ukol-souhrn { display: flex; flex-wrap: wrap; gap: 16px; padding: 10px 14px; margin-bottom: 14px;
  background: var(--bg-tmava); border-radius: var(--r-male); font-size: 13.5px; }

.ukol-krok { display: flex; gap: 12px; align-items: flex-start; padding: 12px 14px; margin-bottom: 8px;
  background: var(--plocha); border: 1px solid var(--ram); border-left-width: 4px; border-radius: var(--r-male); cursor: pointer; }
.ukol-krok:hover { background: var(--bg); }
.ukol-krok.smer-zvysit { border-left-color: var(--zelena); }
.ukol-krok.smer-snizit { border-left-color: #e8a33d; }
.ukol-krok.smer-pauza, .ukol-krok.smer-zmenit { border-left-color: var(--modra); }
.ukol-krok.smer-beze_zmeny { border-left-color: var(--ram); opacity: .7; }
.ukol-krok input[type=checkbox] { margin-top: 3px; width: 17px; height: 17px; flex-shrink: 0; accent-color: var(--modra); }
.ukol-krok-telo { flex: 1; min-width: 0; }
.ukol-krok-hlava { display: flex; flex-wrap: wrap; align-items: baseline; gap: 8px; }
.ukol-popis { font-size: 13px; color: var(--dim); }
.ukol-duvod { margin: 4px 0; font-size: 12.5px; }
.ukol-metriky { display: flex; flex-wrap: wrap; gap: 12px; font-size: 12px; margin-top: 4px; }
.ukol-varovani { background: var(--zluta-bg); color: var(--zluta-text); font-size: 12px;
  padding: 4px 8px; border-radius: 6px; margin-top: 6px; }

.ukol-smer { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .03em;
  padding: 2px 8px; border-radius: 20px; white-space: nowrap; }
.ukol-smer.smer-zvysit { background: var(--zelena-bg); color: var(--zelena); }
.ukol-smer.smer-snizit { background: #fbe7d2; color: #8a5a00; }
.ukol-smer.smer-pauza, .ukol-smer.smer-zmenit { background: var(--modra-svetla); color: var(--modra-tmava); }
.ukol-smer.smer-beze_zmeny { background: var(--bg-tmava); color: var(--dim); }

.ukol-akce { display: flex; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.ukol-akce .tlacitko { margin-top: 0; }

.ukol-vysledky { margin: 14px 0; }
.ukol-krok.vysledek-ok { border-left-color: var(--zelena); cursor: default; }
.ukol-krok.vysledek-chyba { border-left-color: var(--cervena); background: var(--cervena-bg); cursor: default; }
