/* ════════════════════════════════════════════════════════════════════════
   12-utilities.css — Globální utility třídy

   Container, eyebrow, section-head, breadcrumb, mezery, helpers.
   Třídy se přidávají Divi modulům přes Advanced → CSS Class.
   ════════════════════════════════════════════════════════════════════════ */

/* ── Container (override Divi row pokud potřeba) ──────────────────
   Šířku řídíme přes width % + max-width cap. Žádný left/right padding.
   Všude:    width 92 %, cap na 1480 px (var(--container))
   Mobil:    width 95 %  (viz 99-responsive.css)

   Při širokém monitoru (≥ ~1610 px) zafunguje cap → vycentrovaný 1480px.
   Mezi 1024 a 1610 px je container 92 % obrazovky → vždy padding na okrajích.
   ───────────────────────────────────────────────────────────────── */
.container {
  width: 92%;
  max-width: var(--container);
  margin: 0 auto;
  padding: 0;
}

/* ── Eyebrow (růžový uppercase text nad H2) ─────────────────────── */
.eyebrow {
  display: inline-block;
  color: var(--pink);
  font-size: var(--fs-eyebrow);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin-bottom: 10px;
}

/* ── Section head (vycentrovaný blok s eyebrow + H2 + popis) ──────
   Použití: na Divi Row přidat CSS Class „section-head", uvnitř 2-3
   Text moduly (nebo jeden Code modul):
     1) Eyebrow (Text modul, class „eyebrow") — volitelný
     2) H2 nadpis
     3) Popis odstavec
   Pro inline HTML variant: <div class="section-head">…</div>
   ──────────────────────────────────────────────────────────────── */
.section-head,
.section-head.et_pb_row {
  text-align: center;
  margin: 0 auto !important;            /* žádný bottom — řídí per-section .et_pb_row + .et_pb_row */
  max-width: var(--container);
  /* Vypnout Divi default column-gap/row-gap 30px mezi sloupci */
  column-gap: 0 !important;
  row-gap: 0 !important;
}

/* Column zabere celou šíři row (default Divi má max-width 760 → off-center).
   Divi 5 column je flex container s row-gap:30px mezi vnořenými moduly —
   přebíjíme na 0, mezery řídíme vlastním margin-top na sousedech.

   Selektor s descendantem .et_pb_column zvyšuje specifičnost na 0,0,3,0
   aby přebíjel per-section overrides (.categories .et_pb_module …). */
.section-head .et_pb_column,
.section-head.et_pb_row .et_pb_column {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  flex: 1 1 100% !important;
  gap: 0 !important;
  column-gap: 0 !important;
  row-gap: 0 !important;
}

/* Jednotlivé Text moduly: vycentrované, max 760 px */
.section-head .et_pb_column .et_pb_module,
.section-head.et_pb_row .et_pb_column .et_pb_module {
  margin: 0 auto !important;
  padding: 0 !important;
  width: 100%;
  max-width: 760px;
  text-align: center;
}

.section-head h2,
.section-head .et_pb_text h2 {
  line-height: 1.15;
  margin: 0;
}
.section-head h2 em,
.section-head .et_pb_text h2 em {
  font-style: normal;
  color: var(--pink);
}
.section-head p,
.section-head .et_pb_text_inner p {
  color: var(--muted);
  max-width: 580px;
  margin: 0 auto !important;
  padding: 0 !important;
  font-size: var(--fs-large);
}

/* Mezery mezi Text moduly v section-head (vyšší specifičnost 0,0,3,0) */
.section-head .et_pb_column .et_pb_module + .et_pb_module,
.section-head.et_pb_row .et_pb_column .et_pb_module + .et_pb_module {
  margin-top: 12px !important;
}

/* Eyebrow Text modul — class eyebrow přebije default Text styly */
.section-head .eyebrow,
.section-head .et_pb_text.eyebrow .et_pb_text_inner,
.section-head .et_pb_text.eyebrow p {
  display: inline-block;
  color: var(--pink) !important;
  font-size: var(--fs-eyebrow) !important;
  font-weight: 700 !important;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  margin: 0 !important;
  padding: 0 !important;
}

