/* HLAVIČKA - MENU */ 
html, body { overflow-x: hidden; }
html {
  scroll-behavior: smooth;
}
.next-to-carousel-banners {
margin-top: 0;
    }
.next-to-carousel-banners {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}
#header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(0, 0, 0, 0.4);
    height: auto;
}

#header * {
  background: transparent !important;
}
  .overall-wrapper {
        padding-top: 0px;
    }

#footer h4 {
    text-transform: uppercase;
}
.body-banners {
margin: 0px 0;
}
.navigation-in,
.top-bar,
.navigation-buttons {
  background: transparent !important;
}

.fitted .navigation-in ul {
  display: flex;
  justify-content: center;
}

.carousel,
.carousel-inner {
  background-color: black;
  margin-top: 0 !important;
  padding-top: 0 !important;
  margin-bottom: -1px;
}

.banner-wrapper {
  width: 100%;
}

.breadcrumbs {
  display: none;
}

a[data-target="search"],
a[data-target="login"],
a[data-target="cart"] {
  display: none !important;
}


@media (max-width: 991px) {
  #navigation,
  .navigation-in,
  .top-bar,
  .mobile-menu-toggle {
    background: transparent !important;
  }

  .navigation-window-visible #navigation {
    background: rgba(0, 0, 0, 0.9) !important;
  }
}


  .navigation-window-visible #navigation {
    background: white !important;
  }
}
/* HLAVIČKA - konec */  




.next-to-carousel-banners {
  margin-top: 0px
    }
    
/* KDO JSME */
.kdo-jsme-blok {
  width: 100vw;
  margin-left: calc(-50vw + 50%);
  background: #fff;
  padding: 50px 20px 50px 20px;
  position: relative;
  z-index: 1;
}

.kdo-jsme-obsah {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  gap: 40px;
  align-items: flex-start;
  justify-content: center;
}

.kdo-jsme-obrazky {
  flex: 1 1 40%;
  display: flex;
  flex-direction: column;
  gap: 15px;
}

.kdo-jsme-obrazky img {
  width: 100%;
  border-radius: 0px;
  object-fit: cover;
}

.kdo-jsme-text {
  flex: 1 1 40%;
}

.kdo-jsme-text h2 {
  position: relative;
  display: inline-block;
  font-size: 28px;
  margin-bottom: 30px;
  padding-bottom: 10px;
}

.kdo-jsme-text h2::after {
  content: '';
  display: block;
  height: 4px;
  width: 100%;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  position: absolute;
  bottom: 0;
  left: 0;
}
.kdo-jsme-text ul {
  padding-left: 20px;
  list-style-type: disc;
}

.kdo-jsme-text li {
  margin-bottom: 10px;
  font-size: 16px;
  line-height: 1.5;
}

