/* ============================================================================
   Farma Pech — Rezervační systém samosběrů
   Vizuální design tokeny + komponenty (1:1 dle schválených mockupů)
   ----------------------------------------------------------------------------
   Tento soubor je ZÁVAZNÝ zdroj vzhledu. Hodnoty odpovídají mockupům
   v "Rezervační systém Farma Pech.html". Neměň hex/px hodnoty — používej
   tyto třídy a proměnné, ať je výsledek pixel-přesný.

   Použití ve WordPressu: načti tento soubor přes wp_enqueue_style() na
   stránce rezervace i v adminu. Markup obaluj prefixem .fp- (viz třídy níže).
   ============================================================================ */

/* ---- FONTY ---- */
/* Načti přes wp_enqueue_style nebo <link>:
   https://fonts.googleapis.com/css2?family=Roboto+Slab:wght@400;500;700;800&family=Nunito:wght@400;600;700;800&display=swap */

:root {
  /* — Barvy (design systém Farma Pech) — */
  --fp-brand-green:    #30913c; /* primární CTA, odkazy, akcenty, výběr */
  --fp-header-green:   #01b159; /* navigační / hlavičková lišta */
  --fp-green-dark:     #1e2a18; /* tmavé plochy: hero, admin sidebar */
  --fp-green-dark-2:   #27341f; /* karty na tmavém pozadí */
  --fp-yellow:         #ffe372; /* announcement bar, urgence */
  --fp-mint:           #f3f8f1; /* světlé zvýrazněné plochy, vybraný stav */
  --fp-mint-border:    #d8e6d6; /* okraj mint ploch */
  --fp-surface:        #ffffff; /* karty, pozadí formuláře */
  --fp-page-bg:        #f6f8f6; /* pozadí stránky/adminu */
  --fp-text:           #1f1f1f; /* hlavní text */
  --fp-text-muted:     #777777; /* sekundární text */
  --fp-border:         #dadada; /* okraje, předěly */

  /* stavové barvy */
  --fp-error:          #c0392b; /* chyby, plné/vyprodané */
  --fp-error-bg:       #fbf2f2;
  --fp-error-border:   #f0d9d9;
  --fp-warn-text:      #7a6310;
  --fp-warn-bg:        #fff7e0;
  --fp-warn-border:    #f0e0a8;

  /* text na tmavém pozadí */
  --fp-on-dark:        #ffffff;
  --fp-on-dark-soft:   #cdd8c8;
  --fp-on-dark-green:  #8ed29a;

  /* — Typografie — */
  --fp-font-head: "Roboto Slab", Georgia, serif;
  --fp-font-body: "Nunito", system-ui, sans-serif;

  /* — Rádiusy — */
  --fp-r-sm:   6px;
  --fp-r-card: 10px;  /* primární rádius karet/tlačítek (DS token "card") */
  --fp-r-lg:   12px;  /* větší karty, telefon obrazovky */

  /* — Stíny (validované DS tokeny) — */
  --fp-shadow-btn:  0px 6px 14px -6px rgba(13,74,30,0.6);   /* green-drop-sm */
  --fp-shadow-card: 0px 22px 50px -24px rgba(13,74,30,0.6); /* green-drop-lg */

  /* — Spacing (5px grid) — */
  --fp-sp-1: 4px;  --fp-sp-2: 8px;  --fp-sp-3: 12px;
  --fp-sp-4: 16px; --fp-sp-5: 20px; --fp-sp-6: 24px; --fp-sp-8: 32px;
}

/* ---- ZÁKLAD ---- */
.fp-app { font-family: var(--fp-font-body); color: var(--fp-text); line-height: 1.5; }
.fp-app *, .fp-app *::before, .fp-app *::after { box-sizing: border-box; }
.fp-h1 { font-family: var(--fp-font-head); font-weight: 800; font-size: 24px; margin: 0; }
.fp-h2 { font-family: var(--fp-font-head); font-weight: 700; font-size: 19px; margin: 0; }
.fp-label-up { font-family: var(--fp-font-body); font-size: 11px; font-weight: 800;
  letter-spacing: 0.55px; text-transform: uppercase; }

