@charset "UTF-8";
/* SETTINGS */
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-family: sans-serif;
  /* 1 */
  -ms-text-size-adjust: 100%;
  /* 2 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
}
/**
 * Remove default margin.
 */
body {
  margin: 0;
}
/* HTML5 display definitions
   ========================================================================== */
/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block;
}
/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */
audio, canvas, progress, video {
  display: inline-block;
  /* 1 */
  vertical-align: baseline;
  /* 2 */
}
/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0;
}
/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
 */
[hidden], template {
  display: none;
}
/* Links
   ========================================================================== */
/**
 * Remove the gray background color from active links in IE 10.
 */
a {
  background-color: transparent;
}
/**
 * Improve readability when focused and also mouse hovered in all browsers.
 */
a:active, a:hover {
  outline: 0;
}
/* Text-level semantics
   ========================================================================== */
/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted;
}
/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */
b, strong {
  font-weight: bold;
}
/**
 * Address styling not present in Safari and Chrome.
 */
dfn {
  font-style: italic;
}
/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */
h1 {
  font-size: 2em;
  margin: 0.67em 0;
}
/**
 * Address styling not present in IE 8/9.
 */
mark {
  background: #ff0;
  color: #000;
}
/**
 * Address inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%;
}
/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */
sub, sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}
sup {
  top: -0.5em;
}
sub {
  bottom: -0.25em;
}
/* Embedded content
   ========================================================================== */
/**
 * Remove border when inside `a` element in IE 8/9/10.
 */
img {
  border: 0;
}
/**
 * Correct overflow not hidden in IE 9/10/11.
 */
svg:not(:root) {
  overflow: hidden;
}
/* Grouping content
   ========================================================================== */
/**
 * Address margin not present in IE 8/9 and Safari.
 */
figure {
  margin: 1em 40px;
}
/**
 * Address differences between Firefox and other browsers.
 */
hr {
  -moz-box-sizing: content-box;
  box-sizing: content-box;
  height: 0;
}
/**
 * Contain overflow in all browsers.
 */
pre {
  overflow: auto;
}
/**
 * Address odd `em`-unit font size rendering in all browsers.
 */
code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em;
}
/* Forms
   ========================================================================== */
/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */
/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */
button, input, optgroup, select, textarea {
  color: inherit;
  /* 1 */
  font: inherit;
  /* 2 */
  margin: 0;
  /* 3 */
}
/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */
button {
  overflow: visible;
}
/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */
button, select {
  text-transform: none;
}
/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */
button, html input[type="button"], input[type="reset"], input[type="submit"] {
  /* 1 */
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
}
/**
 * Re-set default cursor for disabled elements.
 */
button[disabled], html input[disabled] {
  cursor: default;
}
/**
 * Remove inner padding and border in Firefox 4+.
 */
button::-moz-focus-inner, input::-moz-focus-inner {
  border: 0;
  padding: 0;
}
/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
input {
  line-height: normal;
}
/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */
input[type="checkbox"], input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */
input[type="number"]::-webkit-inner-spin-button, input[type="number"]::-webkit-outer-spin-button {
  height: auto;
}
/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box;
}
/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */
input[type="search"]::-webkit-search-cancel-button, input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none;
}
/**
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em;
}
/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  /* 2 */
}
/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */
textarea {
  overflow: auto;
}
/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */
optgroup {
  font-weight: bold;
}
/* Tables
   ========================================================================== */
