/* ============================================================
   components.css — Atoms (button, ribbon, glass card, page-bg,
   topbar, footer chrome, form, icon).
   ============================================================ */

/* ============================================================
   Page background — solid dark per Figma. Footer má vlastní glow
   (.page-footer-glow), všude jinde jednolité tmavé pozadí.
   ============================================================ */
.page-bg {
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: var(--color-bg);
}

/* ============================================================
   Glass card — Transparent I bg + backdrop blur.
   Used for info-boxy, vybaveni tiles, varianty rows, listing cards.
   ============================================================ */
.card-glass {
  background: var(--color-glass-i);
  -webkit-backdrop-filter: blur(var(--blur-glass));
          backdrop-filter: blur(var(--blur-glass));
  border: 1px solid var(--color-glass-ii);
  border-radius: var(--radius-main);
  transition: border-color 0.2s ease, transform 0.2s ease, background 0.2s ease;
}
.card-glass:hover {
  border-color: var(--color-accent-subtle);
}
@supports not (backdrop-filter: blur(10px)) {
  .card-glass { background: rgba(26, 23, 23, 0.7); }
}

/* ============================================================
   Button atom — primary (gold pill) + ghost (gold outline).
   Per Figma: rounded 12px, px-30 py-10, weight 600.
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  height: 5rem;                              /* 50px per Figma */
  padding: 0 3rem;                           /* 30px horizontal */
  border: 1px solid transparent;
  border-radius: var(--radius-main);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--font-size-body);
  line-height: 1;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.1s ease, box-shadow 0.2s ease;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); }
.btn:active { transform: translateY(0); }

.btn--primary {
  background: var(--color-accent-pressed);   /* Button Gold #a67638 */
  color: var(--color-fg);
  /* gold-glow drop shadow per Figma */
  box-shadow: 0 0 1.5rem rgba(216, 160, 88, 0.22);
}
.btn--primary:hover {
  background: var(--color-accent);            /* Gold #d8a058 */
  color: var(--color-bg);
  box-shadow: 0 0 2rem rgba(216, 160, 88, 0.4);
}

/* Ghost / secondary — transparent gold tint per Figma 6:200 */
.btn--ghost {
  background: var(--color-accent-subtle);   /* rgba(216,160,88,0.08) */
  color: var(--color-accent);                /* gold #d8a058 */
  border-color: transparent;
  box-shadow: none;
}
.btn--ghost:hover {
  background: var(--color-accent-glow);      /* rgba(216,160,88,0.22) */
  color: var(--color-accent);
}

.btn--glass {
  background: var(--color-glass-ii);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  color: var(--color-fg);
}
.btn--glass:hover {
  background: var(--color-glass-i);
  color: var(--color-accent);
}

.btn--block { width: 100%; }

/* Tablet/mobil: tlačítka kompaktnější (proporčně k 14/13px base) */
@media (max-width: 1023px) {
  .btn {
    height: 3.6rem;          /* z 50 → ~50px tablet, 47px mobil */
    padding: 0 2rem;         /* z 30 → 28/26px horizontal */
    font-size: 0.95rem;
  }
  .topbar__cta {
    height: 3.2rem;          /* topbar CTA ještě nižší */
    padding: 0 1.6rem;
    font-size: 0.95rem;
  }
}

/* ============================================================
   Marquee — horní oznamovací lišta (Figma node 264:1153).
   Černý pruh, zlatý gradient text, opakuje se a posouvá doleva,
   jednotlivé kopie oddělené zlatou tečkou. Rozměry v rem ⇒ škáluje
   se s webem (1rem = 10px @1920). Vykreslí se jen když je v panelu
   vyplněn text (viz snippet marquee.php).
   ============================================================ */