/* ── Sekce — modifikátory pozadí ─────────────────────────────────── */
.section-yellow {
  background: var(--bg-warm) !important;
}
.section-yellow-light {
  background: var(--bg-warm-light) !important;
}
.section-soft {
  background: var(--bg-soft) !important;
}
.section-pink-soft {
  background: var(--pink-50) !important;
}
.section-burgundy {
  background: var(--burgundy) !important;
  color: var(--burgundy-text);
}
.section-burgundy h1,
.section-burgundy h2,
.section-burgundy h3,
.section-burgundy h4 {
  color: #fff;
}

/* ── Sekce padding modifikátory ─────────────────────────────────── */
.section-compact { padding: 32px 0 !important; }
.section-medium  { padding: 48px 0 !important; }
.section-large   { padding: 64px 0 !important; }
.section-xl      { padding: 80px 0 !important; }

/* ── Breadcrumb ──────────────────────────────────────────────────── */
.breadcrumb,
.et_pb_breadcrumb_module {
  background: #fff;
  padding: 18px 0 8px;
  font-size: var(--fs-small);   /* už fluid přes clamp token */
  color: var(--muted);
}
.breadcrumb .container,
.et_pb_breadcrumb_module > div {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.breadcrumb a,
.et_pb_breadcrumb_module a {
  color: var(--muted);
}
.breadcrumb a:hover,
.et_pb_breadcrumb_module a:hover {
  color: var(--pink);
}
.breadcrumb .sep,
.et_pb_breadcrumb_module .et_pb_breadcrumb_separator {
  color: #c8c8c8;
}
.breadcrumb .current {
  color: var(--ink);
  font-weight: 600;
}

/* ── Hvězdičky (recenze) ────────────────────────────────────────── */
.stars {
  color: var(--star);
  font-size: var(--fs-small);
  letter-spacing: 1px;
  display: inline-flex;
  gap: 1px;
}

/* ── Tag / chip (univerzální) ────────────────────────────────────── */
.chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: var(--bg-warm);
  border: 1px solid var(--yellow-cta);
  border-radius: var(--radius-pill);
  font-size: var(--fs-small);
  font-weight: 600;
  color: var(--ink);
  transition: all var(--t-fast);
}
.chip:hover {
  background: var(--pink);
  color: #fff;
  border-color: var(--pink);
}
.chip.chip-pink {
  background: var(--pink-50);
  border-color: var(--pink-100);
  color: var(--pink-dark);
}
.chip.chip-green {
  background: var(--success-soft);
  border-color: var(--success-border);
  color: var(--success);
}

/* ── Helper: zobrazení / skrytí ─────────────────────────────────── */
.hide               { display: none !important; }
.hide-mobile        { @media (max-width: 640px) { display: none !important; } }
.show-mobile-only   { display: none !important; }
@media (max-width: 640px) {
  .show-mobile-only { display: block !important; }
  .hide-mobile      { display: none !important; }
}

/* ── Helper: text align ─────────────────────────────────────────── */
.text-center { text-align: center; }
.text-right  { text-align: right; }
.text-left   { text-align: left; }
.text-muted  { color: var(--muted); }
.text-pink   { color: var(--pink); }

/* ── Helper: rychlé spacingy (mimořádně, raději přes section-*) ── */
.mt-0 { margin-top: 0 !important; }
.mt-1 { margin-top: 8px !important; }
.mt-2 { margin-top: 16px !important; }
.mt-3 { margin-top: 24px !important; }
.mt-4 { margin-top: 32px !important; }
.mb-0 { margin-bottom: 0 !important; }
.mb-1 { margin-bottom: 8px !important; }
.mb-2 { margin-bottom: 16px !important; }
.mb-3 { margin-bottom: 24px !important; }
.mb-4 { margin-bottom: 32px !important; }
