/* ================================================================
   mBlue — Button system
   ================================================================

   Varianty:
   - Default `.button` = GHOST sekundární. Transparentní pozadí,
     jemný border, tlumený text. Bere minimum pozornosti.
     Sem patří: Upravit, Otevřít detail, Zpět, Zrušit, Report,
     Export, Odhlásit, Odblokovat, sekce-level akce na show stránce.
   - `.button.primary` = HLAVNÍ akce stránky/formu/dialogu (indigo).
     Max 1 viditelně najednou. Submit ve formu (Uložit, Vytvořit,
     Přihlásit), nebo create CTA na index stránce (+ Přidat).
   - `.button.danger` = destruktivní akce (červená). Trvalé smazání
     ve show, Zablokovat. NE pro inline mazání řádku v tabulce — na
     to je `.button.link.danger`.
   - `.button.link` = textový odkaz, ne button. Inline akce ve
     výpisech a tabulkách. Varianta `.danger` pro "Smazat".

   Všechna tlačítka mají sjednocenou výšku (default size).
   Modifikátory: `.sm` pro inline akce v tabulkách, `.tn` pro nejmenší.
   ================================================================ */

/* ── Default (ghost) ─────────────────────────────────────────────
   Override frameworku — vlastní ghost vzhled místo šedého 3D.
   Specificita `.button.button` (zdvojení třídy) neuměle nelze, takže
   přepisujeme přímo elementové selektory, kde framework styl žije. */
.button,
a.button,
button.button,
button,
input[type="submit"],
input[type="button"] {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  background: transparent;
  color: var(--clr-text-2);
  border: 1px solid var(--clr-border);
  border-radius: var(--radius-sm);
  box-shadow: none;
  padding: 0.4rem 0.85rem;
  font-size: 0.85rem;
  font-weight: 500;
  font-family: inherit;
  line-height: 1.4;
  cursor: pointer;
  text-decoration: none;
  white-space: nowrap;
  vertical-align: middle;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}

.button:hover,
a.button:hover,
button.button:hover,
button:hover,
input[type="submit"]:hover,
input[type="button"]:hover {
  background: var(--clr-surface-alt);
  border-color: #cbd5e1;
  color: var(--clr-text);
  box-shadow: none;
  text-decoration: none;
  transform: none;
}

.button:active,
button:active,
input[type="submit"]:active {
  background: var(--clr-border);
  box-shadow: none;
  transform: none;
}

.button:visited,
a.button:visited {
  color: var(--clr-text-2);
}

.button[disabled],
button[disabled],
input[type="submit"][disabled] {
  background: transparent;
  color: var(--clr-text-muted);
  border-color: var(--clr-border);
  cursor: default;
  box-shadow: none;
}

.button[disabled]:hover,
button[disabled]:hover,
input[type="submit"][disabled]:hover {
  background: transparent;
  border-color: var(--clr-border);
  color: var(--clr-text-muted);
}

/* Tlačítko s ikonou — sjednocená max výška ikony. */
.button img,
button img {
  max-height: 18px;
  display: inline-block;
  object-fit: contain;
}

/* ── Velikosti ───────────────────────────────────────────────────
   default = compact (padding 0.4rem 0.85rem, font 0.85rem)
   .sm     = ještě menší pro inline akce v hustých tabulkách
   .tn     = nejmenší (chip-like) pro menu triggery
   .lg     = větší pro main CTA, pokud potřeba — málo časté */
.button.sm,
button.sm,
input[type="submit"].sm {
  padding: 0.25rem 0.6rem;
  font-size: 0.78rem;
}

.button.sm img,
button.sm img { max-height: 15px; }

.button.tn,
button.tn,
input[type="submit"].tn {
  padding: 0.15rem 0.5rem;
  font-size: 0.72rem;
}

.button.tn img,
button.tn img { max-height: 13px; }

.button.lg,
button.lg,
input[type="submit"].lg {
  padding: 0.6rem 1.4rem;
  font-size: 0.95rem;
}

.button.lg img,
button.lg img { max-height: 22px; }

/* ── Primary ─────────────────────────────────────────────────────
   Indigo CTA — jediná barevná akční varianta na stránce. */
.button.primary,
button.primary,
input[type="submit"].primary {
  background: var(--clr-indigo);
  color: #fff;
  border-color: var(--clr-indigo);
  font-weight: 600;
}

.button.primary:hover,
button.primary:hover,
input[type="submit"].primary:hover {
  background: var(--clr-indigo-dark);
  border-color: var(--clr-indigo-dark);
  color: #fff;
  box-shadow: 0 2px 8px rgba(99, 102, 241, 0.28);
}

.button.primary:active,
button.primary:active,
input[type="submit"].primary:active {
  background: var(--clr-indigo-dark);
  box-shadow: none;
}

.button.primary:visited { color: #fff; }

.button.primary[disabled],
button.primary[disabled],
input[type="submit"].primary[disabled] {
  background: #c7d2fe;
  border-color: #c7d2fe;
  color: #fff;
  cursor: default;
}

/* ── Danger ──────────────────────────────────────────────────────
   Červená pro destruktivní akce. */
.button.danger,
button.danger,
input[type="submit"].danger {
  background: #dc2626;
  color: #fff;
  border-color: #dc2626;
  font-weight: 600;
}

.button.danger:hover,
button.danger:hover,
input[type="submit"].danger:hover {
  background: #b91c1c;
  border-color: #b91c1c;
  color: #fff;
  box-shadow: 0 2px 8px rgba(220, 38, 38, 0.24);
}

.button.danger:visited { color: #fff; }

/* ── Link ────────────────────────────────────────────────────────
   Textový odkaz – pro inline akce v tabulkových řádcích a kartách.
   Žádný background, žádný border, žádný padding – jen text. */
.button.link,
a.button.link,
button.link {
  background: transparent;
  color: var(--clr-indigo);
  border: none;
  box-shadow: none;
  padding: 0;
  font-size: 0.82rem;
  font-weight: 500;
  text-decoration: none;
  white-space: nowrap;
  display: inline;
  line-height: inherit;
}

.button.link:hover,
a.button.link:hover,
button.link:hover {
  background: transparent;
  border: none;
  box-shadow: none;
  color: var(--clr-indigo-dark);
  text-decoration: underline;
}

.button.link:active,
button.link:active {
  background: transparent;
  box-shadow: none;
}

.button.link:visited,
a.button.link:visited { color: var(--clr-indigo); }

.button.link.danger,
a.button.link.danger,
button.link.danger { color: #b91c1c; }

.button.link.danger:hover,
a.button.link.danger:hover,
button.link.danger:hover { color: #7f1d1d; }

.button.link.danger:visited,
a.button.link.danger:visited { color: #b91c1c; }

/* ── Skupina tlačítek ────────────────────────────────────────────
   <div class="buttons"> seskupuje tlačítka v headeru stránky. */
.buttons {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
}

h1 > .buttons,
.edit-title > .buttons {
  padding-left: 1rem;
  border-left: 1px solid var(--clr-border);
}