.marquee {
  overflow: hidden;
  background: #000;                 /* Figma "Lista" = pure black, pod #100f0f stránkou */
  height: 3rem;                     /* 30px @1920 */
  display: flex;
  align-items: center;
  /* Nad vším pod sebou — home-hero se přes margin-top:-11rem vytahuje pod topbar
     a zasahovala do spodních ~5px lišty (bg foto pak ukrajovalo černou). */
  position: relative;
  z-index: 20;
  /* Full-bleed přes celý viewport — vylomí se z body (max-width 1920, centered).
     Na širších obrazovkách lišta jde od kraje ke kraji, ne jen do 1920. */
  width: 100vw;
  margin-left: calc(50% - 50vw);
}
.marquee__track {
  display: flex;
  width: max-content;
  flex-shrink: 0;
  animation: marquee-scroll var(--marquee-duration, 40s) linear infinite;
  will-change: transform;
}
.marquee__group {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.marquee__item {
  display: inline-flex;
  align-items: center;
  gap: var(--space-5);              /* 20px @1920 — mezera tečka↔text */
  padding-right: var(--space-5);    /* stejná mezera mezi kopiemi i na švu skupin */
}
.marquee__dot {
  flex-shrink: 0;
  width: 0.6rem;                    /* 6px @1920 */
  height: 0.6rem;
  color: var(--color-accent);       /* zlatá — currentColor uvnitř SVG */
}
.marquee__text {
  font-family: var(--font-body);
  font-weight: 600;
  /* Stejné clampované rem škálování jako zbytek textů na webu (viz html font-size). */
  font-size: var(--font-size-small);   /* 14px @1920 */
  line-height: 1.9rem;                 /* 19px @1920 — škáluje s webem */
  white-space: nowrap;
  background: var(--gradient-marquee);
  -webkit-background-clip: text;
          background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
@keyframes marquee-scroll {
  from { transform: translateX(0); }
  to   { transform: translateX(-50%); }   /* jedna skupina = bezešvá smyčka */
}
@media (prefers-reduced-motion: reduce) {
  .marquee { justify-content: center; }   /* bez posunu vycentrujeme čitelně */
  .marquee__track { animation: none; }
}
/* Mobil: gradient přes background-clip:text uvnitř animovaného (transform/will-change)
   elementu se na iOS Safari renderuje průhledně → text "zmizí". Fallback na plnou
   zlatou barvu, ať je text vidět. */
@media (max-width: 1023px) {
  .marquee__text {
    background: none;
    -webkit-text-fill-color: var(--color-accent);
    color: var(--color-accent);
    font-size: 1.25rem;   /* na mobilu byl --font-size-small moc malý v poměru k liště */
  }
}

/* ============================================================
   Ribbon — small pill badge for product status.
   ============================================================ */
.ribbon {
  display: inline-block;
  padding: 0.4rem 1rem;
  border-radius: var(--radius-mini);
  font-size: var(--font-size-small);
  font-weight: 600;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}
.ribbon--novinka    { background: var(--color-accent); color: var(--color-bg); }
.ribbon--bestseller { background: var(--color-accent-glow); color: var(--color-accent); }
.ribbon--vyprodano  { background: var(--color-muted); color: var(--color-bg); }

/* ============================================================
   Icon system — SVG sprite via icon() helper.
   Inherits color via currentColor.
   ============================================================ */
.icon {
  display: inline-block;
  width: 2.4rem;
  height: 2.4rem;
  fill: none;
  stroke: currentColor;
  stroke-width: 1.5;
  stroke-linecap: round;
  stroke-linejoin: round;
  vertical-align: middle;
}
.icon--sm { width: 1.6rem; height: 1.6rem; }
.icon--lg { width: 3.6rem; height: 3.6rem; }
.icon--xl { width: 4.8rem; height: 4.8rem; }

/* ============================================================
   Topbar — Logo + center MENU + right CTA.
   Per Figma node 137:668.
   ============================================================ */
.topbar {
  position: relative;
  padding: 4.1rem 0 2rem;
  z-index: 10;
}
.topbar__inner {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: var(--space-5);
}
.topbar__panel {
  display: contents;     /* desktop = panel se chová transparentně, menu+cta jdou přímo do gridu */
}
.topbar__hamburger { display: none; }    /* desktop = hamburger skryt */
.topbar__logo {
  justify-self: start;
  display: inline-flex;
  align-items: center;
  text-decoration: none;
}
.topbar__logo-img {
  width: 21.7rem;       /* 217px @ 1920 — Figma logo dimensions */
  height: 4.4rem;       /* 44px */
  display: block;
}
.topbar__menu {
  display: flex;
  gap: 1rem;
  align-items: center;
}
.topbar__menu-item {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 16rem;
  padding: 1rem 3rem;
  background: var(--color-glass-ii);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border-radius: var(--radius-main);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--font-size-body);
  color: var(--color-fg);
  text-decoration: none;
  transition: background 0.2s ease, color 0.2s ease;
}
.topbar__menu-item:hover {
  background: var(--color-accent-subtle);
  color: var(--color-accent);
}
.topbar__menu-item[aria-current="page"] {
  background: var(--color-accent-glow);
  color: var(--color-accent);
}
.topbar__cta {
  justify-self: end;
  height: 4.2rem;         /* 42px Figma 137:679 — menší než default btn (50px) */
  box-shadow: none;       /* topbar CTA bez glow per Figma 137:679 */
}
.topbar__cta:hover {
  box-shadow: none;
}

@media (max-width: 1023px) {
  .topbar { padding: 1.5rem 0; }
  .topbar__inner { grid-template-columns: auto 1fr; }
  .topbar__logo-img { width: 11rem; height: auto; }     /* zmenšené logo na mobilu/tabletu */

  /* Hamburger button vpravo — zlatá, kompaktní */
  .topbar__hamburger {
    display: inline-flex;
    flex-direction: column;
    justify-content: center;
    gap: 0.4rem;
    justify-self: end;
    width: 3rem;
    height: 3rem;
    padding: 0.6rem;
    background: transparent;
    border: 0;
    cursor: pointer;
    z-index: 11;
  }
  .topbar__hamburger-bar {
    display: block;
    width: 100%;
    height: 0.2rem;
    background: var(--color-accent);   /* gold */
    border-radius: 0.1rem;
    transition: transform 0.2s ease, opacity 0.2s ease;
  }
  /* Otevřený stav → X (translate = gap 0.4 + půl bar 0.1 + půl gap = přesně do středu) */
  .topbar--open .topbar__hamburger-bar:nth-child(1) { transform: translateY(0.6rem) rotate(45deg); }
  .topbar--open .topbar__hamburger-bar:nth-child(2) { opacity: 0; }
  .topbar--open .topbar__hamburger-bar:nth-child(3) { transform: translateY(-0.6rem) rotate(-45deg); }

  /* Panel = full-screen overlay */
  .topbar__panel {
    display: flex;
    flex-direction: column;
    gap: var(--space-5);
    position: fixed;
    inset: 0;
    padding: 10rem var(--margin) var(--space-7);
    background: var(--color-bg);
    -webkit-backdrop-filter: blur(20px);
            backdrop-filter: blur(20px);
    transform: translateX(100%);
    transition: transform 0.25s ease;
    z-index: 10;
    overflow-y: auto;
  }
  .topbar--open .topbar__panel { transform: translateX(0); }

  .topbar__menu {
    flex-direction: column;
    align-items: stretch;
    gap: 1rem;
    width: 100%;
  }
  .topbar__menu-item {
    min-width: 0;
    width: 100%;
    padding: 1.4rem 2rem;
    font-size: var(--font-size-h4);
    text-align: center;
  }
  .topbar__cta {
    width: 100%;
    height: 5rem;
    font-size: var(--font-size-h4);   /* stejně velký text jako ostatní položky menu */
  }
}

/* ============================================================
   Footer — pre-footer CTA + footer chrome.
   Per Figma ALL FOOTER (long variant).
   ============================================================ */
.pre-footer {
  padding: var(--space-7) 0 var(--space-9);   /* 40 top / 100 bottom — méně dechu nad headlinem */
  text-align: center;
}
@media (max-width: 1023px) {
  .pre-footer { padding-left: 30px; padding-right: 30px; }
}
.pre-footer__inner {
  max-width: 90rem;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-5);
}
@media (max-width: 1023px) {
  .pre-footer__inner { gap: var(--space-4); }
}
.pre-footer__headline {
  font-size: 4.4rem;          /* 44px per Figma 6:173 */
  line-height: 5rem;          /* 50px */
  font-weight: 600;
  text-align: center;
  color: var(--color-fg);
  max-width: 79.4rem;         /* 794px per Figma 6:171 */
  margin: 0 auto;
}
@media (max-width: 1023px) {
  .pre-footer__headline { font-size: 2.4rem; line-height: 1.2; }   /* tablet ≈ 34px / mobil ≈ 31px */
  .pre-footer__headline br { display: none; }                      /* na mobilu/tabletu se text slije, žádné force breaks */
}
@media (max-width: 600px) {
  .pre-footer__headline { font-size: 2rem; }                       /* ≈ 26px */
}
.pre-footer__headline em {
  font-style: normal;
  color: var(--color-accent);  /* gold accent na zvýrazněných slovech */
}
.pre-footer__actions {
  display: flex;
  gap: var(--space-4);
  flex-wrap: wrap;
  justify-content: center;
}