.tlacitko-kontakt {
  display: inline-block;
  margin-top: 30px;
  padding: 16px 32px;
  font-size: 18px;
  font-weight: bold;
  color: #fff!important;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  text-decoration: none;
  border: none;
  border-radius: 0px;
  cursor: pointer;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.tlacitko-kontakt:hover {
  opacity: 0.9;
  transform: scale(1.02);
}

@media (max-width: 768px) {
  .kdo-jsme-obsah {
    flex-direction: column;
    align-items: center;
    text-align: center;
  }

  .kdo-jsme-text {
    order: 1;
    width: 90%;
    text-align: left; /* zarovnání odstavců a nadpisu vlevo */
  }

  .kdo-jsme-text h2,
  .kdo-jsme-text ul {
    text-align: left;
  }

  .tlacitko-kontakt {
    order: 2;
    margin: 30px auto;
  }

  .kdo-jsme-obrazky {
    order: 3;
    width: 90%;
    align-items: center;
  }

  .kdo-jsme-obrazky img {
    width: 100%;
    max-width: 100%;
  }
}

@media (min-width: 769px) {
  .kdo-jsme-obsah {
    gap: 80px; /* větší mezera mezi textem a obrázky */
  }

  .kdo-jsme-obrazky img:nth-child(1) {
    transform: translateX(-10px);
  }

  .kdo-jsme-obrazky img:nth-child(2) {
    transform: translateX(10px);
  }

  .kdo-jsme-obrazky img:nth-child(3) {
    transform: translateX(-5px);
  }
}

/* PROJEKTY */
/* Sekce – nech šířku sekce klidně 100% (NE 100vw) a udělej full-screen výšku */
.projekty-fullwrap{
  position: relative;
  min-height: 100vh;
  padding: 32px 0 40px; /* menší mezery nahoře/dole */
  color: #fff;
  z-index: 1;
}

/* Pozadí: táhne se přes CELÝ viewport bez bílých okrajů */
.projekty-fullwrap .projekty-bg{
  position: absolute;
  inset: 0;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;               /* klíč: šířka podle viewportu */
  background-image: url('/user/documents/upload/background/Projekty_pozadi_PC1.jpg');
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  z-index: 0;
}
@media (max-width:768px){
  .projekty-fullwrap .projekty-bg{
    background-image: url('/user/documents/upload/background/Projekty_pozadi_mobil1.jpg');
  }
}



.projekty-inner{
  position: relative;
  z-index: 2;
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 20px;
  text-align: center;
}

.projekty-title {
  position: relative;
  display: inline-block;
  font-size: 28px;
  margin-bottom: 30px;
  padding-bottom: 10px;
  color: #fff;
  text-shadow: 0 2px 4px rgba(0,0,0,0.7); /* jemný stín */
}
.projekty-title::after {
  content: '';
  display: block;
  height: 4px;
  width: 100%;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  position: absolute;
  bottom: 0;
  left: 0;
}

/* === FULL-BLEED SLIDER ===
   obal přes celý viewport bez rozbití layoutu (technika: 100vw + centrování) */
.project-slider-wrapper{
  position: relative;
  z-index: 2;
  width: 100vw;
  left: 50%;
  transform: translateX(-50%);
  /* aby šipky nesekaly text výhod pod tím */
  margin: 4px 0 0;
}

/* „guttery“ po stranách: zarovná okraje se středovým obsahem + nechá vykukovat další slide */
:root{ --page-max: 1400px; }
.project-carousel{
  display: flex;
  gap: 14px;
  overflow-x: auto;
  scroll-behavior: smooth;
  /* vnitřní postranní odsazení = dynamický gutter */
  padding: 8px clamp(12px, (100vw - var(--page-max))/2, 40px) 18px;
  box-sizing: border-box;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
.project-carousel::-webkit-scrollbar{ display:none; }

/* PEVNÁ VELIKOST SLIDU 452×326 + lehký hover */
.project-slide{
  flex: 0 0 auto;
  width: 452px;
  height: 326px;
  position: relative;
  overflow: hidden;
  border-radius: 0;
  text-decoration: none;
  color: inherit;
  transition: transform .5s ease;
}
.project-slide:hover{ transform: scale(1.03); }
.project-slide img{ width:100%; height:100%; object-fit:cover; display:block; }

/* caption dole (zachováno) */
.project-caption{
  position:absolute; left:0; right:0; bottom:0;
  padding: 10px 12px;
  font-size: 20px; line-height:1.3; color:#fff;
  background: linear-gradient(to top, rgb(0 0 0 / 80%), rgb(0 0 0 / 38%) 80%);
  text-align: center;
}

/* ŠIPKY – SVG jako u moumou */
.project-arrow{
  position:absolute; top:50%; transform:translateY(-50%);
  background:transparent; border:none; padding:0; cursor:pointer; z-index:3;
  width:40px; height:40px;
}
.project-arrow img{ width:100%; height:auto; display:block; }
.project-prev{ left: clamp(6px, (100vw - var(--page-max))/2, 24px); }
.project-next{ right: clamp(6px, (100vw - var(--page-max))/2, 24px); }

/* mezera pod sliderem */
.projekty-spacer{ height: 16px; }

/* VÝHODY (beze změny obsahu, jen kontrast + ostré rohy) */
.projekty-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:22px;
}
.projekt-box {
  flex: 1 1 220px;
  max-width: 260px;
  background: rgba(0, 0, 0, 0.6);
  padding: 20px;
  border-radius: 0px;
  text-align: left;
}

.projekt-box img {
  width: 40px;
  height: 40px;
  margin-bottom: 15px;
}

.projekt-box h3 {
  font-size: 18px;
  margin-bottom: 10px;
  color: #fff;
}

.projekt-box p {
  font-size: 15px;
  line-height: 1.5;
  color: #ddd;
}


/* Responsivně */
@media (max-width:1024px){ .projekty-grid{ grid-template-columns:1fr; justify-items: center;} }
@media (max-width:768px){
  .project-carousel{
    padding: 0 clamp(8px, (100vw - 95vw)/2, 16px) 12px;
  }
  .project-slide{
    /* zachovej poměr 452:326, ale škáluj do šířky mobilu s „peek“ */
    width: 86vw;
    height: calc(86vw * (326 / 452));
  }
}

/* KONCERTY */
.concerts-background {

  width: 100vw;
  margin-left: calc(-50vw + 50%);
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding: 80px 20px;
  color: #fff;
  position: relative;
  z-index: 1;
}

.concerts-wrapper {
  width: 100%;
  color: #fff;
  font-family: sans-serif;
  padding: 0;
  box-sizing: border-box;
  text-align: center;
}

.concerts-title {
  position: relative;
  display: inline-block;
  font-size: 28px;
  margin: 0 auto 30px auto;
  padding-bottom: 10px;
  color: #fff;
  text-align: center;
  text-shadow: 0 2px 4px rgba(0,0,0,0.7);
}
.concerts-prodej {
  position: relative;
  display: inline-block;
  font-size: 28px;
  margin: 0 auto 30px auto;
  padding-bottom: 10px;
  color: #fff;
  text-align: center;
  text-shadow: 3px 3px 5px rgba(0, 0, 0, 1);
}

.concerts-prodej::after {
  content: '';
  display: block;
  height: 4px;
  width: 100%;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  position: absolute;
  bottom: 0;
  left: 0;}

.concerts-title::after {
  content: '';
  display: block;
  height: 4px;
  width: 100%;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  position: absolute;
  bottom: 0;
  left: 0;
}
.concerts-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
}

