/*user css DEER*/
.mod-languages {
    position: relative;
    top: 20px;
}
html:not(.nav-ready) .mod-menu.klasic.desktop.magazin {
  visibility: hidden;
}
.napoje .mb-4.d-flex.flex-wrap.gap-2 {
    margin-bottom: var(--space-5) !important;
}
.napoje .bhglist-container span.ms-1.mb-2.typo-b1.mw400.pb-3.border-bottom {
    border-bottom: 0!important;
    margin-left: 0 !important;
}
select#bhgfgLangSelect, button#bhgfgRestoreBtn {
    border-radius: 8px;
}
div#mod-bhg-share-148 {
    margin-top: var(--space-4);
}
/* ==========================================================
   TEXT COLORS – use tokens from typography.css (NO hardcode)
   Body text  -> --c-merlot-300
   Headings   -> --c-merlot-400
   ========================================================== */
html.hp-hero-step3 header {
    background-color: var(--c-forest-400) !important;
}
html.hp-hero-free .mag-lead-fullbleed .hero-scrollcue {
    display: none !important;
    visibility: hidden;
}
body:not(.bhg-room-mode) .item-1463,
body:not(.bhg-room-mode) .item-1464 {
    display:none !important;
}
.text-secondary {
    color: var(--c-merlot-400) !important;
}
body.site.error_site {
    background-color: var(--c-forest-400) !important;
}
body.site.error_site header {
    background-color: var(--c-forest-400) !important;
    background-image: none !important;
}
.modal-backdrop.show {
  background-color: var(--color-primary); /* #93352F */
  opacity: 0.8;
}
.modal-header .btn-close {
  background: none;
  font-size: 0;
  width: 32px;
  height: 32px;
  position: relative;
  opacity: 1;
}
.modal-header .btn-close::after {
  content: "\00D7";
  font-size: 24px;
  color: var(--secondary-color);
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hp-hero-js a#back-top {
    display: none !important;
}

/* ============================================================
   DESKTOP MENU – logo uprostřed, přetéká dolů
   ============================================================ */

/* Navbar flex kontejner – zarovnání NAHORU */
.mod-menu.klasic.desktop.magazin {
  align-items: flex-start;
  overflow: visible;
  position: relative;
}

/* Parent kontejnery – overflow visible */
header .container-nav,
header .grid-child.container-nav,
header.container-header1 {
  overflow: visible;
}

/* Běžné nav-linky – padding shora pro zarovnání s vrškem logo boxu */
.mod-menu.klasic.desktop.magazin > li.nav-item > .nav-link {
  padding-top: 30px;
  padding-bottom: 16px;
  font-size: 14px;
}
.hlavni .mod-menu.klasic.desktop.magazin > li.nav-item > .nav-link {
    padding-top: 5px;
    padding-bottom: 5px;
}
/* --- Logo item (#146) – zelený box, menší padding, větší logo --- */
li.nav-item.item-146, li.nav-item.item-199  {
  position: relative;
  z-index: 10;
}

li.nav-item.item-146 > .nav-link, li.nav-item.item-199 > .nav-link {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--c-forest-400);
  border-radius: 0 0 16px 16px;
  padding: 10px 16px 14px;
  min-height: 140px;
  text-decoration: none;
}
li.nav-item.item-146 a {, li.nav-item.item-199 a
    padding: 0 !important;
}
li.nav-item.item-146 > .nav-link img, li.nav-item.item-199 > .nav-link img {
  width: 120px;
  height: auto;
  display: block;
  margin-top: -10px;
}

li.nav-item.item-146 > .nav-link .image-title, li.nav-item.item-199 > .nav-link .image-title {
  display: none;
}

/* --- Rezervace (#144) – nezávisle vpravo --- */
li.nav-item.item-144 {
  margin-left: auto;
}

li.nav-item.item-144 > .nav-link {
  background: var(--c-forest-400);
  color: var(--c-canvas) !important;
  border-radius: 40px;
  padding: 10px 22px;
  font-size: var(--typo-btn-fs);
  line-height: var(--typo-btn-lh);
  font-weight: var(--typo-w-ui);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-decoration: none;
  white-space: nowrap;
  transition: background-color .15s ease;
}

li.nav-item.item-144 > .nav-link:hover {
  background: var(--c-forest-300);
}
/* Menu text – světlý na hero stránkách */
body.ishero .mod-menu.klasic.desktop.magazin > li.nav-item > .nav-link {
  color: var(--c-canvas) !important;
}
/* Mezery v menu */
.mod-menu.klasic.desktop.magazin {
  gap: clamp(2px, calc(-38px + 4vw), 32px);
}

/* Větší odstup od loga – minus gap (58 - 32 = 26) */
li.nav-item.item-146 {
  margin-left: clamp(8px, calc(4px + 1.8vw), 26px);
  margin-right: clamp(8px, calc(4px + 1.8vw), 26px);
}
/* ============================================================
   DESKTOP MENU – Konec
   ============================================================ */

/* --- Rezervace – tlačítko v headeru (custom modul) --- */
.menu-rezervace {
  position: absolute;
  right: 0;
  top: 16px;
  z-index: 20;
}
/* Mobil – skrýt menu i tlačítko */
@media (max-width: 991.98px) {
  header.header.container-header1 {
    height: 90px;
  }
  .menu-rezervace,
  ul.mod-menu.klasic.desktop.magazin {
    display: none !important;
  }
    li.nav-item.item-146 {
        display: none !important;
    }
    ul.mod-menu.magazin > li.active > a::after {
        display:none !important;
    }
  /* Uvnitř hamburgeru zase zobrazit */
  .hlavni ul.mod-menu.klasic.desktop.magazin {
    display: flex !important;
    flex-direction: column;
    float:left;
  }
  /* Logo mobil – zelený podklad */
  .logo-mobil a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--c-forest-400);
    border-radius: 12px;
    padding: 8px 0 8px 0;
  }

  /* Hamburger – zelené kolečko */
  label.bhg-mobile-menu-btn {
    background-color: var(--c-forest-400) !important;
    color: var(--c-canvas) !important;
  }
}

/* Na hero stránkách – canvas varianta */
body.ishero .menu-rezervace {
  background-color: var(--c-canvas) !important;
  border-color: var(--c-canvas) !important;
  color: var(--c-forest-400) !important;
}
body.ishero .mod-languages li a {
  color: var(--c-canvas) !important;
}
body.ishero .menu-rezervace:hover {
  background-color: #E8DBBF !important;
  border-color: #E8DBBF !important;
  color: var(--c-forest-400) !important;
}

html { scrollbar-gutter: stable; }
:root {
  --color-text:       var(--c-merlot-300);
  --color-text-muted: color-mix(in srgb, var(--c-merlot-300) 70%, transparent);
  --body-color:       var(--c-merlot-300);
  --bs-body-color:    var(--c-merlot-300);
  --bs-heading-color: var(--c-merlot-400);
  --box-shadow-sm:    0px 0px 20px 0px rgba(0, 55, 37, 0.15);
}
a:focus,
a:focus-visible {
  outline: none !important;
  box-shadow: none !important;
  border-color: transparent !important;
}