/* ============================================================================
   HLAVIČKA OBRAZOVKY (mobil) — zelená lišta + krok
   ============================================================================ */
.fp-screen-header {
  background: var(--fp-header-green); color: var(--fp-on-dark);
  padding: 13px 16px; display: flex; align-items: center; gap: 10px;
}
.fp-screen-header__title { font-family: var(--fp-font-head); font-weight: 700; font-size: 15px; }
.fp-screen-header__sub   { font-size: 11px; opacity: 0.9; }
.fp-back { font-size: 18px; cursor: pointer; }

/* ANNOUNCEMENT BAR (desktop) */
.fp-announce {
  background: var(--fp-yellow); color: var(--fp-text); text-align: center;
  font-size: 12px; font-weight: 800; letter-spacing: 0.3px; padding: 7px;
}

/* NAVIGACE (chrome) — sdílená napříč všemi celostránkovými šablonami
   (rezervace, právní stránky, 404). Proto žije v base, ne v layout vrstvě. */
.fp-nav {
  background: var(--fp-header-green); color: var(--fp-on-dark);
  padding: 12px 26px; display: flex; align-items: center; gap: 18px;
  font-size: 14px; font-weight: 700;
}
.fp-nav__brand { display: inline-flex; align-items: center; }
.fp-nav__logo { height: 42px; width: auto; display: block; } /* farma-pech-logo.svg */
.fp-nav a { color: rgba(255,255,255,0.85); text-decoration: none; }
.fp-nav a.is-active { background: rgba(255,255,255,0.2); padding: 5px 12px; border-radius: var(--fp-r-sm); color:#fff; }

/* Hlavní akce vpravo v zelené hlavičce */
.fp-nav__menu { margin-left: auto; display: flex; align-items: center; gap: 18px; }
.fp-nav__myres { color: rgba(255,255,255,0.9) !important; font-weight: 700; }
.fp-nav__myres:hover { color: #fff !important; text-decoration: underline; }
.fp-nav__myres[hidden] { display: none; }
/* Stejný tvar jako .fp-btn, jen invertované na zelené hlavičce. */
.fp-nav__cta {
  background: #fff; color: var(--fp-brand-green) !important;
  padding: 10px 20px; border-radius: var(--fp-r-card); border: 0;
  font-family: var(--fp-font-body); font-weight: 800; font-size: 14.5px;
  box-shadow: var(--fp-shadow-btn);
  transition: transform .12s ease, box-shadow .12s ease;
}
.fp-nav__cta:hover { transform: translateY(-1px); box-shadow: 0 9px 20px -7px rgba(13,74,30,0.6); }

/* Kontextově dělený model na mobilu/tabletu: plná hlavička všude KROMĚ aktivního
   průvodce (body.fp-flow-active), kde kontext drží zelený krokový pruh v aplikaci.
   Žlutý promo pruh (.fp-announce) ale zobrazujeme i v průvodci na mobilu. */
@media (max-width: 780px) {
  body.fp-flow-active .fp-nav { display: none !important; }
  .fp-nav__items { display: none; } /* vlastní odkazy menu — místo na logo + akce */
  .fp-nav { padding: 10px 16px; gap: 10px; }
  .fp-nav__logo { height: 26px; }
  .fp-nav__menu { gap: 12px; }
  .fp-nav__cta { padding: 8px 14px; font-size: 13px; }
}

/* ============================================================================
   PROGRESS — 6 kroků (mobil) / boční stepper (desktop)
   ============================================================================ */
.fp-progress { display: flex; gap: 4px; padding: 10px 16px; }
.fp-progress__seg { flex: 1; height: 5px; border-radius: 3px; background: #cfe3cd; }
.fp-progress__seg.is-done { background: var(--fp-brand-green); }

.fp-sidebar { background: var(--fp-mint); border-right: 1px solid #e3e7e2; padding: 26px 22px; }
.fp-sidebar__step { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.fp-sidebar__step:last-child { margin-bottom: 0; }
.fp-sidebar__num {
  width: 26px; height: 26px; border-radius: 50%; flex: none;
  display: flex; align-items: center; justify-content: center;
  font-size: 13px; font-weight: 800;
  background: #dfeede; color: var(--fp-brand-green);
}
.fp-sidebar__step.is-active .fp-sidebar__num,
.fp-sidebar__step.is-done   .fp-sidebar__num { background: var(--fp-brand-green); color: #fff; }
.fp-sidebar__step.is-upcoming { opacity: 0.5; }

/* ============================================================================
   TLAČÍTKA
   ============================================================================ */
.fp-btn {
  display: inline-flex; align-items: center; justify-content: center;
  font-family: var(--fp-font-body); font-weight: 800; font-size: 16px;
  padding: 16px; border-radius: var(--fp-r-card); border: 0; cursor: pointer;
  width: 100%; text-align: center;
}
.fp-btn--primary { background: var(--fp-brand-green); color: #fff; box-shadow: var(--fp-shadow-btn); }
.fp-btn--secondary { background: #fff; color: var(--fp-text); border: 1px solid var(--fp-border); }
.fp-btn--danger { background: var(--fp-error); color: #fff; }
.fp-btn:disabled, .fp-btn.is-disabled { background: #bcbcbc; color: #fff; box-shadow: none; cursor: not-allowed; }
.fp-btn--inline { width: auto; padding: 13px 30px; font-size: 15px; }

/* ============================================================================
   KARTA PLODINY (krok 1)
   ============================================================================ */
.fp-crop {
  border: 1px solid var(--fp-border); border-radius: var(--fp-r-lg);
  overflow: hidden; background: #fff; cursor: pointer; position: relative;
}
.fp-crop.is-selected { border: 2px solid var(--fp-brand-green); }
.fp-crop.is-disabled { opacity: 0.5; pointer-events: none; }
.fp-crop__img { height: 88px; display: flex; align-items: center; justify-content: center; font-size: 40px; }
.fp-crop__body { padding: 10px 12px; }
.fp-crop__name { font-family: var(--fp-font-head); font-weight: 700; font-size: 16px; }
.fp-crop__meta { font-size: 12px; color: var(--fp-brand-green); font-weight: 700; }
.fp-crop__badge {
  position: absolute; top: 8px; right: 8px; background: var(--fp-brand-green);
  color: #fff; font-size: 10px; font-weight: 800; padding: 3px 8px; border-radius: 20px;
}

/* ============================================================================
   ŘÁDEK DNE (krok 2) — Limit A (kg)
   ============================================================================ */
.fp-day {
  border: 1px solid var(--fp-border); border-radius: var(--fp-r-lg);
  padding: 14px; margin-bottom: 10px; display: flex; align-items: center; gap: 12px;
  background: #fff; cursor: pointer;
}
.fp-day.is-selected { border: 2px solid var(--fp-brand-green); background: var(--fp-mint); }
.fp-day.is-soldout { opacity: 0.55; pointer-events: none; }
.fp-day__date {
  text-align: center; border-radius: var(--fp-r-sm); padding: 6px 10px; min-width: 48px;
  background: #eef1ee; color: var(--fp-text);
}
.fp-day.is-selected .fp-day__date { background: var(--fp-brand-green); color: #fff; }
.fp-day__date-num { font-family: var(--fp-font-head); font-weight: 800; font-size: 18px; line-height: 1; }
.fp-day__date-mon { font-size: 10px; font-weight: 700; }
.fp-day__name { font-weight: 800; font-size: 14px; }
.fp-day__kg { font-size: 11px; color: var(--fp-brand-green); font-weight: 700; margin-top: 2px; }
.fp-day__kg--soldout { color: var(--fp-error); font-weight: 800; }
/* progress bar zbývajících kg */
.fp-bar { height: 6px; background: #dfeede; border-radius: 4px; overflow: hidden; margin-top: 5px; }
.fp-bar__fill { height: 100%; background: var(--fp-brand-green); }

/* ============================================================================
   MŘÍŽKA SLOTŮ (krok 3) — Limit B (osoby)
   ============================================================================ */
.fp-slots { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.fp-slot {
  border: 1px solid var(--fp-border); border-radius: var(--fp-r-lg);
  padding: 14px 10px; text-align: center; background: #fff; cursor: pointer; position: relative;
}
.fp-slot.is-selected { border: 2px solid var(--fp-brand-green); background: var(--fp-mint); }
.fp-slot.is-full { border-color: var(--fp-error-border); background: var(--fp-error-bg); opacity: 0.75; pointer-events: none; }
.fp-slot__time { font-family: var(--fp-font-head); font-weight: 700; font-size: 19px; }
.fp-slot.is-selected .fp-slot__time { color: var(--fp-brand-green); }
.fp-slot.is-full .fp-slot__time { color: #b0463a; }
.fp-slot__free { font-size: 11px; color: var(--fp-brand-green); font-weight: 800; margin-top: 3px; }
.fp-slot__kg { display: block; font-size: 10.5px; color: var(--fp-text-muted); font-weight: 700; margin-top: 2px; }
.fp-slot.is-full .fp-slot__free { color: var(--fp-error); }

/* ============================================================================
   STEPPER (krok 4) — počet osob / kg
   ============================================================================ */
.fp-stepper {
  display: flex; align-items: center; justify-content: space-between;
  border: 1px solid var(--fp-border); border-radius: var(--fp-r-lg); padding: 10px 14px;
}
.fp-stepper.is-invalid { border: 2px solid var(--fp-error); }
.fp-stepper__btn {
  width: 46px; height: 46px; border-radius: 50%; font-size: 26px; font-weight: 800;
  display: flex; align-items: center; justify-content: center; cursor: pointer; border: 0;
}
.fp-stepper__btn--minus { background: var(--fp-mint); border: 2px solid var(--fp-brand-green); color: var(--fp-brand-green); }
.fp-stepper__btn--plus  { background: var(--fp-brand-green); color: #fff; }
.fp-stepper__btn:disabled { background: #e6e6e6; color: #aaa; border-color: #e6e6e6; cursor: not-allowed; }
.fp-stepper__value { text-align: center; font-family: var(--fp-font-head); font-weight: 800; font-size: 30px; line-height: 1; }
.fp-stepper__hint { font-size: 11px; color: var(--fp-text-muted); }

/* ============================================================================
   FORMULÁŘOVÁ POLE (krok 5)
   ============================================================================ */
.fp-field { margin-bottom: 12px; }
.fp-field__label { font-size: 12px; font-weight: 800; color: #444; }
.fp-input {
  width: 100%; border: 1px solid var(--fp-border); border-radius: var(--fp-r-card);
  padding: 13px 14px; margin-top: 5px; font-size: 14px; font-family: var(--fp-font-body);
}
.fp-input.is-valid { border: 2px solid var(--fp-brand-green); }
.fp-input.is-invalid { border: 2px solid var(--fp-error); }
.fp-field__error { font-size: 12px; color: var(--fp-error); font-weight: 700; margin-top: 6px; }

/* segmentová volba notifikací / souhlasy */
.fp-segment { display: flex; flex-direction: column; gap: 8px; margin-top: 7px; }
.fp-segment__opt { border: 1px solid var(--fp-border); border-radius: var(--fp-r-card);
  padding: 11px 13px; font-size: 13px; font-weight: 700; color: #555; cursor: pointer; }
.fp-segment__opt.is-selected { border: 2px solid var(--fp-brand-green); background: var(--fp-mint);
  color: var(--fp-brand-green); font-weight: 800; }
.fp-check { display: flex; gap: 9px; align-items: flex-start; margin-top: 10px; }
.fp-check__box { width: 20px; height: 20px; border: 2px solid #cfcfcf; border-radius: 5px; flex: none; margin-top: 1px; }
.fp-check__box.is-checked { background: var(--fp-brand-green); border-color: var(--fp-brand-green);
  color: #fff; display: flex; align-items: center; justify-content: center; font-size: 13px; font-weight: 800; }

/* ============================================================================
   SOUHRNNÁ KARTA (krok 6) + POTVRZENÍ
   ============================================================================ */
.fp-summary { border: 1px solid var(--fp-mint-border); border-radius: var(--fp-r-lg); overflow: hidden; }
.fp-summary__head { background: var(--fp-mint); padding: 12px 14px; display: flex; align-items: center; gap: 10px;
  border-bottom: 1px solid var(--fp-mint-border); }
.fp-summary__row { display: flex; justify-content: space-between; padding: 8px 0; font-size: 13px; border-bottom: 1px solid #f0f0f0; }
.fp-summary__row:last-child { border-bottom: 0; }
.fp-success { background: var(--fp-brand-green); color: #fff; text-align: center; padding: 34px 20px 30px; }
.fp-success__check { width: 66px; height: 66px; border-radius: 50%; background: rgba(255,255,255,0.18);
  display: flex; align-items: center; justify-content: center; font-size: 34px; margin: 0 auto 14px; }

/* ============================================================================
   STAVOVÉ HLÁŠKY (info / warning / error)
   ============================================================================ */
.fp-note { border-radius: var(--fp-r-sm); padding: 10px 12px; font-size: 11.5px; line-height: 1.5; }
.fp-note--ok    { background: var(--fp-mint); color: var(--fp-brand-green); font-weight: 700; }
.fp-note--info  { background: var(--fp-warn-bg); border: 1px solid var(--fp-warn-border); color: var(--fp-warn-text); }
.fp-note--error { background: var(--fp-error-bg); border: 1px solid var(--fp-error-border); color: var(--fp-error); font-weight: 700; }

/* badge */
.fp-badge { font-size: 11px; font-weight: 800; padding: 4px 9px; border-radius: 20px; }
.fp-badge--ok { background: #e3f3e4; color: #1f7a2b; }
.fp-badge--soldout { background: var(--fp-error-bg); color: var(--fp-error); }

/* ============================================================================
   MODAL (slot zaplněn / duplicita)
   ============================================================================ */
.fp-modal__overlay { position: absolute; inset: 0; background: rgba(20,30,16,0.45);
  display: flex; align-items: center; justify-content: center; padding: 18px; }
.fp-modal { background: #fff; border-radius: 14px; padding: 22px 18px; text-align: center;
  box-shadow: 0px 18px 40px -10px rgba(0,0,0,0.4); max-width: 380px; }
.fp-modal__title { font-family: var(--fp-font-head); font-weight: 700; font-size: 17px; margin-top: 6px; }
.fp-modal__text { font-size: 12.5px; color: #666; margin-top: 6px; }

/* ============================================================================
   ADMIN — KPI dlaždice, tabulka, sloty
   ============================================================================ */
.fp-kpi { background: #fff; border: 1px solid #e3e7e2; border-radius: var(--fp-r-card); padding: 16px 18px; }
.fp-kpi--dark { background: var(--fp-green-dark); border: 0; color: #fff; }
.fp-kpi__label { font-size: 12px; color: var(--fp-text-muted); font-weight: 700; }
.fp-kpi--dark .fp-kpi__label { color: var(--fp-on-dark-green); }
.fp-kpi__value { font-family: var(--fp-font-head); font-weight: 800; font-size: 30px; }
.fp-kpi__value--green { color: var(--fp-brand-green); }
.fp-kpi--dark .fp-kpi__value { color: var(--fp-yellow); }

/* ============================================================================
   RESPONSIVE
   ============================================================================ */
@media (max-width: 780px) {
  .fp-desktop-only { display: none !important; }
  .fp-slots { grid-template-columns: 1fr 1fr; }
}
@media (min-width: 781px) {
  .fp-mobile-only { display: none !important; }
  /* desktop layout: boční stepper + obsah */
  .fp-layout { display: grid; grid-template-columns: 240px 1fr; background: #fff; }
  .fp-content { padding: 30px 34px; }
}

/* sticky spodní CTA (mobil) */
.fp-sticky-cta { position: sticky; bottom: 0; background: #fff; padding: 12px 16px; border-top: 1px solid #eee; }

/* ============================================================================
   PATIČKA — decentní, v typografii a grafice Farma Pech
   Tmavá zelená plocha (DS „dark surface"), název v Roboto Slab, zbytek Nunito.
   ============================================================================ */
.fp-foot {
  position: relative;
  overflow: hidden;
  background: var(--fp-green-dark);
  color: var(--fp-on-dark-soft);
  font-family: var(--fp-font-body);
  /* horní padding s rezervou, aby copyright „nedýchal" na vlně brázd */
  padding: 36px var(--fp-sp-5) 0;

  /* Horní hrana = zoraná půda: místo ostrého řezu mělká vlna brázd.
     Patička se stává „zemí", na které farma stojí (váže na traktor + klíčící
     plody dole). Čistě maskou – nula markupu, nula JS, nula CLS.
     Pásmo brázd je jen 14px vysoké, takže zůstává nad textem. */
  --fp-foot-ridge:
    url("data:image/svg+xml,%3Csvg%20xmlns='http://www.w3.org/2000/svg'%20viewBox='0%200%20160%2014'%20preserveAspectRatio='none'%3E%3Cpath%20d='M0%2014%20L0%2012%20Q40%203%2080%2012%20Q120%203%20160%2012%20L160%2014%20Z'%20fill='%23fff'/%3E%3C/svg%3E");
  -webkit-mask:
    var(--fp-foot-ridge) top left / 160px 14px repeat-x,
    linear-gradient(#000, #000) bottom left / 100% calc(100% - 13px) no-repeat;
          mask:
    var(--fp-foot-ridge) top left / 160px 14px repeat-x,
    linear-gradient(#000, #000) bottom left / 100% calc(100% - 13px) no-repeat;
}
/* sluneční nádech na hřebenech brázd (maska ho ořízne podél hrany) */
.fp-foot::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 14px;
  background: linear-gradient(180deg, rgba(255, 255, 255, 0.07), rgba(255, 255, 255, 0));
  pointer-events: none;
}
.fp-foot__inner {
  max-width: 1240px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  text-align: center;
}
.fp-foot__brand {
  margin: 0;
  font-size: 13px;
  font-weight: 600;
  letter-spacing: 0.2px;
  color: var(--fp-on-dark-soft);
}
.fp-foot__brand-name {
  font-family: var(--fp-font-head);
  font-weight: 700;
  color: var(--fp-on-dark);
  letter-spacing: 0.3px;
}
.fp-foot__links {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
}
.fp-foot__link {
  color: var(--fp-on-dark-green);
  text-decoration: none;
  font-size: 12.5px;
  font-weight: 700;
  transition: color 0.15s ease;
}
.fp-foot__link:hover,
.fp-foot__link:focus-visible { color: var(--fp-on-dark); }
.fp-foot__dot {
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: var(--fp-on-dark-green);
  opacity: 0.6;
}
.fp-foot__credit {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 2px;
  text-decoration: none;
  color: rgba(255, 255, 255, 0.5);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.2px;
  transition: color 0.15s ease, opacity 0.15s ease;
}
.fp-foot__credit:hover,
.fp-foot__credit:focus-visible { color: rgba(255, 255, 255, 0.85); }
.fp-foot__credit-logo {
  height: 13px;
  width: auto;
  display: block;
  opacity: 0.75;
  transition: opacity 0.15s ease;
}
.fp-foot__credit:hover .fp-foot__credit-logo,
.fp-foot__credit:focus-visible .fp-foot__credit-logo { opacity: 1; }

/* — Emoji „políčko" na spodní hraně patičky (pozn.: NE .fp-field, ta patří
   formulářovým polím v rezervaci – jinak kolize) — */
.fp-foot__inner { margin-bottom: 8px; }
.fp-foot__field {
  width: 100%;
  height: 44px;
  margin-top: 2px;
  line-height: 0;          /* žádná inline mezera pod SVG */
  pointer-events: none;
}
.fp-foot__field svg {
  display: block;
  width: 100%;
  height: 44px;
}
/* emoji traktor přebarvíme do zelena (sladění s identitou Farma Pech) */
.fp-foot__tractor {
  filter: hue-rotate(78deg) saturate(1.25) brightness(0.92);
}

@media (prefers-reduced-motion: reduce) {
  .fp-foot__link,
  .fp-foot__credit,
  .fp-foot__credit-logo { transition: none; }
  /* JS vykreslí statickou scénu pole bez pohybu (viz footer-field.js) */
}