/* ============================================================
   Footer area — wrapper s gradientovým pozadím (Figma GLOW 7:387)
   ============================================================ */
.page-footer-area {
  position: relative;
  isolation: isolate;
}

/* Top glow — full-bleed, behind content, na všech sub-stránkách (NE homepage). */
.page-top-glow {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  height: 80rem;             /* fluid (rem clamp) — ≈ 800px @ 1920 */
  z-index: -1;
  pointer-events: none;
  background-image: url('/assets/images/page-top-glow.avif');
  background-size: cover;
  background-position: center top;
  -webkit-mask-image: linear-gradient(180deg, black 0%, black 55%, transparent 100%);
          mask-image: linear-gradient(180deg, black 0%, black 55%, transparent 100%);
}
@media (max-width: 1023px) {
  .page-top-glow { background-image: url('/assets/images/page-top-glow-mobile.avif'); }
}
.page-footer-glow {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;             /* full-bleed mimo body 1920 cap */
  z-index: -1;
  pointer-events: none;
  background-image: url('/assets/images/footer-glow.avif');
  background-size: cover;
  background-position: center bottom;
  -webkit-mask-image: linear-gradient(180deg, transparent 0%, black 42%, black 100%);
          mask-image: linear-gradient(180deg, transparent 0%, black 42%, black 100%);
  opacity: 1;
}
@media (max-width: 1023px) {
  .page-footer-glow { background-image: url('/assets/images/footer-glow-mobile.avif'); }
}