/**
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0;
}
td, th {
  padding: 0;
}
*, *:after, *:before {
  box-sizing: inherit;
}
html {
  box-sizing: border-box;
  font-size: 62.5%;
}
body {
  color: #606c76;
  font-family: "Roboto", "Helvetica Neue", "Helvetica", "Arial", sans-serif;
  font-size: 1.6em;
  font-weight: 300;
  letter-spacing: 0.01em;
  line-height: 1.6;
}
blockquote {
  border-left: 0.3rem solid #d1d1d1;
  margin-left: 0;
  margin-right: 0;
  padding: 1rem 1.5rem;
}
blockquote *:last-child {
  margin-bottom: 0;
}
.button, button, input[type="button"], input[type="reset"], input[type="submit"] {
  background-color: #1b2b23;
  border: 0.1rem solid #1b2b23;
  border-radius: 0.4rem;
  color: #fff;
  cursor: pointer;
  display: inline-block;
  font-size: 1.1rem;
  font-weight: 700;
  height: 3.8rem;
  letter-spacing: 0.1rem;
  line-height: 3.8rem;
  padding: 0 3rem;
  text-align: center;
  text-decoration: none;
  text-transform: uppercase;
  white-space: nowrap;
}
.button:focus, .button:hover, button:focus, button:hover, input[type="button"]:focus, input[type="button"]:hover, input[type="reset"]:focus, input[type="reset"]:hover, input[type="submit"]:focus, input[type="submit"]:hover {
  background-color: #606c76;
  border-color: #606c76;
  color: #fff;
  outline: 0;
}
.button[disabled], button[disabled], input[type="button"][disabled], input[type="reset"][disabled], input[type="submit"][disabled] {
  cursor: default;
  opacity: 0.5;
}
.button[disabled]:focus, .button[disabled]:hover, button[disabled]:focus, button[disabled]:hover, input[type="button"][disabled]:focus, input[type="button"][disabled]:hover, input[type="reset"][disabled]:focus, input[type="reset"][disabled]:hover, input[type="submit"][disabled]:focus, input[type="submit"][disabled]:hover {
  background-color: #1b2b23;
  border-color: #1b2b23;
}
.button.button-outline, button.button-outline, input[type="button"].button-outline, input[type="reset"].button-outline, input[type="submit"].button-outline {
  background-color: transparent;
  color: #1b2b23;
}
.button.button-outline:focus, .button.button-outline:hover, button.button-outline:focus, button.button-outline:hover, input[type="button"].button-outline:focus, input[type="button"].button-outline:hover, input[type="reset"].button-outline:focus, input[type="reset"].button-outline:hover, input[type="submit"].button-outline:focus, input[type="submit"].button-outline:hover {
  background-color: transparent;
  border-color: #606c76;
  color: #606c76;
}
.button.button-outline[disabled]:focus, .button.button-outline[disabled]:hover, button.button-outline[disabled]:focus, button.button-outline[disabled]:hover, input[type="button"].button-outline[disabled]:focus, input[type="button"].button-outline[disabled]:hover, input[type="reset"].button-outline[disabled]:focus, input[type="reset"].button-outline[disabled]:hover, input[type="submit"].button-outline[disabled]:focus, input[type="submit"].button-outline[disabled]:hover {
  border-color: inherit;
  color: #1b2b23;
}
.button.button-clear, button.button-clear, input[type="button"].button-clear, input[type="reset"].button-clear, input[type="submit"].button-clear {
  background-color: transparent;
  border-color: transparent;
  color: #1b2b23;
}
.button.button-clear:focus, .button.button-clear:hover, button.button-clear:focus, button.button-clear:hover, input[type="button"].button-clear:focus, input[type="button"].button-clear:hover, input[type="reset"].button-clear:focus, input[type="reset"].button-clear:hover, input[type="submit"].button-clear:focus, input[type="submit"].button-clear:hover {
  background-color: transparent;
  border-color: transparent;
  color: #606c76;
}
.button.button-clear[disabled]:focus, .button.button-clear[disabled]:hover, button.button-clear[disabled]:focus, button.button-clear[disabled]:hover, input[type="button"].button-clear[disabled]:focus, input[type="button"].button-clear[disabled]:hover, input[type="reset"].button-clear[disabled]:focus, input[type="reset"].button-clear[disabled]:hover, input[type="submit"].button-clear[disabled]:focus, input[type="submit"].button-clear[disabled]:hover {
  color: #1b2b23;
}
code {
  background: #f4f5f6;
  border-radius: 0.4rem;
  font-size: 86%;
  margin: 0 0.2rem;
  padding: 0.2rem 0.5rem;
  white-space: nowrap;
}
pre {
  background: #f4f5f6;
  border-left: 0.3rem solid #1b2b23;
  overflow-y: hidden;
}
pre > code {
  border-radius: 0;
  display: block;
  padding: 1rem 1.5rem;
  white-space: pre;
}
hr {
  border: 0;
  border-top: 0.1rem solid #f4f5f6;
  margin: 3rem 0;
}
input[type="color"], input[type="date"], input[type="datetime"], input[type="datetime-local"], input[type="email"], input[type="month"], input[type="number"], input[type="password"], input[type="search"], input[type="tel"], input[type="text"], input[type="url"], input[type="week"], input:not([type]), textarea, select {
  -webkit-appearance: none;
  background-color: transparent;
  border: 0.1rem solid #d1d1d1;
  border-radius: 0.4rem;
  box-shadow: none;
  box-sizing: inherit;
  height: 3.8rem;
  padding: 0.6rem 1rem 0.7rem;
  width: 100%;
}
input[type="color"]:focus, input[type="date"]:focus, input[type="datetime"]:focus, input[type="datetime-local"]:focus, input[type="email"]:focus, input[type="month"]:focus, input[type="number"]:focus, input[type="password"]:focus, input[type="search"]:focus, input[type="tel"]:focus, input[type="text"]:focus, input[type="url"]:focus, input[type="week"]:focus, input:not([type]):focus, textarea:focus, select:focus {
  border-color: #1b2b23;
  outline: 0;
}
select {
  background: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 30 8" width="30"><path fill="%23d1d1d1" d="M0,0l6,8l6-8"/></svg>') center right no-repeat;
  padding-right: 3rem;
}
select:focus {
  background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 30 8" width="30"><path fill="%231b2b23" d="M0,0l6,8l6-8"/></svg>');
}
select[multiple] {
  background: none;
  height: auto;
}
textarea {
  min-height: 6.5rem;
}
label, legend {
  display: block;
  font-size: 1.6rem;
  font-weight: 700;
  margin-bottom: 0.5rem;
}
fieldset {
  border-width: 0;
  padding: 0;
}
input[type="checkbox"], input[type="radio"] {
  display: inline;
}
.label-inline {
  display: inline-block;
  font-weight: normal;
  margin-left: 0.5rem;
}
.container {
  margin: 0 auto;
  max-width: 112rem;
  padding: 0 2rem;
  position: relative;
  width: 100%;
}
.row {
  display: flex;
  flex-direction: column;
  padding: 0;
  width: 100%;
}
.row.row-no-padding {
  padding: 0;
}
.row.row-no-padding > .column {
  padding: 0;
}
.row.row-wrap {
  flex-wrap: wrap;
}
.row.row-top {
  align-items: flex-start;
}
.row.row-bottom {
  align-items: flex-end;
}
.row.row-center {
  align-items: center;
}
.row.row-stretch {
  align-items: stretch;
}
.row.row-baseline {
  align-items: baseline;
}
.row .column {
  display: block;
  flex: 1 1 auto;
  margin-left: 0;
  max-width: 100%;
  width: 100%;
}
.row .column.column-offset-10 {
  margin-left: 10%;
}
.row .column.column-offset-20 {
  margin-left: 20%;
}
.row .column.column-offset-25 {
  margin-left: 25%;
}
.row .column.column-offset-33, .row .column.column-offset-34 {
  margin-left: 33.3333%;
}
.row .column.column-offset-40 {
  margin-left: 40%;
}
.row .column.column-offset-50 {
  margin-left: 50%;
}
.row .column.column-offset-60 {
  margin-left: 60%;
}
.row .column.column-offset-66, .row .column.column-offset-67 {
  margin-left: 66.6666%;
}
.row .column.column-offset-75 {
  margin-left: 75%;
}
.row .column.column-offset-80 {
  margin-left: 80%;
}
.row .column.column-offset-90 {
  margin-left: 90%;
}
.row .column.column-10 {
  flex: 0 0 10%;
  max-width: 10%;
}
.row .column.column-20 {
  flex: 0 0 20%;
  max-width: 20%;
}
.row .column.column-25 {
  flex: 0 0 25%;
  max-width: 25%;
}
.row .column.column-33, .row .column.column-34 {
  flex: 0 0 33.3333%;
  max-width: 33.3333%;
}
.row .column.column-40 {
  flex: 0 0 40%;
  max-width: 40%;
}
.row .column.column-50 {
  flex: 0 0 50%;
  max-width: 50%;
}
.row .column.column-60 {
  flex: 0 0 60%;
  max-width: 60%;
}
.row .column.column-66, .row .column.column-67 {
  flex: 0 0 66.6666%;
  max-width: 66.6666%;
}
.row .column.column-75 {
  flex: 0 0 75%;
  max-width: 75%;
}
.row .column.column-80 {
  flex: 0 0 80%;
  max-width: 80%;
}
.row .column.column-90 {
  flex: 0 0 90%;
  max-width: 90%;
}
.row .column .column-top {
  align-self: flex-start;
}
.row .column .column-bottom {
  align-self: flex-end;
}
.row .column .column-center {
  align-self: center;
}
@media (min-width: 40rem) {
  .row {
    flex-direction: row;
    margin-left: -1rem;
    width: calc(100% + 2rem);
  }
  .row .column {
    margin-bottom: inherit;
    padding: 0 1rem;
  }
}
a {
  color: #1b2b23;
  text-decoration: none;
}
a:focus, a:hover {
  color: #606c76;
}
dl, ol, ul {
  list-style: none;
  margin-top: 0;
  padding-left: 0;
}
dl dl, dl ol, dl ul, ol dl, ol ol, ol ul, ul dl, ul ol, ul ul {
  font-size: 90%;
  margin: 1.5rem 0 1.5rem 3rem;
}
ol {
  list-style: decimal inside;
}
ul {
  list-style: circle inside;
}
.button, button, dd, dt, li {
  margin-bottom: 1rem;
}
fieldset, input, select, textarea {
  margin-bottom: 1.5rem;
}
blockquote, dl, figure, form, ol, p, pre, table, ul {
  margin-bottom: 2.5rem;
}
table {
  border-spacing: 0;
  display: block;
  overflow-x: auto;
  text-align: left;
  width: 100%;
}
td, th {
  border-bottom: 0.1rem solid #e1e1e1;
  padding: 1.2rem 1.5rem;
}
td:first-child, th:first-child {
  padding-left: 0;
}
td:last-child, th:last-child {
  padding-right: 0;
}
@media (min-width: 40rem) {
  table {
    display: table;
    overflow-x: initial;
  }
}
b, strong {
  font-weight: bold;
}
p {
  margin-top: 0;
}
h1, h2, h3, h4, h5, h6 {
  font-weight: 300;
  letter-spacing: -0.1rem;
  margin-bottom: 2rem;
  margin-top: 0;
}
h1 {
  font-size: 4.6rem;
  line-height: 1.2;
}
h2 {
  font-size: 3.6rem;
  line-height: 1.25;
}
h3 {
  font-size: 2.8rem;
  line-height: 1.3;
}
h4 {
  font-size: 2.2rem;
  letter-spacing: -0.08rem;
  line-height: 1.35;
}
h5 {
  font-size: 1.8rem;
  letter-spacing: -0.05rem;
  line-height: 1.5;
}
h6 {
  font-size: 1.6rem;
  letter-spacing: 0;
  line-height: 1.4;
}
img {
  max-width: 100%;
}
.clearfix:after {
  clear: both;
  content: " ";
  display: table;
}
.float-left {
  float: left;
}
.float-right {
  float: right;
}
/* Základní nastavení */
html {
  box-sizing: border-box;
  font-size: 62.5%;
  scroll-behavior: smooth;
}
*, *:before, *:after {
  box-sizing: inherit;
}
body {
  background: #ffffff;
  color: #2d2d2d;
  font-family: "Roboto", sans-serif;
  font-size: 1.6rem;
  margin: 0;
  padding: 0;
  overflow-x: hidden;
}
.container {
  background: none;
  max-width: 150rem !important;
  margin: 0 auto !important;
  padding: 0 2rem !important;
  width: 100%;
}
/* KLÍČOVÁ OPRAVA MILLIGRAMU: Vypínáme negativní marginy */
.row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  margin: 0 !important;
  width: 100% !important;
  padding: 0 !important;
}
.column {
  display: block;
  flex: 1 1 auto;
  max-width: 100%;
  padding: 0 1rem !important;
}
ul, ol {
  list-style-position: outside;
  margin-left: 2.5rem;
  padding-left: 0;
}
ul li, ol li {
  margin-bottom: 0.8rem;
  padding-left: 0.5rem;
}
/* Validační chyby formulářů */
.wrongIpt {
  color: #d33 !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  margin: 0.5rem 0 1rem 0 !important;
  display: block;
}
.inEmpt {
  border-color: #d33 !important;
  background-color: #fff0f0 !important;
}
.inEmpt:focus {
  border-color: #b33 !important;
  box-shadow: 0 0 0 0.1rem rgba(211, 51, 51, 0.25) !important;
}
.ndisp, .hidd {
  display: none !important;
  visibility: hidden !important;
  opacity: 0;
  pointer-events: none;
}
.text-center, .txtc {
  text-align: center !important;
}
.text-right, .txtr {
  text-align: right !important;
}
.text-left, .txtl {
  text-align: left !important;
}
.button.button-accent, button.button-accent {
  background-color: #b39359 !important;
  border-color: #b39359 !important;
  color: #1b2b23 !important;
  font-weight: 700;
}
.button.button-accent:hover, .button.button-accent:focus, button.button-accent:hover, button.button-accent:focus {
  background-color: #957844 !important;
  border-color: #957844 !important;
  color: #1b2b23 !important;
}
/* RESPONSIVE SWITCH (Všechno přepínání bez závislosti na .column) */
.iconstyl, .menustyl {
  display: flex !important;
  align-items: center !important;
  padding: 0 1rem;
  flex: 0 0 50% !important;
  max-width: 50% !important;
  width: 50% !important;
}
.menustyl {
  justify-content: flex-end !important;
}
.mobile-menu-trigger, #navbar-toggler {
  display: flex !important;
  background: #b39359;
  padding: 0.8rem 1.5rem;
  border-radius: 0.4rem;
  cursor: pointer;
  margin-left: auto;
  color: #1b2b23;
  font-weight: 700;
  align-items: center;
}
.mobile-menu-trigger svg, #navbar-toggler svg {
  width: 20px;
  height: 20px;
  margin-left: 10px;
  fill: #1b2b23;
}
.menu-bar {
  display: none !important;
}
.menu-bar, .nav nav ul, .mega-menu--multiLevel, .footer-bottom ul, .main-footer ul {
  list-style: none !important;
  margin-left: 0 !important;
}
.menu-bar li, .nav nav ul li, .mega-menu--multiLevel li, .footer-bottom ul li, .main-footer ul li {
  margin-bottom: 0;
  padding-left: 0;
}
/* MAIN HEADER & LOGO BOX */
header.main-header {
  background-color: #1b2b23;
  padding: 1.2rem 0;
  position: sticky;
  top: 0;
  z-index: 1000;
}
header.main-header .row {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: center !important;
  justify-content: space-between !important;
  width: 100%;
  margin: 0 auto;
}
header.main-header .logo-container {
  background: #fff;
  padding: 0rem 1.3rem;
  border-radius: 0.8rem;
  display: inline-flex;
}
header.main-header .logo-container img {
  height: 6.5rem;
  width: auto;
}
/* NAVIGATION (DESKTOP) */
.nav nav {
  display: flex;
  justify-content: flex-end;
}
.menu-bar {
  display: flex;
  list-style: none;
  margin: 0;
  padding: 0;
  align-items: center;
}
.menu-bar > li {
  position: relative;
}
.menu-bar > li > a.menu-link {
  color: rgba(255, 255, 255, 0.8) !important;
  padding: 1.5rem 1.4rem;
  display: block;
  font-size: 1.3rem;
  text-transform: uppercase;
  text-decoration: none !important;
  border-bottom: 2px solid transparent;
}
.menu-bar > li > a.menu-link[aria-haspopup="true"]::after {
  content: " ▾";
  opacity: 0.5;
}
.menu-bar > li:hover > a.menu-link, .menu-bar > li.active > a.menu-link {
  color: #fff !important;
  border-bottom: 2px solid #b39359;
}
.menu-bar > li:hover > ul {
  display: block !important;
  opacity: 1;
  visibility: visible;
}
.menu-bar > li:last-child > a.menu-link {
  background: #b39359;
  color: #1b2b23 !important;
  padding: 0.8rem 2rem !important;
  border-radius: 0.4rem;
  margin-left: 1rem;
  border-bottom: none !important;
  font-weight: 700;
}
ul.mega-menu--multiLevel {
  display: none;
  position: absolute;
  top: 100%;
  left: 0;
  background: #fff;
  min-width: 220px;
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.2);
  border-radius: 0.4rem;
  padding: 0.8rem 0;
  list-style: none;
  z-index: 100;
}
ul.mega-menu--multiLevel li a.menu-link {
  color: #2d2d2d !important;
  padding: 1rem 2rem !important;
  text-transform: none;
}
ul.mega-menu--multiLevel li a.menu-link:hover {
  background: #f4f5f6;
  color: #b39359 !important;
}
/* MOBILE MENU LOGIC */
.mobile-menu-trigger, .mobile-menu-back-item, #navbar-toggler {
  display: none !important;
}
header.main-header.menu-open .menu-bar {
  display: flex !important;
  flex-direction: column;
  position: fixed;
  top: 6rem;
  left: 0;
  width: 100%;
  height: calc(100vh - 6rem);
  background: #1b2b23;
  z-index: 999;
  padding: 2rem 0;
  overflow-y: auto;
}
header.main-header.menu-open .menu-bar > li {
  width: 100%;
  border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}