.concert-item {
  width: 70%;
  background-color: #f0f0f0;
  color: #000;
  text-decoration: none;
  border-radius: 0px;
  padding: 5px 20px;
  display: flex;
  justify-content: center;
  align-items: center;
  transition: background 0.2s;
  opacity: 0.65;
  font-size: 20px;
}

.concert-item:hover {
  background-color: #f0f0f0;
  opacity: 0.9;	
}

.concert-item table {
  width: 100%;
  border-collapse: collapse;
}

.concert-item td {
  padding: 5px;
  text-align: center;
  font-size: 20px;
}

.concert-date,
.concert-city,
.concert-venue,
.concert-status {
  font-size: 20px;
  color: #000;
}

.concert-date {
  width: 25%;
  font-weight: bold;
}

.concert-city {
  width: 30%;
  font-weight: bold;
}

.concert-venue {
  width: 30%;
  font-weight: normal;
}

.flag-icon {
  width: 30px;
  height: 21px;
  margin-right: 8px;
  vertical-align: middle;
  display: inline-block;
}

.concert-status {
  width: 15%;
  font-weight: bold;
  text-align: right;
}

.concert-status.vstupenky a {
  color: #015721;
  text-decoration: none;
  font-weight: bold;
}

.concert-status.vyprodano {
  color: #950006;
}

.concert-status.bez-dostupnosti {
  color: #000;
}

.concert-button-wrap {
  margin: 15px auto 25px;
  width: fit-content;
  display: flex;
  justify-content: center;
  opacity: 0.85;
}