html, body { overflow-x: clip; }
@supports not (overflow-x: clip) {
  html, body { overflow-x: hidden; }
}
.bg-body {
    background-color: var(--color-bg) !important;
}
h1,h2,h3,h4,h5,h6,
.h1,.h2,.h3,.h4,.h5,.h6 {
  color: var(--c-merlot-400);
}
.bhg-eshop .small {
    font-size: var(--typo-b1-fs);
}
.eshop-no-category .breadcrumbs {
    display: none;
}
.bhg-eshop__content.eshop-no-category {
    display: none;
}
.typo-h1, .typo-h12, .typo-h2, .typo-h3, .typo-h4 {
  color: var(--c-merlot-400);
}
.bg-forest-400 { background-color: var(--c-forest-400) !important; }
.bg-forest-08  { background-color: var(--bg-forest-08) !important; }
.text-canvas     { color: var(--c-canvas) !important; }
.text-canvas-80  { color: color-mix(in srgb, var(--c-canvas) 80%, transparent) !important; }
.mw920 { max-width: 920px; }
.mw680 { max-width: 680px; }
.mw700 { max-width: 700px; }
.mw600 { max-width: 600px; }
.mw450 { max-width: 450px; }
.mw420 { max-width: 420px; }
.mw400 { max-width: 400px; }
.mw360 { max-width: 360px; }
.fw-extrabold { font-weight: 800 !important; }
.fw-sub   { font-weight: var(--typo-w-sub) !important; }
.fw-500   { font-weight: 500 !important; }
.lh-1     { line-height: 1 !important; }
.lh-05     { line-height: 0.5 !important; }
/* FIX: chyběla závorka u @media */
@media (min-width: 576px) {
  .min450 { min-width: 450px; }
}
:is(
  [class~="forest"],
  [class^="forest-"],
  [class*=" forest-"],
  [class*=" forest__"],
  .bg-forest,
  .forest-split__card
) .badge-pill, .badge-pill.light {
  color: var(--c-canvas);
}
.border-pata {
    border-color: color-mix(in srgb, var(--c-canvas) 20%, transparent) !important;
}

/* ============================================================
   TRUST-ICON – rozměr 56×56
   Přesunuto z modulů #132, #140, #150
   ============================================================ */
.trust-icon {
  width: 56px;
  height: 56px;
}
.trust-icon svg { display: block; }

/* ============================================================
   HERITAGE SPLIT
   Přesunuto z modulů #142, #180, #229, #230, #328, #330
   ============================================================ */
.forest-split__media,
.forest-split__card {
  border-radius: 18px;
  overflow: hidden;
}
.forest-split__img {
  object-fit: cover;
  min-height: clamp(360px, 36vw, 680px);
}
.forest-split__card {
  background: var(--c-forest-400);
  padding: clamp(28px, calc(24px + 0.6vw), 32px);
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
}
.forest-split__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
}
@media (max-width: 575.98px) {
  .forest-split__btn {
    white-space: normal;
    line-height: 1.2;
  }
}
@media (max-width: 991.98px) {
  .forest-split { position: relative; }
  .forest-split__row { margin-bottom: -60px; }
  .forest-split__card {
    margin-top: -40px;
    margin-bottom: 40px;
    position: relative;
    z-index: 2;
  }
  .forest-split__row > .col-12.col-lg-8 {
    padding-left: 0;
    padding-right: 0;
  }
}
body:not(.events) .mod-catswithtags .badge-pill {
    /*display: none;*/
}
/* --- PODNIKY BHG – logo pás --- */
.bhg-logos__img {
  width: auto;
  height: 125px;
  max-height: 125px;
  transition: opacity .2s ease;
}
.bhg-logos__link:hover .bhg-logos__img {
  opacity: .65;
}

@media (max-width: 991.98px) {
  .bhg-logos__img {
    height: 90px;
    max-height: 90px;
  }
}
@media (max-width: 575.98px) {
  .bhg-logos__img {
    height: 88px;
    max-height: 80px;
  }
}
/* === mod_bhglist_items === */
.mod-bhglist-items__img {
    aspect-ratio: 1 / 1;
}
.napoje .bhglist-container section .col > .d-flex {
    max-width: 780px;
    border-bottom: var(--border-width) var(--border-style) var(--border-color) !important;
    padding-bottom: var(--space-4);
}
div#bhgfg-root .bhgfg-translate, .bhglist-container .bhgfg-translate {
    border-bottom: var(--border-width) var(--border-style) var(--border-color) !important;
    padding-bottom: var(--space-5);
}
/* ============================================================
   TIMELINE ZIG-ZAG – O nás (celá šířka containeru)
   Desktop (>=992px):
     - intro řádek: nadpis VLEVO (statický) + 1. item VPRAVO
     - pak zig-zag: even(child#2,#4,#6)=VLEVO, odd(child#3,#5,#7)=VPRAVO
     - svislá čára uprostřed s tečkami
     - kaskádový overlap: každý item začíná v ~60% výšky předchozího
   Mobil (<992px):
     - čára vlevo, obsah vpravo, nadpis nad 1. itemem
   ============================================================ */

.tl-zigzag {
  --tl-line-color: var(--c-forest-400);
  --tl-dot-size: 14px;
  --tl-line-width: 2px;
  --tl-gap: 28px;
  --tl-item-spacing: 48px;
  --tl-overlap: 18%;        /* desktop: posun dalšího itemu zpět */
  --tl-overlap-first: 18%;  /* desktop: posun 1. itemu po intro */
  position: relative;
  padding: 0;
}

/* Svislá čára */
.tl-zigzag::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: var(--tl-line-width);
  background: var(--tl-line-color);
}

/* Tečka */
.tl-zigzag__dot {
  position: absolute;
  top: 6px;
  width: var(--tl-dot-size);
  height: var(--tl-dot-size);
  border-radius: 50%;
  background: var(--tl-line-color);
  z-index: 2;
}

/* Item */
.tl-zigzag__item {
  position: relative;
  padding-bottom: var(--tl-item-spacing);
}
.tl-zigzag__item:last-child {
  padding-bottom: 0;
}

/* Obrázek */
.tl-zigzag__img {
  width: 100%;
  border-radius: 12px;
  object-fit: cover;
  aspect-ratio: 16 / 10;
}

/* Intro blok */
.tl-zigzag__intro {
  position: relative;
  margin-bottom: var(--tl-item-spacing);
}

/* --- MOBIL: čára vlevo --- */
.tl-zigzag::before {
  left: calc(var(--tl-dot-size) / 2 - var(--tl-line-width) / 2);
}
.tl-zigzag__dot {
  left: 0;
}
.tl-zigzag__content {
  margin-left: calc(var(--tl-dot-size) + var(--tl-gap));
}
.tl-zigzag__intro .tl-zigzag__heading {
  margin-left: calc(var(--tl-dot-size) + var(--tl-gap));
  margin-bottom: 2rem;
}
.tl-zigzag__intro .tl-zigzag__content {
  margin-left: calc(var(--tl-dot-size) + var(--tl-gap));
}

/* --- DESKTOP (>=992px) --- */
@media (min-width: 992px) {
  .tl-zigzag {
    --tl-gap: 40px;
    --tl-item-spacing: 64px;
  }

  /* Čára uprostřed */
  .tl-zigzag::before {
    left: 50%;
    transform: translateX(-50%);
  }
  .tl-zigzag__dot {
    left: 50%;
    transform: translateX(-50%);
  }

  /* Kaskádový overlap */
  .tl-zigzag__item {
    padding-bottom: 0;
    margin-top: calc(-1 * var(--tl-overlap));
  }
  .tl-zigzag__item:nth-child(2) {
    margin-top: calc(-1 * var(--tl-overlap-first));
  }

  /* Intro: CSS grid – [nadpis] [tečka] [1. item] */
  .tl-zigzag__intro {
    display: grid;
    grid-template-columns:
      calc(50% - var(--tl-dot-size) / 2 - var(--tl-gap))
      calc(var(--tl-dot-size) + var(--tl-gap) * 2)
      calc(50% - var(--tl-dot-size) / 2 - var(--tl-gap));
    align-items: start;
    margin-bottom: 0;
  }
  .tl-zigzag__intro .tl-zigzag__heading {
    grid-column: 1;
    margin-left: 0;
    margin-bottom: 0;
    text-align: left;
    padding-top: 4px;
  }
  .tl-zigzag__intro .tl-zigzag__dot {
    grid-column: 2;
    position: relative;
    left: auto;
    transform: none;
    justify-self: center;
    top: 6px;
  }
  .tl-zigzag__intro .tl-zigzag__content {
    grid-column: 3;
    margin-left: 0;
    width: auto;
    text-align: left;
  }

  /* Zbylé itemy: šířka poloviny */
  .tl-zigzag__content {
    margin-left: 0;
    width: calc(50% - var(--tl-dot-size) / 2 - var(--tl-gap));
  }

  /* Po intro (child #1): child #2=even, #3=odd, #4=even …
     intro=VPRAVO → #2=VLEVO → #3=VPRAVO → #4=VLEVO … */

  /* Even (child #2, #4, #6… = 1992, 2010, 2022…) = VLEVO */
  .tl-zigzag__item:nth-child(even) .tl-zigzag__content {
    margin-left: 0;
    margin-right: auto;
    text-align: right;
  }
  .tl-zigzag__item:nth-child(even) .tl-zigzag__media {
    display: flex;
    justify-content: flex-end;
  }

  /* Odd (child #3, #5, #7… = 2000, 2016, 2024…) = VPRAVO */
  .tl-zigzag__item:nth-child(odd) .tl-zigzag__content {
    margin-left: auto;
    margin-right: 0;
    text-align: left;
  }
}
/* ============================================================
   FAQ ACCORDION
   Přesunuto z #143, #183, #190, #195, #217, #222, #292–#297
   ============================================================ */