header.main-header.menu-open .menu-bar > li ul.mega-menu--multiLevel {
  display: none !important;
  position: static;
  opacity: 1;
  visibility: visible;
  background: rgba(0, 0, 0, 0.2);
  box-shadow: none;
  width: 100%;
}
header.main-header.menu-open .menu-bar > li ul.mega-menu--multiLevel li a.menu-link {
  color: #fff !important;
  padding: 1.5rem !important;
  font-size: 1.5rem !important;
}
header.main-header.menu-open .menu-bar > li.sub-open {
  background: rgba(255, 255, 255, 0.05);
}
header.main-header.menu-open .menu-bar > li.sub-open ul.mega-menu--multiLevel {
  display: block !important;
}
header.main-header.menu-open .menu-bar > li.sub-open > a.menu-link {
  color: #b39359 !important;
}
header.main-header.menu-open .menu-bar > li a.menu-link {
  padding: 1.8rem !important;
  font-size: 1.7rem !important;
  text-align: center;
}
header.main-header.menu-open .menu-bar .mobile-menu-back-item {
  display: block !important;
  padding: 2rem;
}
header.main-header.menu-open .menu-bar .mobile-menu-back-item a.mobile-menu-back-link {
  background: #b39359;
  color: #1b2b23 !important;
  border-radius: 0.4rem;
  font-weight: 700;
  display: block;
  text-align: center;
  padding: 1.5rem !important;
}
/* FOOTER */
footer.main-footer {
  background-color: #1b2b23;
  color: rgba(255, 255, 255, 0.7);
  padding: 6rem 0 0 0;
  margin-top: 8rem;
  font-size: 1.4rem;
}
footer.main-footer h4 {
  color: #ffffff;
  font-size: 1.8rem;
  margin-bottom: 2rem;
  text-transform: uppercase;
  letter-spacing: 0.1rem;
}
footer.main-footer ul {
  list-style: none;
  margin: 0;
  padding: 0;
}
footer.main-footer ul li {
  margin-bottom: 1rem;
}
footer.main-footer ul li a {
  color: rgba(255, 255, 255, 0.7);
  text-decoration: none;
}
footer.main-footer ul li a:hover {
  color: #b39359;
}
footer.main-footer .social-links {
  margin-top: 2rem;
}
footer.main-footer .social-links a {
  display: inline-block;
  width: 4rem;
  height: 4rem;
  line-height: 4rem;
  background: rgba(255, 255, 255, 0.1);
  color: #ffffff;
  text-align: center;
  border-radius: 50%;
  margin-right: 1rem;
  font-weight: 700;
}
footer.main-footer .social-links a:hover {
  background: #b39359;
  color: #1b2b23;
}
footer.main-footer .footer-bottom {
  margin-top: 4rem;
  font-size: 1.2rem;
}
footer.main-footer .footer-bottom hr {
  border: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  margin-bottom: 2rem;
}
footer.main-footer .footer-bottom a {
  text-decoration: underline;
  color: rgba(255, 255, 255, 0.7);
  font-weight: 700;
}
footer.main-footer .footer-bottom a:hover {
  color: #b39359;
}
.admin-bar {
  background-color: #1b2b23;
  margin-bottom: 3rem;
  border-radius: 0.8rem;
  overflow: hidden;
  box-shadow: 0 0.4rem 1.2rem rgba(0, 0, 0, 0.1);
  border: solid 3px #fff;
}
.admin-bar #navlist_ad ul {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}
.admin-bar #navlist_ad ul li {
  margin: 0 !important;
  padding: 0 !important;
  border-right: 1px solid rgba(255, 255, 255, 0.1);
}
.admin-bar #navlist_ad ul li a {
  display: block;
  padding: 1.5rem 2.5rem;
  color: rgba(255, 255, 255, 0.8) !important;
  text-decoration: none !important;
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05rem;
  transition: all 0.3s ease;
}
.admin-bar #navlist_ad ul li a:hover {
  background-color: rgba(255, 255, 255, 0.05);
  color: #b39359 !important;
}
.admin-bar #navlist_ad ul li:last-child {
  border-right: none;
  margin-left: auto !important;
}
.admin-bar #navlist_ad ul li:last-child a {
  color: #ff9800 !important;
}
.admin-bar #navlist_ad ul li:last-child a:hover {
  background-color: rgba(255, 152, 0, 0.1);
}
/* HERO HOME & PLACEHOLDERS - GLOBÁLNÍ */
.hero-home {
  background-color: #b39359;
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)), url("/media/images/uvod/hero-bg-2.jpg");
  background-position: 75% center;
  background-size: cover;
  background-repeat: no-repeat;
  height: 60vh;
  min-height: 40rem;
  margin-bottom: 4rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #ffffff;
}
.webp .hero-home {
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)), url("/media/images/uvod/hero-bg-2.webp");
}
.avif .hero-home {
  background-image: linear-gradient(rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)), url("/media/images/uvod/hero-bg-2.avif");
}
.hero-home .hero-content {
  max-width: 90rem;
  padding: 0 2rem;
}
.hero-home .hero-content h1 {
  color: #ffffff;
  font-size: 5.5rem;
  font-family: "Playfair Display", serif;
  margin-bottom: 1.5rem;
  line-height: 1.1;
  text-shadow: 0 0.2rem 1rem rgba(0, 0, 0, 0.3);
}
.hero-home .hero-content p {
  font-size: 2.2rem;
  font-weight: 300;
  opacity: 0.95;
}
.image-placeholder-box {
  position: relative;
  background: #b39359;
  border-radius: 0.8rem;
  overflow: hidden;
  width: 100%;
  padding-top: 66.66%;
}
.image-placeholder-box .img-wrapper {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
  display: flex;
  justify-content: center;
  align-items: center;
}
.image-placeholder-box .img-wrapper picture, .image-placeholder-box .img-wrapper img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
/*  11. BOOKING SIDEBAR & CALENDAR */
.booking-card {
  background: #fff;
  padding: 2rem;
  border-radius: 0.8rem;
  box-shadow: 0 1rem 4rem rgba(0, 0, 0, 0.1);
  border: 1px solid #eee;
}
.booking-card .calendar-wrapper {
  margin-bottom: 2.5rem;
  /* SEO Nadpis nad kalendářem */
  /* Náhled dat - sjednocená šířka s kalendářem */
}
.booking-card .calendar-wrapper .calendar-title {
  display: block;
  text-align: center;
  margin-bottom: 0.8rem !important;
  color: #1b2b23;
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 700;
}
.booking-card .calendar-wrapper .calendar-scroll-container {
  width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  display: flex;
  justify-content: center;
  padding: 0.5rem 0;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar {
  width: 307px !important;
  min-width: 307px !important;
  box-shadow: none;
  border: 1px solid #e1e1e1;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-months {
  background: #1b2b23 !important;
  border-radius: 0.8rem 0.8rem 0 0;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-months .flatpickr-month {
  color: #fff !important;
  fill: #fff !important;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-months .flatpickr-current-month {
  color: #fff !important;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-months .flatpickr-current-month .numInputWrapper input.cur-year {
  color: #fff !important;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-months .flatpickr-prev-month, .booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-months .flatpickr-next-month {
  fill: #fff !important;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar span.flatpickr-weekday {
  background: transparent !important;
  color: #999 !important;
  font-weight: 700;
  padding: 1rem 0;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-day.selected, .booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-day.startRange, .booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-day.endRange {
  background: #b39359 !important;
  border-color: #b39359 !important;
}
.booking-card .calendar-wrapper .calendar-scroll-container .flatpickr-calendar .flatpickr-day.inRange {
  background: rgba(179, 147, 89, 0.15) !important;
  box-shadow: -5px 0 0 rgba(179, 147, 89, 0.15), 5px 0 0 rgba(179, 147, 89, 0.15);
}
.booking-card .calendar-wrapper .selected-dates-preview {
  width: 307px;
  margin: 1.5rem auto 0 auto;
  display: flex !important;
  justify-content: space-between;
  align-items: center;
  padding: 1.2rem;
  background: #f9f9f9;
  border-radius: 0.6rem;
  border: 1px solid #eee;
}
.booking-card .calendar-wrapper .selected-dates-preview .date-box {
  display: flex;
  flex-direction: column;
  /* Třída, kterou přidáme přes JS, jakmile je vybráno datum */
}
.booking-card .calendar-wrapper .selected-dates-preview .date-box .label {
  font-size: 1rem;
  color: #666;
  text-transform: uppercase;
  font-weight: 700;
  margin-bottom: 0.3rem;
}
.booking-card .calendar-wrapper .selected-dates-preview .date-box .val-wrapper {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}
.booking-card .calendar-wrapper .selected-dates-preview .date-box .val-wrapper .val {
  font-weight: 700;
  font-size: 1.3rem;
  color: #1b2b23;
}
.booking-card .calendar-wrapper .selected-dates-preview .date-box .val-wrapper .check-icon {
  color: #28a745;
  font-weight: bold;
  font-size: 1.4rem;
  display: none;
}
.booking-card .calendar-wrapper .selected-dates-preview .date-box.active .check-icon {
  display: inline-block;
}
.booking-card .calendar-wrapper .selected-dates-preview .separator {
  color: #ccc;
  font-size: 1.4rem;
}
.booking-card .addon-grid {
  margin-top: 2rem;
}
.booking-card .addon-grid h5 {
  margin-bottom: 1rem;
}
.booking-card .addon-grid .addon-item {
  display: flex !important;
  align-items: center !important;
  margin-bottom: 0.8rem;
}
.booking-card .addon-grid .addon-item input[type="checkbox"] {
  display: inline-block !important;
  width: auto !important;
  margin-bottom: 0 !important;
  margin-right: 1rem !important;
  cursor: pointer;
}
.booking-card .addon-grid .addon-item label {
  display: inline-block !important;
  margin-bottom: 0 !important;
  font-weight: normal;
  font-size: 1.4rem;
  cursor: pointer;
  line-height: 1;
}
/* COOKIE CONSENT & UTILITIES */
#outer-consent {
  position: fixed;
  bottom: 0;
  left: 0;
  width: 100%;
  background-color: rgba(27, 43, 35, 0.98);
  color: #ffffff;
  z-index: 9999;
  padding: 2rem 0;
  box-shadow: 0 -0.5rem 2rem rgba(0, 0, 0, 0.2);
  border-top: 0.2rem solid #b39359;
}
#outer-consent #consent-cookie {
  max-width: 150rem;
  margin: 0 auto;
  padding: 0 2rem;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 1.4rem;
  line-height: 1.5;
}
#outer-consent #consent-cookie a {
  color: #b39359;
  text-decoration: underline;
  margin-left: 0.5rem;
}
#outer-consent #consent-cookie a:hover {
  color: #c3aa7c;
}
#outer-consent #consent-cookie button#cook-consent {
  background-color: #b39359;
  color: #1b2b23;
  border: none;
  padding: 0.8rem 2.5rem;
  border-radius: 0.4rem;
  font-weight: 700;
  cursor: pointer;
  margin-left: 3rem;
  white-space: nowrap;
  height: auto;
  line-height: 1;
}
#outer-consent #consent-cookie button#cook-consent:hover {
  background-color: #c3aa7c;
}
/* PRODUCT DETAIL (Levá strana - 67%) */
.section-padding {
  padding: 6rem 0;
}
/* Blok textového popisu */
.product-description {
  padding: 1rem 0 3rem 0;
}
.product-description h3, .product-description h4 {
  margin-top: 3rem;
  margin-bottom: 1.5rem;
}
.product-description p {
  margin-bottom: 1.5rem;
  line-height: 1.6;
}
.product-description ul {
  margin-bottom: 2rem;
}
.product-description ul li {
  margin-bottom: 0.5rem;
}
/* Specifikace (Kostky)*/
.spec-grid-wrapper {
  display: flex;
  flex-wrap: wrap;
  margin: 2rem 0 1rem 0 !important;
  width: 100% !important;
}
.spec-grid-wrapper .spec-box {
  flex: 0 0 50%;
  padding: 0.5rem;
}
@media (min-width: 901px) {
  .spec-grid-wrapper .spec-box {
    flex: 0 0 25%;
  }
}
.spec-grid-wrapper .spec-item {
  display: block;
  text-align: center;
  padding: 2rem 1rem;
  background-color: #f4f5f6 !important;
  border-radius: 0.4rem;
  border-bottom: 0.3rem solid #b39359;
  height: 100%;
}
.spec-grid-wrapper .spec-item small {
  display: block;
  text-transform: uppercase;
  color: #494949;
  font-size: 1.2rem;
  margin-bottom: 0.5rem;
}
.spec-grid-wrapper .spec-item strong {
  display: block;
  font-size: 2rem;
  color: #1b2b23;
  font-weight: 700;
}
/* 13. NEWS & BLOG MODULE */
/* 13.1 Společné prvky a mřížka */
.news-grid {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: stretch;
  margin: 0 -1rem !important;
}
.news-item {
  /* Vynucení 4 sloupců (25%) na desktopu */
  flex: 0 0 25% !important;
  max-width: 25% !important;
  padding: 1rem !important;
  display: flex;
}
.news-card {
  background: #fff;
  border-radius: 0.8rem;
  box-shadow: 0 0.5rem 2rem rgba(0, 0, 0, 0.1);
  width: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
  overflow: hidden;
  border: 1px solid #eee;
  transition: transform 0.2s ease, box-shadow 0.2s ease;
}
.news-card:hover {
  transform: translateY(-0.5rem);
  box-shadow: 0 1rem 3rem rgba(0, 0, 0, 0.15);
  background-color: #fdfdfd;
}
/* 13.2 Obrazová část (Seznam i Detail) */
.news-image {
  position: relative;
  width: 100%;
  height: 18rem;
  overflow: hidden;
  line-height: 0;
  /* Speciální úprava pro DETAIL (Zobrazit celý obrázek) */
  /* Pozicování SVG prvků PŘES obrázek */
}
.news-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.news-image.detail-view {
  height: auto !important;
  border-radius: 0.8rem;
  box-shadow: 0 1.5rem 4rem rgba(0, 0, 0, 0.15);
}
.news-image.detail-view img {
  height: auto !important;
  object-fit: contain;
}
.news-image .svgdatumovka {
  position: absolute;
  top: 1rem;
  left: 1rem;
  height: 3.5rem;
  z-index: 10;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}