.concert-button {
  display: inline-block;
  padding: 16px 32px;
  font-size: 18px;
  font-weight: bold;
  color: #fff !important;
  background: linear-gradient(to right, #FB9C01, #E04B00); /* Otočený gradient */
  text-decoration: none;
  border: none;
  border-radius: 0px;
  cursor: pointer;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.concert-button:hover {
  opacity: 0.9;
  transform: scale(1.02);
}


@media screen and (max-width: 768px) {
  body, html {
    margin: 0;
    padding: 0;
  }

  .concerts-wrapper,
  .banner-wrapper,
  .next-to-carousel-banners {
    width: 100% !important;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
  }
    .next-to-carousel-banners .concert-item {
    width: 80% !important;
    padding: 5px 15px !important;
    font-size: 20px !important;
  }


  .concert-item table,
  .concert-item tbody,
  .concert-item tr,
  .concert-item td {
    display: block;
    width: 100%;
    padding: 0 !important;
    text-align: center;
  }

  .concert-date,
  .concert-city,
  .concert-venue,
  .concert-status {
    font-size: 20px;
    text-align: center;
  }

  .concert-button-wrap {
    width: 80%;
  }
}
.rammstein-banner {
  position: relative;
  width: 100%;
  overflow: hidden;
}
/*bannery*/
.image-banner-wrapper {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
  padding: 30px 0;
  box-sizing: border-box;
}

.image-banner-link {
  width: 70%;
  display: block;
  border-radius: 0px;
  overflow: hidden;
  transition: transform 0.5s ease;
}

.image-banner-link:hover {
  transform: scale(1.03);
}

.image-banner-img {
  width: 100%;
  height: auto;
  display: block;
  border-radius: 0px;
}

@media screen and (max-width: 768px) {
  .index-content-wrapper,
  .banners-content,
  .banner-wrapper,
  .image-banner-wrapper{
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    box-sizing: border-box;
  }

  .image-banner-link {
    display: block;
      width: 80%;
  }
}
.navigation-window-visible #navigation {
  background-color: transparent !important; /* původně bylo: white */
}
@media (max-width: 600px) {
  .custom-footer > div {
    padding-bottom: 0px;
  }
}
.custom-footer__contact {
  color: white;
}

.custom-footer__contact h4,
.custom-footer__contact h4 span {
  color: white;
}

/* Bílá barva pro texty a odkazy */
.custom-footer__contact a,
.custom-footer__contact span {
  color: white !important;
  text-decoration: none;
}

/* Hover: odkazy zůstávají bílé */
.custom-footer__contact a:hover {
  color: white !important;
  text-decoration: underline;
}

/* Bílé odrážky nebo ikonky pomocí ::before */
.custom-footer__contact ul {
  list-style: none;
  padding-left: 0;
  margin: 0;
}

.custom-footer__contact ul li {
  position: relative;
  padding-left: 18px;
  margin-bottom: 10px;
}

/* Pokud bys měl SVG ikonky jako background image */
.custom-footer__contact .facebook::before,
.custom-footer__contact .instagram::before,
.custom-footer__contact .tel::before,
.custom-footer__contact .mail::before {
  filter: invert(1);
}
#footer h4 {
    font-size: 20px;
    font-weight: 500;
    text-transform: uppercase;
    padding-bottom: 20px;
}
#footer {
  background-image: url('/user/documents/upload/footer-pc2.jpg'); /* ← zde nahraď URL obrázku */
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center center;
  width: 100%;
}
@media screen and (max-width: 768px) {
  #footer {
    background-image: url('/user/documents/upload/footer-mobil2.jpg'); /* obrázek pro mobil */
  }
}
.footer-bottom span {
        color: white;
    }
#signature a {
    color: white;
}
/*
[data-testid="textArticleTitle"] {
  display: none !important;
}
*/
[data-testid="buttonNextArticle"] {
  display: none !important;
}
#footer {
  position: relative;
}

.concerts-background,
.projekty-fullwrap,
.kdo-jsme-blok {
  position: relative;
}

/* full-bleed linka přes celý display */
.concerts-background::before,
.projekty-fullwrap::before,
.kdo-jsme-blok::before,
#footer::before{
  content:"";
  position:absolute;
  top:0;
  left:50%;
  transform: translateX(-50%);
  width:100vw;                /* klíč: šířka podle viewportu */
  height:5px;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  pointer-events:none;
  z-index:2;
}
.concerts-background::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 0;
  height: 5px;
  width: 100%;
  background: linear-gradient(to right, #E04B00, #FB9C01);
}


/* text a banner nad carouselem */
.zppromo-banner {
  position: relative;
  width: 100%;
  height: 100vh;
  overflow: hidden;
}
.zppromo-img {
  width: 100%;
  height: 100vh;
  object-fit: cover;
  display: block;
}

.zppromo-video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.zppromo-content {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  text-align: center;
  color: white;
  z-index: 2;
  padding: 0 20px;
}

.zppromo-logo {
  max-width: 300px; /* zvětšeno z 220px */
  width: 100%;
  height: auto;
  margin-bottom: 40px; /* mírně větší mezera */
  filter: drop-shadow(2px 2px 6px rgba(0, 0, 0, 0.4));
}

.zppromo-content h2,
.zppromo-content h3 {
  margin: 0;
  padding: 10px 0;
  font-weight: bold;
  text-shadow: 1px 1px 4px rgba(0, 0, 0, 0.4);
  color: white;
}

.zppromo-content h2 {
  font-size: 52px; /* bylo 40px */
}

.zppromo-content h3 {
  font-size: 32px; /* bylo 26px */
}