.faq .tf-accordion-widget--item {
  border-bottom: 1px solid color-mix(in srgb, var(--c-merlot-400) 20%, transparent) !important;
}
.faq .tf-accordion-widget--item--title {
  font-family: var(--ff-head);
  font-size: var(--typo-s2-fs);
  line-height: var(--typo-s2-lh);
  font-weight: 600;
  color: var(--c-merlot-400);
  padding-left: 0;
}
.faq .tf-accordion-widget--item--content {
  font-size: var(--typo-b2-fs);
  line-height: var(--typo-b2-lh);
  font-weight: 400;
}
@media (max-width: 991.98px) {
  .faq.container-fluid.pt-5.border-top.border-2 {
    border: none !important;
    padding-top: 0 !important;
  }
}

/* ==========================================================
   PŘESUNUTO Z MODULŮ – pseudo-elementy, masking, animace
   ========================================================== */
/* --- HP HERO – Přesunuto z #198 (CZ), #321 (EN) --- */
.hp-hero {
  position: relative;
  overflow: hidden;
  min-height: clamp(420px, 70vh, 740px);
  padding: clamp(20px, 4vw, 56px) clamp(20px, 5vw, 64px);
  color: inherit;
  padding-top: 0;
}
.hp-hero::before {
  content: "";
  position: absolute;
  left: 0;
  bottom: -15px;
  width: min(760px, 58vw);
  height: min(760px, 78vh);
  background: currentColor;
  opacity: 0.30;
  pointer-events: none;
  transform: translateY(0);
  will-change: transform, opacity;
  -webkit-mask-image: url("/images/staromestske-namesti.png");
          mask-image: url("/images/staromestske-namesti.png");
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: left bottom;
          mask-position: left bottom;
  -webkit-mask-size: contain;
          mask-size: contain;
}
@supports (-webkit-mask-composite: source-in) {
  .hp-hero::before {
    -webkit-mask-image:
      url("/images/staromestske-namesti.png"),
      linear-gradient(to top, transparent 0%, rgba(0,0,0,.35) 10%, #000 22%, #000 100%),
      linear-gradient(to right, #000 0%, #000 55%, rgba(0,0,0,.60) 70%, transparent 92%);
    -webkit-mask-repeat: no-repeat, no-repeat, no-repeat;
    -webkit-mask-position: left bottom, left bottom, left bottom;
    -webkit-mask-size: contain, 100% 100%, 100% 100%;
    -webkit-mask-composite: source-in, source-in;
  }
}
.hp-hero__note,
.hp-hero__bottom {
  opacity: 1;
  transform: translateY(0);
  will-change: transform, opacity;
  position: relative;
  z-index: 1;
}
.hp-hero__claim {
  font-weight: 700;
  line-height: 0.92;
  letter-spacing: -0.02em;
  font-size: clamp(44px, 5.8vw, 84px);
}
@media (max-width: 860px) {
  .hp-hero__bottom { grid-template-columns: 1fr; align-items: start; }
  .hp-hero__note   { justify-self: start; max-width: 60ch; }
  .hp-hero::before {
    opacity: 0.24;
    width: min(720px, 92vw);
    height: min(560px, 62vh);
    left: -12px;
    bottom: -15px;
    -webkit-mask-position: left bottom;
            mask-position: left bottom;
  }
}
html.hp-hero-step3-start .hp-hero::before {
  opacity: 0;
  transform: translateY(-120vh);
  transition: transform 260ms ease, opacity 260ms ease;
}
html.hp-hero-step3-start .hp-hero__note,
html.hp-hero-step3-start .hp-hero__bottom {
  opacity: 0;
  transform: translateY(-18px);
  transition:
    opacity calc(var(--panel2-anim, 900ms) / 2) ease,
    transform calc(var(--panel2-anim, 900ms) / 2) ease;
}

/* --- DEER HERO – mobil: kontakt badge pod buttony --- */
@media (max-width: 991.98px) {
  .deer-hero {
    flex-direction: column;
  }
  .deer-hero [style*="bottom:50px"] {
    position: static !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    width: 100%;
    margin-top: 2rem;
  }
}

/* --- NASE PODNIKY – Přesunuto z #170 (CZ), #307 (EN) --- */
.podniky-wrap {
  position: relative;
  padding: 24px 0;
  isolation: isolate;
}
.podniky-wrap.bg-paper::before {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  left: 50%;
  width: 100vw;
  transform: translateX(-50%);
  background: var(--c-paper);
  z-index: -1;
}
.podniky-left {
  position: sticky;
  top: 24px;
  align-self: flex-start;
  padding: 8px 12px;
}
.podniky-right { padding: 8px 12px; }
@media (max-width: 991.98px) {
  .podniky-left { position: static; }
}

/* --- PETR BAUER – Přesunuto z #175 (CZ), #256 (EN) --- */
.person__media {
  border-radius: var(--radius-card, 20px);
  overflow: hidden;
  aspect-ratio: 1 / 1;
}
.person__quote-wrap { max-width: 36rem; }
@media (max-width: 991.98px) {
  .person__quote-wrap { max-width: 100%; padding-top: 0.5rem; }
}

/* --- PATIČKA ORLOJ – Přesunuto z #128 (CZ), #326 (EN) --- */
footer.container-footer {
  position: relative;
  overflow: hidden;
}
footer.container-footer::before {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 450px;
    height: 450px;
    background: url("/images/orloj3.png") no-repeat left bottom;
    background-size: contain;
    opacity: 0.60;
    pointer-events: none;
    z-index: 4;
    filter: saturate(1.1) contrast(1.1);
}
@media (max-width: 767px) {
  footer.container-footer::before {
    width: 260px;
    height: 260px;
    opacity: 0.50;
  }
}

/* --- CO NÁS DEFINUJE – Přesunuto z #174 (CZ), #310 (EN) --- */
.value-icon {
  width: 64px;
  height: 64px;
}

/* --- REZERVOVAT STŮL – Přesunuto z #228 (CZ), #275 (EN) --- */
.reserve-btn {
  --reserve-link-color: var(--c-canvas);
  --reserve-icon-bg:    #e7d7c6;
  --reserve-icon-color: var(--color-primary);
}
@media (min-width: 992px) {
  .border-start-lg {
    border-left: 1px solid var(--color-border) !important;
  }
}
.btn.btn-outline.reserve-btn {
  border: 0 !important;
  color: var(--reserve-link-color) !important;
  text-decoration: none;
  padding-left: 0 !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.reserve-btn__icon {
  width: 44px;
  height: 44px;
  background: var(--reserve-icon-bg);
  color: var(--reserve-icon-color);
}
.reserve-btn__svg  { display: block; }
.reserve-btn__text { letter-spacing: .08em; }

/* --- BHG HERO CTA – Přesunuto z #176 (CZ), #298 (EN) --- */
.bhg-hero {
  border-radius: 16px;
  min-height: 400px;
  background: #000;
  position: relative;
  overflow: visible;
}
.bhg-hero__bg {
  position: absolute;
  inset: 0;
  background: url("images/bhg-family-interier-restaurace.webp") center/cover no-repeat;
  border-radius: inherit;
  overflow: hidden;
  z-index: 0;
}
.bhg-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(90deg, rgba(0,0,0,.12) 0%, rgba(0,0,0,0) 60%);
  pointer-events: none;
  z-index: 0;
}
.bhg-card {
  position: relative;
  z-index: 1;
  background: var(--c-surface, #f6f1ea);
  border-radius: 8px;
  box-shadow: 0px 0px 20px 0px rgba(0, 55, 37, 0.15);
}
.bhg-card--lift { transform: translateY(-40px); }
@media (max-width: 991.98px) {
  .bhg-hero { padding: 18px 0; }
  .bhg-card { margin: 14px; max-width: 100%; }
  .bhg-card--lift { transform: none; }
}
@media (max-width: 767.98px) {
  .bhg-hero {
    padding: 0;
    min-height: auto;
    background: transparent;
    overflow: visible;
    border-radius: 18px;
  }
  .bhg-hero::after { content: none; }
  .bhg-hero__bg {
    position: relative;
    inset: auto;
    height: 60vw;
    min-height: 240px;
    max-height: 380px;
    border-radius: inherit;
    overflow: hidden;
    z-index: 0;
    background: url("images/rodina.jpg") center/cover no-repeat;
  }
  .bhg-hero__bg::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: inherit;
    background: linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,0) 55%);
    pointer-events: none;
  }
  .bhg-card {
    margin: 0 !important;
    max-width: none;
    border-radius: 18px;
    transform: translateY(-12vw);
  }
  .bhg-hero .container {
    padding: 0;
    margin-bottom: -50px;
  }
}
@media (max-width: 575.98px) {
  .bhg-hero { border-radius: 18px; }
  .bhg-card { border-radius: 18px; padding: 20px; }
}