/* ============================================================
   Site footer — per Figma 19:1624 / 7:386 (Footer Main + Bottom)
   ============================================================ */
.site-footer {
  padding-top: var(--space-7);
  padding-bottom: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: 3.1rem;                  /* 31px Figma gap mezi boxem a bottom */
}
.site-footer__main {
  /* card-glass class poskytne bg + border + radius + blur */
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1.6fr);
  gap: 4rem;
  padding: 9rem 12rem 7rem;       /* Figma left:120 top:85 → ~12rem padding */
  min-height: 36rem;              /* 360px */
}
.site-footer__col {
  display: flex;
  flex-direction: column;
  gap: 4rem;                      /* 40px Figma gap heading→links */
}
.site-footer__col--brand {
  gap: 4rem;
}
.site-footer__logo { display: inline-block; }
.site-footer__logo .topbar__logo-img { width: 16rem; height: auto; }
.site-footer__tagline {
  font-size: var(--font-size-body);
  line-height: 2.6rem;
  color: var(--color-muted);
  max-width: 30rem;               /* 300px */
}
.site-footer__heading {
  font-size: var(--font-size-body);
  font-weight: 400;
  color: var(--color-muted);      /* perex barva */
  letter-spacing: 0;
}
.site-footer__links {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2rem;                      /* 20px Figma */
  padding: 0;
}
.site-footer__links li,
.site-footer__contact li { margin-top: 0; }
.site-footer__links a {
  color: var(--color-fg);
  font-weight: 600;
  font-size: var(--font-size-body);
  text-decoration: none;
  transition: color 0.15s ease;
}
.site-footer__links a:hover { color: var(--color-accent); }

.site-footer__contact {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 2rem;
  padding: 0;
}
.site-footer__contact li {
  display: flex;
  align-items: center;
  gap: 1.5rem;                    /* 15px Figma */
}
.site-footer__contact-ico {
  width: 3.6rem;
  height: 3.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--color-accent-subtle);   /* rgba(216,160,88,0.08) */
  border-radius: var(--radius-mini);
  color: var(--color-accent);
  flex-shrink: 0;
}
.site-footer__contact-ico .icon { width: 2.2rem; height: 2.2rem; }   /* +20 % oproti původním 1.8 */
.site-footer__contact a {
  font-family: var(--font-display);
  font-size: 2.6rem;              /* 26px Figma */
  font-weight: 600;
  color: var(--color-fg);
  text-decoration: underline;
  text-decoration-thickness: 1px;
  text-underline-offset: 0.2em;
  white-space: nowrap;
}
.site-footer__contact a:hover { color: var(--color-accent); }