.news-image .svgicon {
  position: absolute;
  top: 1rem;
  right: 1rem;
  width: 3.5rem;
  height: 3.5rem;
  z-index: 10;
  filter: drop-shadow(0 2px 4px rgba(0, 0, 0, 0.3));
}
/* 13.3 Obsahová část karty */
.news-body {
  padding: 1.5rem;
  flex-grow: 1;
  display: flex;
  flex-direction: column;
}
.news-body .news-title {
  font-size: 1.4rem;
  font-weight: 700;
  text-transform: uppercase;
  margin-bottom: 1rem;
  color: #1b2b23;
  min-height: 3.4rem;
  line-height: 1.2;
}
.news-body .news-anotace {
  font-size: 1.3rem;
  color: #666;
  line-height: 1.4;
  margin-bottom: 2.5rem;
}
.news-body .read-more {
  margin-top: auto;
  font-weight: 700;
  font-size: 1.2rem;
  color: #b39359;
  text-decoration: underline;
}
.news-body .read-more:hover {
  color: #1b2b23;
}
/* 13.4 Stránkování */
.pagination-wrapper {
  width: 100%;
  display: flex;
  justify-content: center;
  margin: 3rem 0;
}
.pagination-wrapper .pagination {
  display: flex;
  gap: 0.5rem;
  align-items: center;
}
.pagination-wrapper .pagination .pagination-link, .pagination-wrapper .pagination span.pagination-link {
  display: flex;
  align-items: center;
  justify-content: center;
  min-width: 3.5rem;
  height: 3.5rem;
  padding: 0 1rem;
  background: #f4f5f6;
  border: 1px solid #ddd;
  border-radius: 0.4rem;
  font-weight: 700;
  color: #1b2b23;
  font-size: 1.3rem;
}
.pagination-wrapper .pagination .pagination-link.active, .pagination-wrapper .pagination span.pagination-link.active {
  background: #b39359;
  border-color: #b39359;
  color: #fff;
}
.pagination-wrapper .pagination .pagination-link:hover:not(.active), .pagination-wrapper .pagination span.pagination-link:hover:not(.active) {
  background: #eee;
}
/* 13.5 Detail aktuality */
.news-detail-body .detail-title {
  font-size: 3.2rem;
  margin-bottom: 2rem;
  color: #1b2b23;
}
.news-detail-body .detail-anotace {
  font-size: 1.8rem;
  font-weight: 700;
  line-height: 1.6;
  margin-bottom: 3rem;
  border-left: 0.4rem solid #b39359;
  padding-left: 2rem;
}
.news-detail-body .detail-text-content {
  font-size: 1.6rem;
  line-height: 1.8;
}
.ilustracni-tag {
  display: block;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
  padding: 0.3rem 0.8rem;
  font-size: 1rem;
  position: absolute;
  bottom: 0;
  right: 0;
}
.datumsvg {
  fill: #000;
  font-family: sans-serif;
  font-weight: 700;
}
/* 14. CONTACTS */
.contact-info-card {
  background: #1b2b23;
  color: #fff;
  padding: 3.5rem;
  border-radius: 0.8rem;
}
.contact-info-card .info-item {
  margin-bottom: 2.5rem;
}
.contact-info-card .info-item small {
  display: block;
  color: #b39359;
  text-transform: uppercase;
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
}
.contact-info-card .info-item strong {
  font-size: 1.8rem;
}
.contact-info-card .info-item address {
  font-style: normal;
  line-height: 1.6;
}
.contact-info-card hr {
  border: 0;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  margin: 2rem 0;
}
.map-wrapper {
  line-height: 0;
  overflow: hidden;
  border-radius: 0.8rem;
}
/* 15. DYNAMICKÁ GALERIE (Justified Layout) */
.gallery-grid-justified {
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
  width: 100%;
  margin: 0 !important;
  padding: 0;
  /* Poslední řádek nebude "natažený" přes celou šířku */
}
.gallery-grid-justified .gallery-item {
  position: relative;
  height: 28rem;
  list-style: none;
  flex-shrink: 1;
}
.gallery-grid-justified .gallery-item img {
  height: 100%;
  width: 100%;
  object-fit: cover;
  display: block;
}
.gallery-grid-justified .gallery-item:hover .gallery-thumb {
  transform: scale(1.05);
}
.gallery-grid-justified .gallery-item-filler {
  height: 0;
  margin: 0;
  padding: 0;
}
.gallery-img-inner {
  position: relative;
  height: 100%;
  width: 100%;
  overflow: hidden;
  border-radius: 0.6rem;
  line-height: 0;
}
.gallery-img-inner .gallery-thumb {
  transition: transform 0.4s ease;
}
.gallery-img-inner {
  height: 100%;
  width: auto;
}
.gallery-img-inner img {
  height: 100%;
  width: auto;
  object-fit: cover;
  max-width: 100%;
}
.gallery-filter {
  margin-bottom: 4rem;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 1rem;
}
.gallery-filter .filter-btn {
  display: inline-block;
  padding: 0.8rem 2rem;
  background-color: #f4f5f6;
  color: #2d2d2d;
  border-radius: 0.4rem;
  text-decoration: none !important;
  font-weight: 700;
  font-size: 1.4rem;
  text-transform: uppercase;
  letter-spacing: 0.05rem;
  transition: all 0.3s ease;
  border: 1px solid transparent;
}
.gallery-filter .filter-btn:hover {
  background-color: #e6e8eb;
  color: #b39359;
}
.gallery-filter .filter-btn.active {
  background-color: #b39359;
  color: #fff;
  border-color: #b39359;
  box-shadow: 0 0.2rem 1rem rgba(179, 147, 89, 0.3);
}
/* Responzivita pro Justified Layout */
@media (max-width: 900px) {
  .gallery-grid-justified .gallery-item {
    height: 22rem;
  }
}
@media (max-width: 640px) {
  .gallery-grid-justified {
    gap: 0.5rem;
  }
  .gallery-grid-justified .gallery-item {
    height: 18rem;
    flex-grow: 1 !important;
  }
}
/* ==========================================================================
   RESPONSIVE SWITCH (The Brain) - Původní logika
   ========================================================================== */
