/* ============================================================================
   Farma Pech — právní stránky (Ochrana OÚ, Obchodní podmínky)
   Vzhled sladěný s rezervačním systémem. Tokeny z farma-pech.css.
   ============================================================================ */

/* Sticky-footer layout (farma-pech.css neobsahuje body layout celostránky) */
body.fp-legal-body {
  margin: 0;
  background: var(--fp-page-bg);
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  font-family: var(--fp-font-body);
  color: var(--fp-text);
  -webkit-font-smoothing: antialiased;
}
.fp-legal-page {
  flex: 1 0 auto;
  width: 100%;
  padding: clamp(24px, 5vw, 48px) 16px clamp(32px, 6vw, 56px);
  box-sizing: border-box;
}
.fp-foot { flex-shrink: 0; }

/* Karta dokumentu */
.fp-legal {
  max-width: 760px;
  margin: 0 auto;
  background: var(--fp-surface);
  border: 1px solid var(--fp-border);
  border-radius: var(--fp-r-lg);
  box-shadow: var(--fp-shadow-card);
  padding: clamp(22px, 4.5vw, 52px);
  box-sizing: border-box;
}
.fp-legal *,
.fp-legal *::before,
.fp-legal *::after { box-sizing: border-box; }

/* Nadpisy – Roboto Slab */
.fp-legal__title {
  font-family: var(--fp-font-head);
  font-weight: 800;
  font-size: clamp(26px, 4.5vw, 38px);
  line-height: 1.15;
  color: var(--fp-text);
  margin: 0 0 22px;
  letter-spacing: -0.01em;
}
.fp-legal__body { font-size: 16.5px; line-height: 1.72; color: var(--fp-text); }

.fp-legal__body h2 {
  font-family: var(--fp-font-head);
  font-weight: 700;
  font-size: clamp(19px, 2.6vw, 23px);
  line-height: 1.25;
  color: var(--fp-brand-green);
  margin: 38px 0 12px;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--fp-mint-border);
}
.fp-legal__body h3 {
  font-family: var(--fp-font-head);
  font-weight: 600;
  font-size: clamp(16px, 2vw, 18px);
  color: var(--fp-text);
  margin: 24px 0 8px;
}
.fp-legal__body > h2:first-child,
.fp-legal__body > p:first-child { margin-top: 0; }

/* Text */
.fp-legal__body p { margin: 0 0 14px; }
.fp-legal__body strong { font-weight: 700; }
.fp-legal__body em { color: var(--fp-text-muted); font-style: italic; }

/* Úvodní perex (první <em> odstavec) */
.fp-legal__body > p:first-child em,
.fp-legal__body > p:first-child {
  font-size: 17.5px;
  line-height: 1.6;
}

/* Odkazy */
.fp-legal__body a {
  color: var(--fp-brand-green);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  font-weight: 600;
  transition: color 0.15s ease;
}
.fp-legal__body a:hover,
.fp-legal__body a:focus-visible { color: var(--fp-header-green); }

/* Seznamy */
.fp-legal__body ul,
.fp-legal__body ol { margin: 0 0 16px; padding-left: 22px; }
.fp-legal__body li { margin: 0 0 7px; }
.fp-legal__body ul li::marker { color: var(--fp-brand-green); }
.fp-legal__body ol li::marker { color: var(--fp-brand-green); font-weight: 700; }

/* Inline kód (localStorage apod.) */
.fp-legal__body code {
  font-family: ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: 0.88em;
  background: var(--fp-mint);
  border: 1px solid var(--fp-mint-border);
  border-radius: var(--fp-r-sm);
  padding: 1px 6px;
}

/* Tabulka (právní základ zpracování) */
.fp-legal__body table {
  width: 100%;
  border-collapse: collapse;
  margin: 4px 0 20px;
  font-size: 14.5px;
  border: 1px solid var(--fp-mint-border);
  border-radius: var(--fp-r-card);
  overflow: hidden;
}
.fp-legal__body thead th {
  background: var(--fp-mint);
  font-family: var(--fp-font-head);
  font-weight: 700;
  text-align: left;
  color: var(--fp-text);
}
.fp-legal__body th,
.fp-legal__body td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--fp-mint-border);
  vertical-align: top;
}
.fp-legal__body tbody tr:last-child td { border-bottom: 0; }
.fp-legal__body tbody tr:nth-child(even) td { background: rgba(243, 248, 241, 0.5); }

/* Mobil: tabulka se scrollem, ať se nerozbije úzké rozvržení */
@media (max-width: 600px) {
  .fp-legal__body table { display: block; overflow-x: auto; white-space: nowrap; }
  .fp-legal__body td,
  .fp-legal__body th { white-space: normal; min-width: 120px; }
}

@media (prefers-reduced-motion: reduce) {
  .fp-legal__body a { transition: none; }
}