/* Bottom row (mimo box) */
.site-footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-4);
  font-size: var(--font-size-body);
  color: var(--color-muted);
  flex-wrap: wrap;
  padding: 0 var(--space-4);
}
.site-footer__copyright { white-space: nowrap; }
.site-footer__legal {
  list-style: none;
  display: flex;
  gap: 2rem;
  padding: 0;
  margin: 0;
}
.site-footer__legal li { margin-top: 0; }   /* override global li+li rule */
.site-footer__legal a {
  color: var(--color-muted);
  text-decoration: none;
  transition: color 0.15s ease;
}
.site-footer__legal a:hover { color: var(--color-fg); }
.site-footer__credit {
  color: var(--color-muted);
  text-decoration: none;
  white-space: nowrap;
  transition: color 0.15s ease;
}
.site-footer__credit:hover { color: var(--color-accent); }

@media (max-width: 1023px) {
  /* Tablet: logo nahoře, 3 sloupce [about | menu | social], dole celá šířka kontakt */
  .site-footer__main {
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-areas:
      "logo    logo    logo"
      "about   pages   social"
      "contact contact contact";
    gap: var(--space-6) var(--space-5);    /* row 30 / col 40 — větší dech mezi řádky */
    padding: var(--space-5);
    align-items: start;
    min-height: 0;                         /* zrušit desktop min-height: 36rem co natahoval cells */
  }
  /* Brand col rozpadnout aby logo a tagline byly samostatné grid items */
  .site-footer__col--brand { display: contents; }
  .site-footer__logo       { grid-area: logo; }
  .site-footer__tagline    { grid-area: about; margin: 0; }
  .site-footer__col:nth-child(2) { grid-area: pages; }    /* DOM: brand-internals, pages, social, contact */
  .site-footer__col:nth-child(3) { grid-area: social; }
  .site-footer__col--contact     { grid-area: contact; }

  /* Skrýt nadpisy sloupců (samotné odkazy stačí, šetří místo) */
  .site-footer__heading { display: none; }

  /* Bez heading je ten 4rem gap uvnitř col (mezi h4 a obsahem) zbytečný */
  .site-footer__col { gap: 0; }

  .site-footer__logo .topbar__logo-img { width: 11rem; }

  /* Kontakty — mail + tel vedle sebe na jednom řádku, menší font + wrap aby se vešly */
  .site-footer__contact {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 2rem;
  }
  .site-footer__contact a {
    font-size: 1.8rem;
    white-space: normal;
    word-break: break-word;
  }

  /* Bottom: legal nahoře přes celou šířku, pod tím copyright vlevo + credit vpravo na jednom řádku */
  .site-footer__bottom {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-areas:
      "legal legal"
      "copy  credit";
    row-gap: 2rem;          /* víc dechu mezi legal řádkem a copyright řádkem */
    column-gap: 0.8rem;
    align-items: center;
  }
  .site-footer__legal     { grid-area: legal; }
  .site-footer__copyright { grid-area: copy; }
  .site-footer__credit    { grid-area: credit; justify-self: end; }

  /* Bottom blíž k box paticky — menší gap mezi card-glass a copyright řádkem */
  .site-footer { gap: 1.6rem; }
}
@media (max-width: 600px) {
  /* Mobil: 2 sloupce [pages | social], logo nahoře, kontakt dole, about skryto */
  .site-footer__main {
    grid-template-columns: 1fr 1fr;
    grid-template-areas:
      "logo    logo"
      "pages   social"
      "contact contact";
  }
  .site-footer__tagline { display: none; }
  .site-footer__contact a { font-size: 1.6rem; }
}

/* ============================================================
   Site main wrapper.
   ============================================================ */
.site-main {
  /* žádný bottom padding — poslední blok / pre-footer drží mezeru sami */
  position: relative;
  flex: 1 0 auto;   /* sticky footer — vyplní volnou výšku, patička jde dolů */
}

/* ============================================================
   Form — contact form styling.
   ============================================================ */