/* --- ERROR 404 – Přesunuto z #254 --- */
.err404-wrap {
  position: relative;
  overflow: visible;
  min-height: clamp(520px, 78vh, 820px);
  display: grid;
  place-items: center;
  color: inherit;
}
.err404-wrap::after {
  content: "";
  position: absolute;
  bottom: -32px;
  height: min(980px, 92vh);
  width: 71%;
  left: 54%;
  margin-left: 65vw;
  transform: translateX(-100%) translateX(6px);
  background-image: url("/images/Ilustrace-orloj.png");
  background-repeat: no-repeat;
  background-position: right bottom;
  background-size: 115% auto;
  opacity: .28;
  pointer-events: none;
  z-index: 1;
}
@media (max-width: 860px) {
  .err404-wrap::after {
    bottom: -15px;
    height: min(720px, 70vh);
    width: 70%;
    left: 50%;
    margin-left: 50vw;
    transform: translateX(-100%) translateX(14px);
    background-size: 120% auto;
    opacity: .22;
  }
}

/* --- ESHOP HERO – Přesunuto z #141 --- */
.eshop-hero {
  min-height: clamp(420px, 38vw, 620px);
  display: flex;
  align-items: stretch;
}
.eshop-hero__bg {
  position: absolute;
  inset: 0;
  background: url("/images/eshop-banner.jpg") center right / cover no-repeat;
}
.eshop-hero__inner {
  position: relative;
  z-index: 1;
  width: 100%;
  display: flex;
  align-items: stretch;
}
.eshop-hero__card {
  width: min(540px, 100%);
  border-radius: 14px;
  padding: clamp(28px, 3.2vw, 56px);
  background: var(--color-bg, #fff);
  margin-block: 32px;
  height: calc(100% - 64px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}
@media (max-width: 991.98px) {
  .eshop-hero__bg { background-position: center; }
  .eshop-hero__card { margin-left: auto; margin-right: auto; }
}
@media (max-width: 767.98px) {
  .eshop-hero { min-height: auto; padding: 16px 0; }
  .eshop-hero__bg { display: none; }
  .eshop-hero__card {
    width: 100%;
    max-width: 560px;
    height: auto;
    margin: 0 auto;
    padding: 24px;
    border-radius: 24px;
  }
  .eshop-hero__card::before {
    content: "";
    display: block;
    height: clamp(180px, 46vw, 260px);
    background: url("/images/eshop-banner.jpg") center / cover no-repeat;
    margin: -24px -24px 20px -24px;
    border-radius: 24px 24px 0 0;
  }
  .eshop-hero__card h2 { margin-top: 0; }
  .eshop-hero__card p  { margin-top: 16px !important; }
}

/* --- WORLD CARD – homepage --- */
.world-card__media {
  position: relative;
  aspect-ratio: 16 / 9;
  background-size: cover;
  background-position: center;
}
.world-card__media::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.35) 0%, rgba(0,0,0,0) 55%);
  pointer-events: none;
}
.world-card__label {
  position: absolute;
  left: 18px;
  bottom: 16px;
  z-index: 2;
  text-shadow: 0 2px 12px rgba(0,0,0,.45);
  transition: opacity .2s ease, transform .2s ease;
}
.world-card__overlay {
  position: absolute;
  inset: 0;
  z-index: 3;
  transform: translateY(100%);
  transition: transform .28s ease;
  pointer-events: none;
}
.world-card__overlay a.btn { pointer-events: auto; }
.world-card:hover .world-card__overlay,
.world-card:focus-within .world-card__overlay { transform: translateY(0); }
.world-card:hover .world-card__label,
.world-card:focus-within .world-card__label  { opacity: 0; transform: translateY(8px); }

/* --- REZERVACE POKOJŮ --- */
.info-panel.infoapa { display: none; }
.bg-surface, .total, .kolotoc .pole, .bg-total { background-color: var(--c-surface) !important; }
.kolotoc .pole { border: none !important; }
.kolotoc .pole.vybran { color: var(--c-canvas); }
.kolotoc .pole.odjezd .bhg-day-card {
  background-color: var(--c-forest-400) !important;
  border-color: var(--c-forest-400) !important;
  opacity: 0.6;
  color: var(--c-canvas);
}
.date-picker-wrapper { background-color: var(--c-surface) !important; }