/* Zvýšení velikosti tlačítka */
.tlacitko-kontakt {
  display: inline-block;
  margin-top: 35px;
  padding: 20px 40px; /* větší padding */
  font-size: 22px; /* bylo 18px */
  font-weight: bold;
  color: #fff !important;
  background: linear-gradient(to right, #E04B00, #FB9C01);
  text-decoration: none;
  border: none;
  border-radius: 0px;
  cursor: pointer;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.tlacitko-kontakt:hover {
  opacity: 0.9;
  transform: scale(1.02);
}

@media (max-width: 768px) {
  .zppromo-banner {
    height: auto;
    aspect-ratio: 1.31 / 1;
    overflow: hidden;
  }

  .zppromo-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }

  .zppromo-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    text-align: center;
    padding: 0 10px;
    margin-top: 30px;
  }

  .zppromo-logo {
    max-width: 120px;
    margin-bottom: 10px;
  }

  .zppromo-content h2 {
    font-size: 22px;
    line-height: 1.1;
    margin: 5px 0;
    white-space: nowrap;
  }

  .zppromo-content h3 {
    font-size: 16px;
    line-height: 1.2;
    margin: 5px 0;
  }

  .tlacitko-kontakt {
    font-size: 15px;
    padding: 10px 20px;
    margin-top: 10px;
  }
}


.banner {
  margin-bottom: 0px;
}

@media (max-width: 600px) {
  .banner {
    margin-bottom: 0px;
  }
}

/* ROZBALOVACÍ MENU - ÚPRAVA STYLU */
ul.menu-level-2 {
  background: rgba(0, 0, 0, 0.4) !important; /* stejné jako horní menu */
  border: none !important;                  /* odstranění rámečku */
  box-shadow: none !important;              /* odstranění stínu */
  backdrop-filter: blur(4px);               /* volitelné zjemnění pozadí */
}

ul.menu-level-2 li a {
  color: white !important;
}

ul.menu-level-2 li a:hover {
  background: rgba(255, 255, 255, 0.1); /* decentní efekt na hover */
}
.navigation-window-visible #navigation {
        background-color: white !important;
    }
    @media (max-width: 768px) {
  #header.scrolled.scrolled-down {
    transform: none !important;
    opacity: 1 !important;
  }
}
@media screen and (max-width: 768px) {
   .index-content-wrapper,
   main.content,
   .content-inner,
   .banners-content,
   .banner-wrapper,
   .next-to-carousel-banners {
     display: block !important;
     visibility: visible !important;
     overflow: visible !important;
     width: 100% !important;
     margin: 0 !important;
     padding: 0 !important;
     box-sizing: border-box;
   }
}
@media screen and (max-width: 768px) {
  .index-content-wrapper {
    display: block !important;
  }
}
@media (max-width: 768px) {
  ul.menu-level-2 li a {
    color: #000000 !important;
  }
}

/* Gradient pro tlačítko */
#wt-form-wrapper-Q6DAB button[type="submit"] {
  background: linear-gradient(to right, #E04B00, #FB9C01);
  color: white;
  border: none;
  padding: 0.75rem;
  font-size: 1rem;
  font-weight: 500;
  border-radius: 8px;
  cursor: pointer;
  transition: opacity 0.3s ease;
}

#wt-form-wrapper-Q6DAB button[type="submit"]:hover {
  opacity: 0.9;
}

/* Globální mezera pod každým inputem */
#wt-form-wrapper-Q6DAB input {
  margin-bottom: 4px !important;
}

/* Globální mezera pod field group */
.formeo .f-field-group {
  margin-bottom: 4px;
}

/* Na mobilu – pole pod sebe a šířka 90 %, bez paddingu sloupců */
@media (max-width: 768px) {
  #wt-form-wrapper-Q6DAB input,
  #wt-form-wrapper-Q6DAB textarea,
  #wt-form-wrapper-Q6DAB button[type="submit"] {
    margin: 0 auto 1rem auto;
    display: block;
  }

  #wt-form-wrapper-Q6DAB .formeo-row {
    display: block !important;
  }

  #wt-form-wrapper-Q6DAB .formeo-column {
    width: 100% !important;
    display: block !important;
    padding: 0 !important;
  }
}

  @media (max-width: 768px) {
    .footer-flex {
      margin-bottom: 20px !important;
    }
  }
  .news-item .text .title {
    font-weight: 600;
}