.form-field { display: grid; gap: 0.6rem; }
.form-field label {
  font-size: var(--font-size-body);
  font-weight: 500;
  color: var(--color-fg);
  text-align: left;        /* zarovnání s krajem inputu i v centered parentu */
}
.form-field input,
.form-field textarea {
  font: inherit;
  padding: 1.2rem 1.4rem;
  background: var(--color-glass-ii);
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border: 1px solid var(--color-glass-ii);   /* Transparent II per Figma — #f1e9db @ 3% */
  border-radius: var(--radius-mini);     /* 6px */
  color: var(--color-fg);
  width: 100%;
  transition: border-color 0.15s ease, background 0.15s ease;
}
.form-field input:hover,
.form-field textarea:hover {
  background: var(--color-accent-subtle);   /* "Transparent Gold" #d8a05814 */
}
.form-field input:focus,
.form-field textarea:focus {
  outline: none;
  border-color: var(--color-accent);
  background: var(--color-accent-subtle);
}
.form-field textarea {
  min-height: 12rem;
  resize: vertical;
}
.form-field input::placeholder,
.form-field textarea::placeholder {
  color: var(--color-muted);
}

/* Per Figma 19:2756 — 20px gold-outlined box, gold checkmark, text vertically centered */
.form-checkbox {
  display: inline-flex;                 /* hug content, ne fill grid cell */
  align-items: center;                  /* checkbox vystředěný s textem */
  gap: 1rem;                            /* 10px Figma */
  font-size: var(--font-size-body);     /* 16px Figma */
  color: var(--color-fg);               /* white per Figma */
  cursor: pointer;
  justify-self: center;                 /* horizontálně na střed v grid parentu (.contact-form) */
}
.form-checkbox input[type="checkbox"] {
  appearance: none;
  -webkit-appearance: none;
  width: 2rem;                          /* 20px Figma */
  height: 2rem;
  margin: 0;
  flex-shrink: 0;
  background: transparent;
  border: 1px solid var(--color-accent);
  border-radius: var(--radius-mini);    /* 6px */
  cursor: pointer;
  background-position: center;
  background-repeat: no-repeat;
  background-size: 70%;
  transition: background-color 0.15s ease, border-color 0.15s ease;
}
.form-checkbox input[type="checkbox"]:hover {
  background-color: var(--color-accent-subtle);   /* Figma "Transparent Gold" #d8a05814 — jen na hover */
}
.form-checkbox input[type="checkbox"]:checked {
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 14 14' fill='none' stroke='%23d8a058' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='2.5,7.5 6,11 11.5,3.5'/></svg>");
}
.form-checkbox input[type="checkbox"]:focus-visible {
  outline: 2px solid var(--color-accent);
  outline-offset: 2px;
}
.form-checkbox__link {
  color: var(--color-fg);            /* white per Figma */
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-underline-offset: 0.2em;
}
.form-checkbox__link:hover { color: var(--color-accent); }

.contact-form {
  display: grid;
  gap: var(--space-4);
}
.contact-form__row-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
@media (max-width: 1023px) {
  .contact-form__row-2 { grid-template-columns: 1fr; }
  .contact-form { gap: var(--space-3); }                /* z 16 → 10 mezi řádky */
  .form-field { gap: 0.4rem; }                          /* z 6 → 4 (label↔input) */
  .form-field input, .form-field textarea {
    padding: 1rem 1.2rem;
    font-size: 16px;     /* iOS NEZOOMUJE input s font-size ≥ 16px */
  }
  .form-field textarea { min-height: 9rem; }
  .form-field label { font-size: 0.95rem; }
  .form-checkbox { font-size: 0.95rem; gap: 0.7rem; justify-self: start; text-align: left; }
  .form-checkbox input[type="checkbox"] { width: 1.6rem; height: 1.6rem; }
}
.contact-form__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px; height: 1px;
  overflow: hidden;
}
.contact-form__submit-row {
  display: flex;
  justify-content: center;
  margin-top: var(--space-3);
}
.contact-form__status {
  font-size: var(--font-size-body);
  text-align: center;
  min-height: 1.5em;
}
.contact-form__status--success { color: var(--color-accent); }
.contact-form__status--error   { color: #e15a5a; }

.contact-form__success {
  text-align: center;
  padding: var(--space-6) var(--space-4);
  color: var(--color-accent);
  font-size: var(--font-size-h4);
  outline: none;
}