/* klasické stylování */
.mag-body p { margin-bottom: 1.5rem; }
.mod-languages li a {
    text-decoration: none !important;
}
/* Tlačítko nahoru – hover + všechny interakční stavy stejně */
a#back-top:hover,
a#back-top:focus,
a#back-top:focus-visible,
a#back-top:active,
a#back-top:visited {
  color: var(--c-canvas);
  background-color: var(--c-forest-400);
  border-color: var(--c-forest-400);
  outline: none;
  box-shadow: none;
}
p.counter { display: none; }
.card { overflow: hidden; }
.shadow-block, .shadow-panel {
  box-shadow: 0px 0px 20px 0px rgba(0, 55, 37, 0.15) !important;
  transition: transform .28s cubic-bezier(.2,.8,.2,1);
  will-change: transform;
}
.shadow-block:hover { transform: translateY(-16px) scale(1.02) !important; }
/*  error page */
/* Error stránka – světlé menu na tmavém pozadí */
body.site.error_site header li.nav-item a,
body.site.error_site header li.nav-item span,
body.site.error_site header .navbar-brand a,
body.site.error_site header .container-nav a,
body.site.error_site header .mod-menu .nav-link,
body.site.error_site header .brand-logo {
    color: var(--c-canvas) !important;
}
/* Error stránka – tlačítko REZERVACE má canvas pozadí, takže text musí být forest */
body.site.error_site header .menu-rezervace,
body.site.error_site header .menu-rezervace * {
    color: var(--c-forest-400) !important;
}
body.site.error_site header {
    top:40px;
}
body.site.error_site header img[src*="logo-shop"] {
    content: url("/images/logo-deer-light.svg");
}
/* formuláře */
form#bhgCheckoutForm input:not(.form-check-input),
form#bhgCheckoutForm textarea,
form#voucher input:not(.form-check-input),
form#voucher textarea,
form#bhgCheckoutForm input#pickup_date,
form#bhgCheckoutForm select,
form#bhgCheckoutForm select option,
#pickup_time.form-select {
  background-color: transparent !important;
}
.own-select,
.own-select {
  position: relative !important;
  display: inline-block;
  overflow: visible !important;
}
.own-select > select.form-select,
.own-select > select.form-select {
  width: 100%;
  background-color: transparent !important;
  background: transparent !important;
  background-image: none !important;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  padding-right: 2.5rem;
}
.own-select::after,
.own-select::after {
  content: "";
  position: absolute;
  right: .9rem;
  top: 50%;
  transform: translateY(-50%);
  z-index: 2;
  pointer-events: none;
  width: 0;
  height: 0;
  border-left: .35rem solid transparent;
  border-right: .35rem solid transparent;
  border-top: .45rem solid currentColor;
}

/* FIX: odstraněno dvojité "color: color:" */
body { color: var(--c-merlot-300); }

.itemid-870 .main-bottom.no-card.border-top { border-top: none !important; }
.container-topbar1.d-flex.container {
  justify-content: flex-end;
  background-color: var(--c-forest-400) !important;
  margin-bottom: var(--space-3) !important;
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}
.topbar .mod-languages a {
  font-size: var(--typo-c2-fs);
  text-decoration: none !important;
}
.magpod .topbar .mod-languages a { color: var(--c-canvas) !important; }
.topbar .mod-languages { margin-top: -3px; }

header .reserve-btn {
  --reserve-link-color: var(--c-merlot-400);
  --reserve-icon-bg:    var(--c-forest-400);
  --reserve-icon-color: var(--c-canvas);
}
.magpod header .reserve-btn {
  --reserve-link-color: var(--c-canvas);
  --reserve-icon-bg:    var(--c-canvas);
  --reserve-icon-color: var(--c-forest-400);
}
header .reserve-btn:hover {
  background-color: var(--c-forest-300) !important;
  color: var(--c-canvas) !important;
}
header .reserve-btn:hover .reserve-btn__text { color: var(--c-canvas) !important; }

div#mod-custom156 { display: flex; }
.itemid-870 .nohome { display: none; }
body.site.com_bhgshop.view-produkt .breadcrumbs.horni { display: none; }
.bhg-prod .vpravo .breadcrumb {
  background-color: transparent;
  padding: 0 !important;
  margin-bottom: 3rem;
}

.footer {
  color: var(--c-canvas) !important;
  background-color: var(--c-forest-400) !important;
  background-image: none;
  border-radius: 16px 16px 0 0;
}
footer.container-footer { margin-top: var(--space-6); }
.footer a:not(.btn) {
    color: color-mix(in srgb, var(--c-canvas) 80%, transparent) !important;
}
.footer a:not(.btn) {
    text-decoration: none !important;
}
.footer .modal a:not(.btn) {
    color: inherit !important;
}
.kontakty footer.container-footer { margin-top: -7px; }

.share-btn {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  background: var(--c-forest-400) !important;
  color: var(--on-primary) !important;
}
.share-btn:focus-visible { outline: 2px solid currentColor; outline-offset: 2px; }
.share-ic     { width: 32px; height: 32px; display: block; }
.share-ic--24 { width: 24px; height: 24px; }
.breadcrumb   { --breadcrumb-font-size: 12px; }

