
* {	padding: 0;	margin: 0; }
body { background: #fff; color: #222; font-family: roboto slab, arial; font-size: 14px; }
:root { --highlight: #6eb43f; --highlight-hover: #5fa32e; --highlight2: #94c11f; }

/******************************************************************************/

a { color: #222; }
a:hover { text-decoration: none; }
img { border: 0; margin: 0; padding: 0; }

h1 { color: #020000; font-size: 36px; font-weight: bold; margin-bottom: 0.5em; text-transform: uppercase; }
h2 { color: #020000; font-size: 22px; font-weight: bold; margin-bottom: 0.5em; }
h3 { color: #020000; font-size: 16px; font-weight: bold; margin-bottom: 0.5em; }

table {	border-collapse: collapse; }

ul { padding-left: 15px; }
ol { padding-left: 20px; }
ol li { margin-bottom: 0.5em; }

input, textarea, select { font-family: roboto slab, arial; font-size: 14px; padding: 2px; }

/******************************************************************************/

.responsive-design { font-size: 1em; }
.highlight, .zvyrazneni { color: var(--highlight) !important; }
.highlight2 { color: var(--highlight2); }
.nu { text-decoration: none; }
.nu:hover { text-decoration: underline; }
.un { text-decoration: underline; }
.un:hover { text-decoration: none; }
.nn { text-decoration: none; }
.nn:hover { text-decoration: none; }

/******************************************************************************/
/* bloky */

.wrap1 { clear: both; float: left; position: relative; width: 100%; }
.wrap2 { margin: 0 auto; position: relative; width: 100% !important; max-width: 1260px; box-sizing: border-box; }
/*.content { float: left; padding: 0px 0px; position: relative; width: 100%; }*/

/******************************************************************************/
/* tlačítka */

.button, #breadcrumbs a, #breadcrumbs span { background: #222; border-radius: 3px; color: #fff; display: inline-block; margin: 1px 0; padding: 5px 15px; text-decoration: none; text-transform: uppercase; }
.button:hover, #breadcrumbs a:hover { background: #000; }
#breadcrumbs span { background: #ccc; color: #222; }

.button.back { background: var(--highlight); color: #fff; }
.button.back:hover { background: var(--highlight-hover); }

/******************************************************************************/
/* hlášky */

#msg-ok { background: #6fb43f; border-radius: 10px; color: #fff; margin-bottom: 1em; padding: 10px 15px; }
#msg-error { background: #dc143c; border-radius: 10px; color: #fff; margin-bottom: 1em; padding: 10px 15px; }

/******************************************************************************/
/* slider */

#wrap-slider { height: 100%; overflow: hidden; position: absolute; width: 100%; z-index: -2; }
#wrap-slider { position: fixed; }
#wrap-slider img { position: absolute; }
.slider { opacity: 0; }

#slider-text { position: absolute; right: 0; top: 100px; width: 65%; z-index: -1 }
#slider-text { position: fixed; }
#st-up { background: #fff; display: inline-block; font-size: 20px; margin-bottom: 5px; padding: 10px 25px; }
#st-down { background: #fff; font-size: 40px; font-weight: bold; padding: 10px 25px; }
#st-down2 { background: #fff; color: #cc0000; font-size: 15px; font-weight: bold; margin-top: 5px; padding: 10px 25px; }
#logo-slider { display: none; position: absolute; bottom: -80px; }

/******************************************************************************/
/* hlavní plášť */

#wrap-main { overflow: hidden; position: relative; }

/******************************************************************************/
/* pomocná třída pro správné pozicování */

.pointer { position: relative; }
.hashtag-position { position: absolute; top: -99px; }

/******************************************************************************/
/* hlavička */

#wrap-head { position: relative; z-index: 0; }

/******************************************************************************/
/* menu */

#wrap-menu-static { height: 100px; }
#wrap-menu { background: #020000; height: 100px; position: relative; width: 100%; z-index: 3; }
#content-menu { margin: 0 auto; position: relative; width: 1000px; }
#menu { padding: 0; text-align: center; width: 100%; }
#menu li { --margin-right: 40px; display: inline-block; list-style: none; margin: 0 var(--margin-right) 0 0; }
.lang--de #menu li { --margin-right: 20px; }
#menu li a { border-bottom: 7px solid #020000; border-top: 7px solid #020000; color: #666565; display: table-cell; font-size: 16px; height: 86px; text-decoration: none; text-transform: uppercase; vertical-align: middle; }
#menu li a:hover, #menu li a.active { border-bottom: 7px solid #020000; border-top: 7px solid var(--highlight); color: #fff; }
#menu.menu-top li a:hover, #menu.menu-top li a.active { border-bottom: 7px solid var(--highlight); border-top: 7px solid #020000; }
#menu li.edge a { margin-right: 0; }


#logo-menu { left: -340px; position: absolute; top: 26px; }
#social { color: #666565; right: -340px; position: absolute; top: 36px; width: 246px; }
#social a { color: #666565; margin-right: 35px; }
#social a:hover { color: #fff; }

/******************************************************************************/
/* obsah */

.wrap-content { background: #fff; position: relative; }
.content { margin: 0 auto; padding: 50px 0px; position: relative; width: 1000px; }
.content.full { max-width: 1580px; width: 94%; }
.content p { line-height: 1.75em; }

.nice-paragraph { max-width: 800px; }

/******************************************************************************/
/* parallax */

.wrap-parallax { clear: both; height: 400px; overflow: hidden; position: relative; }
.content-parallax { margin: 0 auto; width: 1000px; }
.content-parallax .text { color: #fff; display: table-cell; font-size: 50px; font-weight: bold; height: 400px; padding: 0 10px; text-align: center; vertical-align: middle; width: calc(100% - 20px); }

#parallax1 { background-attachment: fixed; background-color: #000; background-image: url('../img/bg01.jpg'); background-position: center center; background-size: 100%; }
#parallax2 { background-attachment: fixed; background-color: #000; background-image: url('../img/bg02.jpg'); background-position: center center; background-size: 100%; }

/******************************************************************************/
/* ikonky - prepinani jazyku */

/*
img.czech { display: none; position: fixed; top:100px; width: 30px; z-index: 999999; }
img.english { display: none; position: fixed; top: 125px; width: 30px; z-index: 999999; }
*/

.languages { color: #666; font-size: 16px; right: -180px; position: absolute; top: 40px; }
.languages a { color: #666; margin: 0 2.5px; text-decoration: none; }
.languages a:hover, .languages a.active { color: #fff; }

/******************************************************************************/
/* o nás */

.table-about { font-size: 13px; }
.table-about p { text-align: justify; }
.table-about img { height: auto; margin: 1em 0; width: 100%;  }

.about { display: inline-block; margin: 0 25px 1em 0; vertical-align: top; width: calc(33% - 28px); }

/******************************************************************************/
/* drobečková navigace */

#breadcrumbs { margin-bottom: 1em; }

/******************************************************************************/
/* portfolio - verze 1 */

/*
#wrap-portfolio { position: relative; }

#menu-portfolio { background: url('../img/icon_bars.png') left 16px no-repeat; border-top: 1px solid #ddd; margin-bottom: 0.5em; padding: 1em 0 1em 60px; }
#menu-portfolio a, #menu-portfolio span { color: #777; display: inline-block; margin: 0 30px 1em 0; text-decoration: none; text-transform: uppercase; }
#menu-portfolio a:hover { color: var(--highlight); }

.portfolio { display: inline-block; height: 350px; margin: 0 15px 15px 0; text-decoration: none; vertical-align: top; width: 235px; }
.portfolio.edge { margin-right: 0; }
.portfolio .photo { background: #efefef; height: 235px; margin-bottom: 1em; width: 235px; }
.portfolio .title { font-weight: bold; margin: 1em 0 0.5em 0; }
.portfolio .perex { color: #777; font-size: 0.85em; }

.portfolio-detail { left: 3000px; position: absolute; top: 0px; }

.table-trophy { clear: both; margin-top: 2.5em; }
.table-trophy td:nth-child(1) { padding-right: 25px; }
*/

/******************************************************************************/
/* portfolio */

.portfolio1 { display: inline-block; min-height: 235px; margin: 15px 15px 30px 0; text-decoration: none; vertical-align: top; width: calc(100%/4 - 15px); }
.portfolio1.edge { margin-right: 0; }
.portfolio1 .photo { background: #efefef; min-height: 147px; margin-bottom: 1em; }
.portfolio1 .photo img { height: auto; vertical-align: bottom; width: 100%; }
.portfolio1:hover .photo img { opacity: .75; }
.portfolio1 .title { font-weight: bold; margin: 1em 0 0.5em 0; }
.portfolio1 .perex { font-size: 0.85em; }

.content-trophy { padding-bottom: 0 !important; }
.table-trophy { clear: both; }
.table-trophy td:nth-child(1) { padding-right: 25px; }

.portfolio2 { display: inline-block; margin: 10px 10px; position: relative; text-decoration: none; vertical-align: top; width: calc(33.3% - 20px); }
.portfolio2 .wrap-img { background-position: center center; background-size: cover; overflow: hidden; height: 300px; vertical-align: middle; }
.portfolio2 img { height: auto; vertical-align: top; width: 100%; }
.portfolio2:hover img { opacity: .15; }
.portfolio2 .title { bottom: 20px; color: #000; display: none; font-weight: bold; margin-bottom: 0.5em; position: absolute; text-align: center; text-transform: uppercase; top: calc(50% - .5em); width: 100%; }
.portfolio2:hover .title { display: block; }
.portfolio2 .perex { display: none; }

.portfolio-img { display: inline-block; margin: 10px 10px; text-decoration: none; vertical-align: top; width: calc(33.3% - 20px); }
.portfolio-img .wrap-iframe { padding-top: calc(100% * 0.625); position: relative; }
.portfolio-img iframe { height: 100%; position: absolute; top: 0; }
.portfolio-img img { height: auto; vertical-align: bottom; width: 100%; }
.portfolio-text { padding: 10px 0 0 0; }

/*
.portfolio-img { margin-bottom: 15px; text-align: center; }
.portfolio-img img { height: auto; vertical-align: top; width: 1280px; width: 1000px; }
 */

.close { font-size: 3em; position: absolute; right: 25px; text-align: right; top: 25px; z-index: 2; }
.close2 { display: none; margin: 0 0 0 auto; }
.close:hover { color: #000; }

.table-navigation { margin: 3em 0 0 0; }

/******************************************************************************/
/* video */

.video-wrapper { overflow: hidden; padding-top: 62.5%; position: relative; width: 100%; }
.video-wrapper iframe { border: 0; height: 100%; left: 0; position: absolute; top: 0; width: 100%; }

/******************************************************************************/
/* cta */

.cta { background: #e1283c; border-radius: 5px; color: #eee; display: block; font-size: 2em; margin-top: 2em; padding: 1em 15px; text-align: center; text-decoration: none; }

/******************************************************************************/
/* klienti */

.client { display: inline-block; height: 115px; margin: 0 58px 15px 0; text-decoration: none; vertical-align: top; width: 115px;}
.client.edge { margin-right: 0; }

/******************************************************************************/
/* instagram */

.ig { display: inline-block; margin: 1px 2px; overflow: hidden; padding-bottom: calc(39.5% - 2px); /* padding-bottom: calc(33% - 2px); */ position: relative; vertical-align: top; width: calc(33% - 2px); width: 328px; }
.ig iframe { left: 0; top: -55px; position: absolute; max-width: 100%; }

.ig .ig-hover-layer { background: rgba(255,255,255,.9) url('../img/icon_instagram.png') center center no-repeat; display: none; left: 1px; overflow: hidden; padding-bottom: 125%; position: absolute; top: 55px; width: calc(100% - 2px); z-index: 1; }
.ig:hover .ig-hover-layer { display: block; }

.ig { padding-bottom: 0; }
.ig iframe { position: relative; top: 0; }
.ig .ig-help-layer { background: #fff; height: 50px; position: absolute; right: 2px; top: 2px; width: 130px; z-index: 1; }

/******************************************************************************/
/* volná místa */

#volna-mista-pointer img { height: auto; max-width: 100%; }

/******************************************************************************/
/* patička */

#wrap-foot-img { height: 100%; overflow: hidden; position: absolute; width: 100%; z-index: -3; }
#wrap-foot-img { position: fixed; }
#wrap-foot-img img { position: absolute; }

#wrap-foot { background: none; min-height: 300px; clear: both; }
#foot { color: #fff; margin: 0 auto; text-align: center; width: 1000px; }
#foot a { color: #fff; }
#foot .zvyrazneni a { color: var(--highlight); }

.block { background-color: rgba(0,0,0,0.6); min-height: 250px; margin-top: 100px; padding: 30px 50px 30px 50px; width: 900px; }
.block h3 { color: #fff; font-size: 55px; text-transform: uppercase; }

#foot-menu { margin-bottom: 30px; padding: 0; text-align: center; width: 100%; }
#foot-menu li { display: inline-block; }
#foot-menu li a { background: #19191b; border-radius: 25px; display: inline-block; padding: 10px 30px; text-decoration: none; text-transform: uppercase; }
#foot-menu li a:hover, #foot-menu li a.active { background: #6fb43f; }

.foot-text { display: none; }
#kontakt-kontakt { display: block; }

#foot-social a { margin: 0 30px; }
#copy { font-size: 1.25em; font-weight: bold; margin: 2em 0 3em 0; text-shadow: 1px 1px 1px #222; }

#terms_and_conditions { text-align: left; }
#terms_and_conditions h1, #terms_and_conditions h2 { color: #fff; }
#terms_and_conditions h4 { margin: 15px 0; }

/******************************************************************************/
/* kontaktní formulář */

#contact-form table { width: 100%; }
#contact-form table td { padding: 7px 0; }
#contact-form input[type="text"] { background: rgba(255, 255, 255, 0.9); border: 0; border-radius: 10px; padding: 15px 20px; width: 658px; }
#contact-form textarea { background: rgba(255, 255, 255, 0.9); border: 0; border-radius: 10px; padding: 15px 20px; width: 658px; }
#contact-form input[type="submit"], #newsletter input[type="submit"] { background: #19191b; background: #6fb43f; border: 1px solid #444; border: 1px solid #6fb43f; border-radius: 5px; color: #fff; cursor: pointer; padding: 10px 30px; text-transform: uppercase; }
#contact-form input[type="submit"]:hover { background: #5ea32e; border: 1px solid #6fb43f; }
#mapsitna { display: none; }

/******************************************************************************/
/* hp:newsletter */

#newsletter { background: #eee; }
#newsletter .content { padding: 75px 0 100px 0; }

.newsletter .title { display: inline-block; font-size: 2em; font-weight: bold; font-family: Roboto Slab; vertical-align: middle; width: 550px; }
.newsletter .nl-email { background: transparent; border: 0; border-bottom: 1px solid #444; margin-right: 25px; width: calc(100% - 750px); }
.newsletter .nl-accept-gdpr { margin-top: 2em; }
.newsletter .nl-accept-gdpr label { margin-left: 8px; }
.newsletter .nl-submit { float:right; }

/******************************************************************************/
/* BLOG - přehled */

.blog-container-box { margin-top: 50px; }

.blog-container-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr); /* VŽDY 3 sloupce */
    /*grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));*/
    gap: 40px;
    margin: auto;
}

.bcl-blog-post {
    background: white;
    overflow: hidden;
    /*border: 1px solid #eee;*/
    transition: transform 0.3s ease-in-out;
    position: relative;
}

/*
.bcl-blog-post:hover {
    border: 1px solid #bbb;
}
*/

.bcl-blog-post img {
    width: 100%;
    height: 180px;
    object-fit: cover;
}

.bcl-blog-content {
    padding: 15px 0;
}

.bcl-blog-image { position: relative; }
.bcl-blog-image-title { position: absolute; bottom: 0; left: 0; background: rgba(255, 255, 255, 0.75); width: 80%; height: 15%; }
.bcl-blog-title { }
.bcl-blog-category { text-transform: uppercase; }
/*
.bcl-blog-image-title .bottom-border {
    width: 30%;
    border-bottom: 2px solid var(--highlight);
    position: absolute;
    bottom: 2px;
}
*/
/*
.bcl-blog-image-title .bcl-blog-date {
    font-size: 1em;
    color: #666;
    position: absolute;
    bottom: 10px;
    left: 5px;
}
*/

.bottom-border {
    width: 30%; /* zde definuješ délku linky */
    border-bottom: 2px solid var(--highlight);
}

.bcl-blog-title .bcl-blog-date { font-size: 1em; color: #666; }

.bcl-blog-tags {
    font-size: 0.9em;
    color: #0077cc;
    margin-bottom: 10px;
}

.bcl-blog-text {
    font-size: 1em;
    color: #333;
    margin-bottom: 10px;
}

/*.bcl-blog-image-title .bcl-more-info { position: absolute; bottom: 15px; }*/
.bcl-more-info a { color: var(--highlight); }

.btn-load-more {
    background: var(--highlight);
    border-radius: 25px;
    display: inline-block;
    padding: 10px 30px;
    text-decoration: none;
    text-transform: uppercase;
    border: none;
    cursor: pointer;
}

.btn-load-more:hover { color: #fff; }

/* BLOG - DETAIL */

.blog-photos { margin-top: 30px; }

.blog-categories {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
    padding: 20px 0;
}

.blog-categories a {
    display: inline-block;
    padding: 5px 10px;
    background-color: #f3f3f3;
    color: #333;
    text-decoration: none;
    border-radius: 3px;
    font-size: 15px;
    transition: all 0.2s ease-in-out;
    border: 1px solid transparent;
}

.blog-categories a:hover, .blog-categories a.active {
    background-color: #333;
    color: #fff;
    border-color: #333;
}

/******************************************************************************/
/* BLOG - DETAIL */

.news-img { display: inline-block; margin: 10px 10px; text-decoration: none; vertical-align: top; width: calc(33.3% - 20px); }
.news-img .wrap-iframe { padding-top: calc(100% * 0.625); position: relative; }
.news-img iframe { height: 100%; position: absolute; top: 0; }
.news-img img { height: auto; vertical-align: bottom; width: 100%; }
.news-text { padding: 10px 0 0 0; }

/******************************************************************************/
/* PATIČKA */

.footer {
  background: #000;
  color: #fff;
  padding: 40px 20px;
  font-family: Arial, sans-serif;
  font-size: 14px;
}

.footer-inner {
  /*max-width: 1200px;*/
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 20px;
}

.footer-col {
  flex: 1 1 22%;
  min-width: 200px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: left;    /* ale texty vlevo */
}

.footer-logo-col .footer-logo {
  max-width: 180px;
}

.footer-col p {
  line-height: 1.6;
  margin: 10px 0;
}

.footer-col a {
  color: #fff;
}

.footer-col a:hover {
  text-decoration: underline;
}

.footer-nav {
  list-style: none;
  padding: 0;
  margin: 0;
}

.footer-nav li {
  margin-bottom: 6px;
}

.footer-nav a {
  color: #fff;
  transition: color 0.3s ease;
  text-transform: uppercase;
}

.footer-nav a:hover,
.footer-nav a.active {
  color: #fff;
  font-weight: bold;
}

.footer-social a {
  color: #ccc;
  margin-right: 15px;
  display: inline-block;
  transition: color 0.3s ease;
}

.footer-social a:hover {
  color: #fff;
}

.footer-social .fa-2x {
  font-size: 20px;
}

/* Všechny textové prvky a seznamy uvnitř sloupce budou zarovnané vlevo */
.footer-col > * {
  width: 100%;
}

/* 🔥 Výjimka: Sociální ikony – zarovnat vlevo a vedle sebe */
.footer-social {
  display: flex;             /* => vedle sebe */
  justify-content: flex-start;
  gap: 15px;
  width: 100%;
  margin-top: 10px;
}

.footer-social a {
  color: #ccc;
  transition: color 0.3s ease;
}

.footer-social a:hover {
  color: #fff;
}

.footer-social .fa-2x {
  font-size: 20px;
}


/******************************************************************************/
/* ochrana proti spamu */

.mapsitna { display: none; }