/* Responzivita pro Justified Layout */
@media (max-width: 900px) {
  .gallery-grid-justified .gallery-item {
    height: 22rem;
  }
}
@media (max-width: 640px) {
  .gallery-grid-justified {
    gap: 0.5rem;
  }
  .gallery-grid-justified .gallery-item {
    height: 18rem;
    flex-grow: 1 !important;
  }
}
@media (min-width: 771px) {
  .menu-bar {
    display: flex !important;
  }
  .mobile-menu-trigger, #navbar-toggler {
    display: none !important;
  }
  .iconstyl {
    flex: 0 0 10% !important;
    max-width: 10% !important;
  }
  .menustyl {
    flex: 0 0 90% !important;
    max-width: 90% !important;
  }
  .column-25 {
    flex: 0 0 25% !important;
    max-width: 25% !important;
  }
  .column-50 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
  .column-67 {
    flex: 0 0 66.66% !important;
    max-width: 66.66% !important;
  }
  .column-33 {
    flex: 0 0 33.33% !important;
    max-width: 33.33% !important;
  }
  .sticky-container {
    position: sticky;
    top: 10rem;
    z-index: 10;
  }
}
@media (min-width: 771px) and (min-width: 1051px) {
  .column-67 {
    flex: 0 0 66.66% !important;
    max-width: 66.66% !important;
  }
  .column-33 {
    flex: 0 0 33.33% !important;
    max-width: 33.33% !important;
  }
}
@media (min-width: 771px) and (max-width: 1050px) {
  .column-67 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
  .column-33 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}
@media (max-width: 770px) and (min-width: 641px) {
  .menu-bar {
    display: none !important;
  }
  .mobile-menu-trigger, #navbar-toggler {
    display: flex !important;
  }
  .iconstyl, .menustyl {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
  .column-67, .column-33 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
  .booking-card {
    min-width: 300px;
  }
}
@media (max-width: 640px) {
  .column-67, .column-33 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
    padding: 0 !important;
    margin-bottom: 3rem;
  }
  .hero-home {
    height: auto !important;
    min-height: 30rem;
    padding: 6rem 0;
  }
  .hero-home h1 {
    font-size: 3.2rem !important;
  }
  .sticky-container {
    position: static !important;
  }
  .spec-grid-wrapper .spec-box {
    display: none !important;
    visibility: hidden !important;
  }
}
/* FIX PRO SPECIKACE (KOSTKY) */
.spec-item small {
  display: block;
  margin-bottom: 0.5rem;
}
.spec-item strong {
  display: block;
}