.bhg-qty { border-color: var(--bs-border-color, #dee2e6) !important; }
.bhg-qty .btn {
  color: var(--bs-body-color);
  background: transparent;
  line-height: 1;
  font-size: 18px;
}
.bhg-qty .btn:hover { background: rgba(0,0,0,.04); }
.bhg-qty input {
  width: 56px;
  min-width: 56px;
  box-shadow: none !important;
  background: transparent;
}
.bhg-qty input:focus { outline: none; }
.bhg-qty:focus-within {
  border-color: var(--bs-primary) !important;
  box-shadow: 0 0 0 .2rem rgba(13,110,253,.15);
}

/* otázky a odpovědi */
.faq .tf-accordion-widget {
  border: 0 !important;
  border-color: transparent !important;
  box-shadow: none !important;
  outline: 0;
}
.faq .tf-accordion-widget--item--title {
  font-family: var(--ff-head);
  font-size: var(--typo-s2-fs);
  line-height: var(--typo-s2-lh);
  font-weight: 600;
  color: var(--c-merlot-400);
  padding-left: 0;
}
.tf-accordion-widget--item--content {
  font-size: var(--typo-s3-fs) !important;
  line-height: var(--typo-s3-lh) !important;
  font-weight: var(--typo-w-body) !important;
  color: var(--c-merlot-300) !important;
}
.tf-accordion-widget--item--content:not(.multiform .tf-accordion-widget--item--content) {
  padding-left: 0 !important;
}
.multiform .tf-accordion-widget {
  --panel-border-color: transparent !important;
  --panel-background-color: transparent !important;
  border: none !important;
  box-shadow: none !important;
}
.multiform .tf-accordion-widget--item--title {
  margin-bottom: 20px;
  background: transparent;
  border: 1px solid color-mix(in srgb, var(--btn-color, var(--color-primary)) 55%, transparent);
  border-radius: 40px;
}
@media (max-width: 991.98px) {
  div#mod-custom193 section.py-5 { padding-bottom: 0 !important; }
  div#mod-custom195 section { padding-top: 0 !important; padding-bottom: 0 !important; }
  div#mod-custom195 section .faq { padding-top: 10px !important; }
}

/* slider homepage */
.swiper-wrapper { padding-top: 35px; padding-bottom: 35px; }
.swiper-slide img { display: block; width: 100%; height: auto; transform: translateY(0); }
.swiper-slide img         { border-radius: 8px; }
.swiper-slide.is-odd  img { transform: translateY(-35px); }
.swiper-slide.is-even img { transform: translateY( 35px); }
.swiper, .swiper-slide    { overflow: visible; }

/* drobečkovka */
.layout-cassiopeia_bhgblognapsali .container-banner { margin: 0; }
.breadcrumb { background-color: transparent; }
.homeshop .horni.eshop, .com_bhgshop.view-cart .horni.eshop { display: none; }
.drobek .breadcrumb,
.drobek .breadcrumb a,
.drobek .breadcrumb span,
.drobek .breadcrumb li:before {
  font-size: var(--typo-c2-fs) !important;
  color: var(--color-text) !important;
  text-transform: uppercase;
}
.magpod .drobek .breadcrumb,
.magpod .drobek .breadcrumb a,
.magpod .drobek .breadcrumb span,
.magpod .drobek .breadcrumb li:before { color: var(--c-canvas) !important; }
.breadcrumbs.small.horni .breadcrumb { padding-left: 0 !important; }
.magpod .breadcrumb { display: none; }
.layout-cassiopeia_bhgblogstitky .breadcrumb { display: block; }
.bhg-breadcrumbs--desktop .breadcrumb {
  padding-left: 0 !important;
  padding-top: 0 !important;
  margin-bottom: var(--space-5) !important;
}
@media (max-width: 767.98px) {
  .bhg-breadcrumbs--desktop .breadcrumb { display: none; }
}
.mod-breadcrumbs__wrapper .bc-divider       { color: var(--c-merlot-400); }
.drobek .mod-breadcrumbs__wrapper .bc-divider { color: var(--c-canvas); }

/* modul recenze */
.review-panel__sketch {
  position: absolute;
  inset: 0;
  pointer-events: none;
  display: block;
  opacity: .55;
  z-index: 0;
}
.review-panel__sketch::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 56%;
  background: url("/images/a-panel.png") left bottom / auto 100% no-repeat;
  -webkit-mask-image: linear-gradient(to right, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
          mask-image: linear-gradient(to right, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
}
.review-panel__sketch::after {
  content: "";
  position: absolute;
  right: 0; top: 0; bottom: 0;
  width: 56%;
  background: url("/images/b-panel.png") right bottom / auto 100% no-repeat;
  -webkit-mask-image: linear-gradient(to left, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
          mask-image: linear-gradient(to left, rgba(0,0,0,1) 0%, rgba(0,0,0,1) 55%, rgba(0,0,0,0) 100%);
}
.review-panel::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 1;
  background: linear-gradient(to right,
    transparent 0%, transparent 10%,
    var(--c-merlot-400) 28%, var(--c-merlot-400) 72%,
    transparent 90%, transparent 100%
  );
}
@media (max-width: 767.98px) {
  .review-panel__sketch::before { display: none; }
  .review-panel { padding-bottom: 4rem !important; }
}

/* hero modul s obrázkem */
.hero-section { width: 100%; position: relative; }
.hero-fullvw {
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  position: relative;
  background-size: cover;
  background-position: center;
  min-height: 100vh;
  height: 100vh;
  height: 100svh;
}
.hero-under-header {
  padding-top: var(--header-h, 0px);
  min-height: calc(100svh + var(--header-h, 0px));
  height: calc(100svh + var(--header-h, 0px));
}
.hero-section .hero-overlay {
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background:
    radial-gradient(70% 55% at 18% 78%, rgba(0,0,0,.70) 0%, rgba(0,0,0,.45) 35%, rgba(0,0,0,0) 70%),
    linear-gradient(180deg,
      rgba(0,0,0,.75) 0%, rgba(0,0,0,.55) 10%, rgba(0,0,0,.25) 22%, rgba(0,0,0,0) 38%,
      rgba(0,0,0,0) 72%, rgba(0,0,0,.35) 85%, rgba(0,0,0,.80) 100%
    );
}
.hero-section .hero-inner {
  min-height: 100% !important;
  height: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  position: relative !important;
  z-index: 1 !important;
  padding-bottom: var(--space-5);
}
.hero-section .hero-grid { margin-top: auto !important; align-items: flex-end !important; }
.autoplay-progress-circle { display: none !important; }

header { position: relative; z-index: 40; background: transparent; }

@media (max-width: 991.98px) {
  .hero-section.hero-under-header {
    --hero-overhang: 100px;
    overflow: visible !important;
    margin-bottom: var(--space-5);
  }
  .hero-inner,
  .hero-inner > .hero-grid {
    min-height: 100% !important;
    height: 100% !important;
    align-content: end;
  }
  .hero-inner {
    transform: translateY(var(--hero-overhang));
    padding-top: 2rem;
    padding-bottom: 0 !important;
  }
  .hero-note {
    width: 100%;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
    background: rgba(255,255,255,.92);
    border-radius: 1rem;
    box-shadow: 0 .5rem 1.5rem rgba(0,0,0,.18);
    padding: 1.25rem;
  }
  .hero-note .text-canvas { color: var(--c-merlot-300) !important; }
}

/* naše vize */
.vision__media {
  border-radius: 22px;
  overflow: hidden;
  box-shadow: 0 16px 32px rgba(0,0,0,.18);
}
.vision__media img {
  width: 100%;
  height: clamp(180px, 18vw, 240px);
  object-fit: cover;
  display: block;
}
@media (max-width: 980px) {
  .vision__grid { grid-template-columns: 1fr; }
  .vision__text { max-width: 70ch; }
  .vision__media img { height: 240px; }
}

/* detail voucheru */
.zazitektyp { display: none; }
.vouchertyp { display: block; }
body.itemid-757 .zazitektyp { display: block; }
body.itemid-757 .vouchertyp { display: none; }

/* staré */
header .mod-list { flex-direction: row; float: right; }
header .mod-list li { padding: 0 5px; }
button#language_btn_110 { border: none; padding: 0 0 0 20px; }
div#mod-custom123 { width: fit-content; }
.container-topbar1 { align-items: center; max-width: 100%; }
header li.nav-item a, header li.nav-item span { text-transform: uppercase; text-decoration: none !important; }
.magpod li.nav-item a, .magpod li.nav-item span { color: var(--c-canvas) !important; }
.topmenu li.nav-item a, .topmenu li.nav-item span { color: var(--c-canvas) !important; text-transform: none; }
.container-topbar1 .mod-menu {
  margin-left: auto;
  margin-bottom: 0;
  display: flex;
  gap: 1rem;
  list-style: none;
  padding-left: 0;
}
ul.mod-menu.mod-list.nav.magazin { padding-right: 22%; }
.container-topbar1 .topbar { margin-left: 1.5rem; float: none !important; }

.container-topbar1 #mod-custom123 a span { font-size: 1.2rem; margin-right: 0.5rem; }
.grid-child.container-nav { display: flex; }
.grid-child.container-nav #mod-custom124 p,.grid-child.container-nav #mod-custom349 p { margin: 0; }
.logovmenu span { display: none; }

ul.mod-menu.magazin { position: relative; }
ul.mod-menu.magazin > li.active > a { position: relative; }
ul.mod-menu.magazin > li.active > a::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -14px;
  width: 12px;
  height: 12px;
  background: no-repeat center / 12px 12px;
  background-image: url("data:image/svg+xml,%3Csvg%20width='12'%20height='12'%20viewBox='0%200%2012%2012'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3E%3Cpath%20d='M5.65625%200C5.65625%200%206.50528%202.50587%207.65625%203.65685C8.80722%204.80782%2011.3131%205.65685%2011.3131%205.65685C11.3131%205.65685%208.80722%206.50587%207.65625%207.65684C6.50527%208.80782%205.65625%2011.3137%205.65625%2011.3137C5.65625%2011.3137%204.80723%208.80782%203.65625%207.65684C2.50528%206.50587%20-0.000604153%205.65685%20-0.000604153%205.65685C-0.000604153%205.65685%202.50528%204.80782%203.65625%203.65685C4.80722%202.50587%205.65625%200%205.65625%200Z'%20fill='%23F1E5CB'/%3E%3C/svg%3E");
  pointer-events: none;
}

body:not(.magpod) .logovmenu.svetle,
body:not(.magpod) li.nav-item.item-911 { display: none !important; }
.magpod .logovmenu.tmave,
.magpod li.nav-item.item-914,.magpod li.nav-item.item-1375 { display: none !important; }

/*.grid-child.container-nav .mod-menu.desktop {
  margin-left: auto;
  margin-bottom: 0;
  display: flex;
  align-items: center;
  gap: 1.5rem;
  list-style: none;
  padding-left: 0;
} */
@media (max-width: 1200px) { .grid-child.container-nav .mod-menu { gap: 1rem; } }
@media (max-width: 1000px) { .grid-child.container-nav .mod-menu { gap: 0.9rem; } }
.grid-child.container-nav .mod-menu .nav-item { display: flex; align-items: center; }

.topbar.topmenu .nav-item.active { position: relative; }
.topbar.topmenu .nav-item.active::after {
  content: "";
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: -20px;
  width: 12px;
  height: 12px;
  background-repeat: no-repeat;
  background-position: center;
  background-size: 12px 12px;
  background-image: url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20viewBox%3D%220%200%2012%2012%22%20fill%3D%22none%22%3E%3Cpath%20d%3D%22M5.65686%200C5.65686%200%206.50589%202.50587%207.65686%203.65685C8.80783%204.80782%2011.3137%205.65685%2011.3137%205.65685C11.3137%205.65685%208.80783%206.50587%207.65686%207.65684C6.50588%208.80782%205.65686%2011.3137%205.65686%2011.3137C5.65686%2011.3137%204.80784%208.80782%203.65686%207.65684C2.50589%206.50587%206.19888e-06%205.65685%206.19888e-06%205.65685C6.19888e-06%205.65685%202.50589%204.80782%203.65686%203.65685C4.80783%202.50587%205.65686%200%205.65686%200Z%22%20fill%3D%22%23F1E5CB%22/%3E%3C/svg%3E");
}

.mod-menu.klasic .dropdown { position: relative; }
.mod-menu.klasic .dropdown-menu li a { color: black !important; }
.mod-menu.klasic .dropdown-menu {
  display: block;
  position: absolute;
  top: 100%;
  left: -222px;
  opacity: 0;
  visibility: hidden;
  transform: translateY(8px);
  transition: opacity 0.2s ease, visibility 0.2s ease, transform 0.2s ease;
  pointer-events: none;
  margin-top: 0;
  z-index: 1000;
}
.mod-menu.klasic .dropdown:hover > .dropdown-menu,
.mod-menu.klasic .dropdown:focus-within > .dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
  pointer-events: auto;
}

/* menu mobilní */
@media (max-width: 991.98px) {
  a#back-top { display: none; }
  .bhg-mobile-menu-close { position: absolute; right: 15px; top: 15px; }
  .bhg-mobile-menu-close:hover { background: rgba(0,0,0,0.25); }
  .bhg-mobile-hamburger .mod-menu li a,
  .bhg-mobile-hamburger .mod-menu li span { color: var(--c-canvas) !important; }
  .logo-mobil { position: fixed; left: 10px; z-index: 99998; }
  .magpod .logo-mobil { color: var(--c-canvas); }
  input#bhg-mobile-menu-toggle { display: none; }
  .container-topbar1.d-flex.container { background-color: transparent !important; }
  .topbar .mod-languages { position: fixed; top: 15px; right: 60px; }
  .topbar.topmenu, header ul.mod-menu.mod-list.nav.desktop { display: none !important; }
  .menu.rezervace { display: none; }
  .bhg-mobile-hamburger {
    display: block !important;
    position: fixed;
    right: 10px;
    top: 10px;
  }
  label.bhg-mobile-menu-btn,
  label.bhg-mobile-menu-close {
    width: 44px;
    height: 44px;
    padding: 0;
    border-radius: 50%;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 25px;
    color: var(--c-canvas) !important;
    line-height: 1;
  }
  .bhg-mobile-hamburger li.nav-item.item-911,
  .bhg-mobile-hamburger li.nav-item.item-914 { display: none !important; }
  .horni ul.mod-menu.mod-list.nav {
    padding-top: 25px;
    margin-top: 5px;
    border-top: solid 1px color-mix(in srgb, var(--c-canvas) 20%, transparent);
  }
  .bhg-mobile-hamburger .horni li.nav-item a,
  .bhg-mobile-hamburger .horni li.nav-item span { text-transform: none; font-size: 14px; }
  .bhg-mobile-menu-divider {
    margin: 0.75rem 0;
    border: 0;
    border-top: 1px solid var(--color-border, #999);
  }
  .mod-bhgshop-cart--offcanvas.is-open .bhg-cart-panel { top: 50px !important; }
  .bhg-mobile-hamburger .bhg-mobile-menu-content {
    position: fixed;
    top: 0;
    right: -320px;
    width: 320px;
    max-width: 100%;
    padding: 1.5rem 1.25rem 2rem;
    background: var(--color-bg, #fff);
    box-shadow: -0.25rem 0 .75rem rgba(0,0,0,.25);
    overflow: visible;
    z-index: 99990;
    transition: right .25s ease-in-out;
  }
  .bhg-mobile-hamburger .bhg-mobile-menu-checkbox:checked ~ .bhg-mobile-menu-content {
    display: block;
    right: 0;
  }
  .bhg-mobile-menu-inner { padding: 0; }
  /*.bhg-mobile-menu-content::after {
    content: "";
    position: absolute;
    left: 0;
    top: 100%;
    width: 100%;
    height: 70px;
    background-image: url("/images/oblouk-menu-forest.png");
    background-repeat: no-repeat;
    background-position: center top;
    background-size: 100% 100%;
  }   */
/* Nový SVG oblouk pod menu */
.bhg-mobile-menu-content .bhg-menu-arc {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  z-index: 1;
  line-height: 0;
  pointer-events: none;
}
.bhg-mobile-menu-content .bhg-menu-arc .arc {
  transform: scaleY(-1);
}
  .bhg-mobile-menu-content .mod-menu { list-style: none; margin: 0 0 1.5rem; padding: 0; }
  .bhg-mobile-menu-content .mod-menu.nav {
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    float: left;
    gap: 0.8rem;
    width: 100%;
  }
  .bhg-mobile-menu-divider {
    margin: 1.25rem 0;
    border: 0;
    border-top: 1px solid var(--color-border, #eee);
  }
  .bhg-main-site-btn {
    display: block;
    margin-top: 1.5rem;
    padding: 0.75rem 1rem;
    border-radius: 0;
    border: 1px solid var(--color-border, #ddd);
    background-color: var(--color-bg, #fff);
    text-align: center;
    text-transform: uppercase;
    letter-spacing: .08em;
    font-size: 0.8rem;
    position: absolute;
    bottom: 60px;
    left: 5px;
    width: calc(100% - 10px);
  }
  .bhg-main-site-btn .arrow { margin-left: .5rem; }
  .bhg-mobile-menu-content li.active > a { display: flex; align-items: center; width: 100%; }
  .bhg-mobile-menu-content li.active > a::after {
    content: "";
    width: 12px;
    height: 12px;
    margin-left: auto;
    flex: 0 0 12px;
    background-repeat: no-repeat;
    background-position: center;
    background-size: 12px 12px;
    background-image: url("data:image/svg+xml,%3Csvg%20width%3D%2212%22%20height%3D%2212%22%20viewBox%3D%220%200%2012%2012%22%20fill%3D%22none%22%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%3E%3Cpath%20d%3D%22M5.65686%200C5.65686%200%206.50589%202.50587%207.65686%203.65685C8.80783%204.80782%2011.3137%205.65685%2011.3137%205.65685C11.3137%205.65685%208.80783%206.50587%207.65686%207.65684C6.50588%208.80782%205.65686%2011.3137%205.65686%2011.3137C5.65686%2011.3137%204.80784%208.80782%203.65686%207.65684C2.50589%206.50587%206.19888e-06%205.65685%206.19888e-06%205.65685C6.19888e-06%205.65685%202.50589%204.80782%203.65686%203.65685C4.80783%202.50587%205.65686%200%205.65686%200Z%22%20fill%3D%22%23F1E5CB%22/%3E%3C/svg%3E");
  }
  button.bhg-cart-toggle > span { display: none; }
  button.bhg-cart-toggle span.bhg-cart-toggle-icon { display: block; color: var(--c-merlot-400); }
  button.bhg-cart-toggle.btn.btn-primary {
    background-color: color-mix(in srgb, var(--c-merlot-400) 20%, transparent);
    border: none;
    padding: 12px 14px !important;
  }
  .mod-bhgshop-cart { position: absolute !important; right: 100px; top: 10px; }
  .mod-languages li a { color: var(--c-merlot-400) !important; }
  div#mod-custom124, div#mod-custom156 { display: none; }
  .view-eshop header.header.container-header1 { height: 65px; }
  .view-eshop header { height: 65px; }
  .bhg-mobile-hamburger.eshop { z-index: 9999; }
}

/* košík – napravo od menu */
.grid-child.container-nav .mod-bhgshop-cart { margin-left: 1.5rem; display: flex; align-items: center; }
div#bhgCartPanel th.pt-0.pb-2.text-muted.fw-normal.small { display: none; }
button.btn.btn-outline-secondary.btn-sm.js-bhg-clear { display: none; }
button.btn.btn-outline-danger.btn-sm.js-bhg-remove { border: none; }

@media (max-width: 991px) {
  #mod-custom124 img { max-width: 120px; height: auto; }
}

/* eshop */
a.btn.btn-sm.btn-outline-secondary.zpet { display: none; }
.com_bhgshop header.header, .shp header.header {
  /*box-shadow: 0px 2px 10px 0px rgba(0, 55, 37, 0.1);*/
  padding-bottom: 15px;
  margin-bottom: -15px;
}

/* ConvertForms */
.convertforms .cf-btn.cf-btn--forest {
  --button-background-color: var(--btn-color, var(--color-primary));
  --button-border: 1px solid var(--btn-color, var(--color-primary));
  --button-padding: unset;
  --button-border-radius: 40px;
  --button-font-size: 12px;
}
.convertforms .cf-btn.cf-btn--forest:hover {
  background: var(--c-forest-300);
  border-color: var(--c-forest-300);
  color: var(--c-canvas);
}
/*             galerie              */
.tf-gallery-wrapper figure.item a {
    border-radius: var(--radius-card);
    overflow: hidden;
}
.tf-gallery-wrapper .gallery-items.grid {
    row-gap: var(--space-4)!important;
}
.tf-gallery-wrapper .gallery-items {
    column-gap: var(--space-4)!important;
}
/* výpis zážitků */
/* Zážitky – obrázek v kartě */
.bhg-product-img-wrapper {
  position: relative;
  padding-top: 66.6667%;
  overflow: hidden;
}
.bhg-product-img-wrapper img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}
.bhg-product-tile:hover .bhg-product-img-wrapper img {
  transform: scale(1.03);
}
/* patička */
.footer .text-uppercase.small.fw-semibold {
  font-size: 14px;
  line-height: 22px;
  font-weight: 500 !important;
  color: var(--c-canvas);
  text-transform: none !important;
}
.footer a.nav-link {
  font-size: 14px;
  line-height: 22px;
  font-weight: 400;
  color: color-mix(in srgb, var(--c-canvas) 80%, transparent) !important;
  margin-bottom: 6px;
}
/* platební ikony */
.payment-icons {
  gap: clamp(12px, calc(12px + (24 - 12) * ((100vw - 320px) / (992 - 320))), 24px);
}
.payment-icon {
  display: block;
  height: 41px;
  width: auto;
  max-width: 90px;
  object-fit: contain;
  border-radius: 6px;
}
.footer li.metismenu-item a, .footer li.metismenu-item span { font-size: 14px; text-decoration: none !important; }
.footer li.metismenu-item { padding-left: 0 !important; }
.metismenu.mod-menu .metismenu-item.divider:not(.parent) { border-right: none; width: auto; margin: inherit; padding: inherit; }

@media (max-width: 767px) {
  img.footer-logo { content: url("/images/logo-h.png"); }
  .footer .d-inline-flex.align-items-center.justify-content-center { margin-bottom: 0 !important; }
}

/* ============================================================
   ARC SYSTEM – base styly pro SVG oblouky (z oblouk.php)
   ============================================================ */
.arc-wrap{
  width: 100%;
  line-height: 0;
}
.arc{
  display: block;
  width: 100%;
}
.arc .arc-stroke{
  fill: none;
  stroke-linecap: round;
}

/* ============================================================
   DEER HERO – fullscreen hero s progressive blur overlays
   Přesunuto z custom modulu deer-hero
   ============================================================ */
.deer-hero{
  position: relative;
  min-height: max(820px, 100vh);
  min-height: max(820px, 100svh);
  display: flex;
  align-items: center;
  justify-content: center;
}
.deer-hero__bg{
  position: absolute;
  inset: 0;
  background: url("/images/hphero.jpg") center/cover no-repeat;
  z-index: 0;
}
/* Poloprůhledný tmavý overlay přes celou fotku */
.deer-hero__bg::after{
  content: "";
  position: absolute;
  inset: 0;
  background: rgba(26, 11, 13, 0.5);
  pointer-events: none;
}
/* Horní overlay: gradient shora dolů + blur shora (20px) → dole (0px) */
.deer-hero__overlay-top{
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 220px;
  background: linear-gradient(180deg, rgba(26,11,13,0.7) 0%, rgba(26,11,13,0) 100%);
  -webkit-mask-image: linear-gradient(180deg, #000 0%, transparent 100%);
          mask-image: linear-gradient(180deg, #000 0%, transparent 100%);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  z-index: 1;
  pointer-events: none;
}
/* Spodní overlay: gradient zdola nahoru + blur zdola (20px) → nahoře (0px) */
.deer-hero__overlay-bottom{
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 65%;
  background: linear-gradient(0deg, rgba(26,11,13,1) 0%, rgba(26,11,13,0) 100%);
  -webkit-mask-image: linear-gradient(0deg, #000 0%, transparent 100%);
          mask-image: linear-gradient(0deg, #000 0%, transparent 100%);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  z-index: 1;
  pointer-events: none;
}
.deer-hero__arc{
  --arc-top: transparent;
  --arc-bottom: var(--c-surface);
  position: absolute;
  bottom: 0; left: 0; right: 0;
  z-index: 4;
  line-height: 0;
}
.deer-hero__arc .arc{
  width: 100%;
  display: block;
}
.deer-hero__contact-item{
  background: var(--c-surface);
  white-space: nowrap;
  -webkit-backdrop-filter: blur(8px);
          backdrop-filter: blur(8px);
  box-shadow: 0 2px 12px rgba(0,0,0,.12) !important;
  transition: background-color .15s ease !important;
}
a.deer-hero__contact-item:hover{
  background: var(--c-grain-100);
  color: var(--c-forest-400) !important;
}
.deer-hero__contact-item svg{
  flex-shrink: 0;
}
/* Canvas outline button – pro tmavé pozadí */
.btn.btn-canvas-outline{
  color: var(--c-canvas);
  border: 1px solid color-mix(in srgb, var(--c-canvas) 50%, transparent);
  background: transparent;
}
.btn.btn-canvas-outline:hover{
  background: color-mix(in srgb, var(--c-canvas) 12%, transparent);
  border-color: color-mix(in srgb, var(--c-canvas) 70%, transparent);
  color: var(--c-canvas);
}
@media (max-width: 991.98px){
  .deer-hero [style*="bottom:50px"]{
    position: static !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    margin-top: 2rem;
  }
}
/* steps */
.bhg-step-dot {
  width: 32px;
  height: 32px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  font-weight: 500;
  line-height: 1;
  background: var(--c-forest-50-warm);
  color: var(--c-forest-400);
}
.is-active .bhg-step-dot {
  /* FIX: nahrazeno tokenem */
  background: var(--color-primary);
  color: var(--c-surface) !important;
}
.is-active .bhg-step-text { color: var(--c-forest-400) !important; }

/* Map */

/* Aplikuje grayscale filtr pouze na dlaždice mapy */
.openstreetmap.map-widget .leaflet-tile {
  /*filter: grayscale(100%);*/
  filter: grayscale(80%) opacity(80%);
  -webkit-filter: grayscale(80%) opacity(80%);
  -moz-filter: grayscale(80%)  opacity(80%);
}

/* Ujistíme se, že markerové ikony nejsou ovlivněné */
.openstreetmap.map-widget .leaflet-marker-icon,  .openstreetmap.map-widget .leaflet-marker-icon img {
  filter: none !important;
}
