/*========= obecně písma a prvotní vzhled ==============================================*/
/* latin */
@font-face {
  font-family:'Inter';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url(/img/inter/lat.woff2) format('woff2');
  unicode-range:U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+2074, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* latin-ext */
@font-face {
  font-family:'Inter';
  font-style:normal;
  font-weight:100 900;
  font-display:swap;
  src:url(/img/inter/lext.woff2) format('woff2');
  unicode-range:U+0100-02AF, U+0304, U+0308, U+0329, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}

html {font-size: 17px; background: #fff; color:#001927; }
body {font-family: 'Inter','Arial', sans-serif; }
input,select,textarea,button {font-family: 'Inter','Arial',sans-serif;font-size: 1rem;box-sizing:border-box;}

/*========= obecné =====================================================================*/
body { margin:0; }
#container { min-height: 100%; }
img {max-width: 100%;}
a img {border:0;text-decoration: none;}
a {text-decoration: underline;}

h1 { font-size: 28px; }
h2 { margin-bottom: .6em; font-size: 28px; }
h2.nomarginb {margin-bottom: 0;}
h3 {}
h2 a { text-decoration: none; }
h3 a { text-decoration: none; }
h4 a { text-decoration: none; }

ul{ padding: 0 0 0 2em; overflow: hidden; }
ul li{ padding:0; margin-bottom: .5em;}
blockquote { background: #eee; border: 1px solid #ddd; margin: 0 0 1.5em; padding: .25em 1em;}
blockquote p { font-size: 1.2em; margin: .5em;}
hr { width: 100%; height: 1px; margin:.75em 0;  }

table {max-width:100%; border-collapse: collapse; }
table td,table th { padding-right: 1em; }
table.ramovana { border: 1px solid;}
table.ramovana td,table.ramovana th { border: 1px solid; padding-left: .5em; padding-right: .5em; }

template {display:none;}

/*========= globální třídy a modifikátory ==============================================*/
/* Případně doplněny s konkrétními identifikátory podstránek a sekcí */
.hid {display: none!important;}

.chyba,.msgOk {padding: .5em 1em .5em; border: 2px solid;margin-bottom: 2em;}
.chyba {font-size: 1.2em; background: #fdd; color:#d00; font-weight: bold; border-color: #eaa; }
.msgOk {background: #dfd; color:#242; border-color: #aea; }
.chyba p,.msgOk p {margin-bottom: .5em!important; margin-top: .5em!important; }

.left {float:left!important;}
.right {float:right!important;}
.cleaner {display: block; width: 100%; clear: both!important;}

.nalevo {text-align: left!important;}
.nastred {text-align: center!important;}
.napravo {text-align: right!important;}
.navse {text-align: justify!important;}

.tucny  { font-weight: bold;}
.italika { font-style: italic }
.podtrzeny { text-decoration: underline!important; }
.preskrtnute {text-decoration: line-through!important; }

.mensi-pismo { font-size: .8em; }
.vetsi-pismo { font-size: 1.25em;  }
.velke-pismo { font-size: 1.5em;  }
.pismo2x { font-size: 2em; }

.kurzor-sipka { cursor: default; }
.kurzor-otaznik { cursor: help; }
.kurzor-ruka { cursor: pointer; }

.transparent { -moz-opacity:.5; opacity:.5; }
.full {width: 100%;}

.topMsg {background: #ecc; color:#f33; font-weight: bold; font-size: 1.1em; padding: .25em 10%; text-align: center;}
form .post {display: none!important;}
form .bblcntnr {}
form .bblcntnr .bubble { display: block; text-align: left; }
form .bblcntnr .bubble span { border:1px solid #eaa; background: #fdd; color:#d00; font-weight: bold; display: inline-block; padding: .1em .5em;margin: .1em; }
form .js_error_list { opacity:1; display: block; text-align: left; border:1px solid #eaa; background: #fdd; color:#d00; font-weight: bold; padding: .1em .5em;margin: .1em;}
form .js_error_list:empty { display: none;}
@keyframes fadeOut {  from { opacity: 1; }  to { opacity: .25; } } form .js_error_list.diss {opacity: .25; animation: fadeOut 10s}

.max-sirka {width: 100%; max-width: 1300px; margin:auto;position: relative;}

.tlacitko {color:#fff; background:var(--mainbarva); border: 0; font-size: 1rem; padding: .75em 1.5em; line-height: 1em; font-weight: bold; text-decoration: none; cursor: pointer; display: inline-block;}
button.tlacitko,input[type=submit].tlacitko {}
.tlacitko:hover {}
button.tlacitko:hover,input[type=submit].tlacitko:hover {}

.slflex {--mezery:calc( var(--sloupce) - 1 ); column-gap: var(--rozestup); display: flex; flex-wrap: wrap; }
.slflex > * { display: block; flex: 0 0 calc( calc( 100% - var(--mezery) * var(--rozestup) ) / var(--sloupce) ); }

:root {--wastemenu-color: #000; --wastemenu-xcolor: #000; --wastemenu-lwidth: 9%; --wastemenu-border: 9%; }
span.wasteofspace{  height: 2rem; min-width: 2rem; font-size: 0; display: inline-block; vertical-align: middle; overflow: hidden; padding: 0;
   background: linear-gradient(to bottom, 
         transparent 0% var(--wastemenu-border), 
         var(--wastemenu-color) var(--wastemenu-border) calc( var(--wastemenu-border) + var(--wastemenu-lwidth) ), 
         transparent calc( var(--wastemenu-border) + var(--wastemenu-lwidth) ) calc( 50% - var(--wastemenu-lwidth) / 2 ), 
         var(--wastemenu-color) calc( 50% - var(--wastemenu-lwidth) / 2 ) calc( 50% + var(--wastemenu-lwidth) / 2 ), 
         transparent calc( 50% + var(--wastemenu-lwidth) / 2 ) calc( 100% - var(--wastemenu-border) - var(--wastemenu-lwidth) ), 
         var(--wastemenu-color) calc( 100% - var(--wastemenu-border) - var(--wastemenu-lwidth) ) calc( 100% - var(--wastemenu-border) ), 
         transparent calc( 100% - var(--wastemenu-border) ) 100% 
      );
}
span.wasteofspace.waste-x {
   background: linear-gradient(45deg, 
         transparent 0% calc( 50% - var(--wastemenu-lwidth) / 2 ), 
         var(--wastemenu-xcolor) calc( 50% - var(--wastemenu-lwidth) / 2 ) calc( 50% + var(--wastemenu-lwidth) / 2 ), 
         transparent calc( 50% + var(--wastemenu-lwidth) / 2 ) 100%
      ), linear-gradient(-45deg, 
         transparent 0% calc( 50% - var(--wastemenu-lwidth) / 2 ), 
         var(--wastemenu-xcolor) calc( 50% - var(--wastemenu-lwidth) / 2 ) calc( 50% + var(--wastemenu-lwidth) / 2 ), 
         transparent calc( 50% + var(--wastemenu-lwidth) / 2 ) 100%
      );
}

/*========= společné definice (barvy, chování apod.) ===================================*/
:root {--mainbarva:#D21E33; }
h1:first-letter,h2:first-letter,h3:first-letter,p.h2:first-letter,p.h3:first-letter {text-transform: uppercase}
a,.mainbarva { color:var(--mainbarva) }
#naseptavac .naseppolozka:focus { background: var(--mainbarva);}
.gbg, .kform form {background: #ded6d1;}
.mainbg {background: var(--mainbarva); color:#fff;}
.mainbg a {color:#fff;}

.hoverline,.nohoverline,.hoverparent {text-decoration: none;}
.hoverline:hover,.hoverbase:hover .hoverparent {text-decoration: underline;}

/*========= prvky hlavičky =============================================================*/
#hlavickabg {background: url(/img/bghead.webp) center center no-repeat #fff; padding: 1.5em 0 1px; }
.uvodni #hlavickabg {background-position: center bottom; }
#hlavicka { }
#hgrid {display: grid; row-gap: 1em; column-gap: 3%; align-items: center; grid-template: auto / 150px 200px 1fr auto auto auto; margin-bottom: 1.5em;
        grid-template-areas: 'logo slogan . htel vlajky kosik';
}
#hlogo { display: block; grid-area: logo; }
#hslogan { grid-area: slogan; border-left: 1px solid #AEAEAE; padding: .5em 1em; margin-left: -.75em; color: #666; }
#htel { grid-area: htel; font-weight: bold; background: url(/img/i_foun.svg) left center no-repeat; padding-left: 2em; line-height: 30px; font-size: 22px; white-space: nowrap; }
#htel a {  color:#589909; }
#htel a:not(:hover) { text-decoration: none; }
#kosinfo { grid-area: kosik; }
#vlajky { grid-area: vlajky; }
#xhmenu { grid-area: xmenu; }

/*========= košík ======================================================================*/
#kosinfo { display: inline-block; text-decoration: none; box-sizing: border-box; font-weight: bold; background: #EBEBEB; padding-right: 1em; padding-left: 0;color:#000; }
#kosinfo::before { display: inline-block; margin-right: 1em; min-height: 50px; min-width: 50px; background: url(/img/i_kos.svg) center center no-repeat #625454; content: ' '; vertical-align: middle; }

/*========= menu =======================================================================*/
.hmenu {}
.hmenu a {text-decoration: none; display: grid; align-items: center; }
.hmenu .radic { display: inline-block; position: relative; }
.hmenu .msp { display: inline-block; padding: 0 1em; line-height: 1.25em; }
.hmenu .radic:hover .msp,
.hmenu .active .msp{ text-decoration: underline; }

#nhmenu { width: 100%; background: var(--mainbarva); display: flex; align-items: stretch; justify-items: stretch; padding: 1em 0; }
#nhmenu .radic { flex: 1 1 auto; }
#nhmenu a { height: 100%; color:#fff; font-weight: bold; text-transform: uppercase; text-align: center; }

#xhmenu {z-index: 1000; font-weight: bold; }
#xhmenu a { color: #000;  }
#xhmenu .extrawrap {display: block; background: #DED6D1; position: fixed; top:0; padding: 3em 12% 10em 5%; left:0; width: 100vw; bottom: 0; overflow: auto; z-index: 999; box-sizing: border-box;}
#xhmenu .radic{ display: block; text-align: left; z-index: 1000;}
#xhmenu .msp { padding:1em 0; height: auto;}
#xhmenu .radic:hover .podmenu, #xhmenu .podmenu.shown { display: none; }

/*========= jazyky =====================================================================*/
#vlajky { text-align: right; background: url(/img/i_vlzobak.svg) calc(100% - .5em) center no-repeat #EBEBEB; padding: .5em 0 .5em .5em; position: relative; }
#vlajky .flag { text-transform: uppercase; padding-right: 2em; display: block;}
#vlajky .flag-roll { position: absolute; top:100%; left:0; width: 100%; background: #EBEBEB; z-index: 200; display: block;}
#vlajky:not(:hover) .flag-roll { display: none}

#xvlajky {border-top:1px solid #ddd; display: block; margin-bottom: 1em;text-align: center; text-transform: uppercase; }
#xvlajky a {display: inline-block; width: auto; margin: 0 1em; padding: 1em 0; }

/*========= prvky stránky ==============================================================*/
#hcontent { padding-bottom: 2em; padding-top: 1px; }
.uvodni #hcontent { position: relative; min-height: 480px; padding-bottom: 4px; }
.uvodni #hcontent::after { position: absolute; z-index: 100; background: url(/img/drevnik.webp); background-size: contain; width:490px; height: 572px; top:0; right:0; display: block; content: ' '; }
#hcontent .webheading { font-weight: bold; font-size: 40px; text-transform: uppercase; margin: 3em 0 1.5em; max-width: calc(100% - 450px); }
#hcontent .webheading .big { font-size: 72px;}
#hcontent .tlacitko {background: transparent url(/img/tlship_transp.svg) calc(100% - 1.5em) center no-repeat; color:var(--mainbarva); border:1px solid var(--mainbarva); padding-right: 4em; }

#strankabg {background: #EBE6E3; padding: 2em 0 3em; }
.uvodni #strankabg {padding-top: 4em; }
#stranka { display: block; }
.uvodni #stranka { display: grid; grid-template: auto / 1fr 31%; column-gap: 5%; grid-template-areas: 'telo sloupecR';  }
#telo {grid-area: telo;}
#sloupec-pravy { grid-area: sloupecR; margin-top: 4em; }

#sl-link { background:#ded6d1 center top no-repeat; padding: 1.5em; }
#sl-link p {margin-top: 0; }
#sl-link.hasimg { background-image: var(--bgimg); background-size: 100% auto; padding-top: calc(1.5em + var(--bgsize)); }
#sl-link .slouplink { margin-top: 1.5em; margin-bottom: 0; }
#sl-link .tlacitko { background-image: url(/img/tlship_fill.svg); background-position: calc(100% - 1em) center; background-repeat: no-repeat; padding-right: 3em; }

#refsbg {background: #fff; padding: 3em 0 2em;}
#refs { text-align: center; }
#refs h2 {font-size: 32px; }
#refs .tlacitko { background: transparent url(/img/tlship_transp.svg) calc(100% - 1.5em) center no-repeat; color:var(--mainbarva); border:1px solid var(--mainbarva); padding-right: 4em; }
#fotoflex { --sloupce:4; --rozestup:2%; margin: 3em 0; }
#quotflex { display: flex; justify-content: center; column-gap: 4%; align-items: end; margin: 3em 0 0; }
#quotflex .quotwrap { flex: 0 0 40%; }
#quotflex blockquote { font-style: italic; position: relative; border-radius: 10px; border:0; padding: 3em 1.5em; }
#quotflex blockquote::after { display: block; position: absolute; top:100%; right: 50px; background: url(/img/refzobak.svg) center bottom; width: 43px; height: 30px; content: ' '; }
#quotflex .quotwrap > p { font-weight: bold; text-align: left; padding-left: 2em; }

#vyhody {--sloupce:2; --rozestup:3%; margin: 2em 0; row-gap: 1em; align-content: stretch; }
#vyhody .vyhoda { padding-left: 70px; box-sizing: border-box; background: var(--vyhbg) left center no-repeat; display: grid; align-items: center; min-height: 50px; }

/*========= obsah ======================================================================*/
#telo {padding: 0; margin:0;}

.obsah { line-height: 1.5em; position: relative; }
.obsah p { margin-top: 0;}
.obsah img.left,.obsah iframe.left,.obsah div.left {margin: .75em 1em; margin-left: 0;}
.obsah img.right,.obsah iframe.right,.obsah div.right {margin: .75em 1em; margin-right: 0;}
.obsah iframe {max-width: 100%;}

.obsah div.left,.obsah div.right, .obsah div.full {text-align: center; padding:1em;}
.obsah div.full{ margin: .75em 0;}
.obsah div.left > :last-child,.obsah div.right > :last-child,.obsah div.full > :last-child {margin-bottom:0; }

.anotacka { font-size: 1.1em; }

/*========= drobečková =================================================================*/
.drobnav {line-height: 1.75em; font-size: .8em; color:#888; margin: 1.5em 0; }
.drobnav a {color:#888;}
.drobnav span { padding:0; margin:0; display: inline-block;}
.drobnav span.odd {margin: 0 .75em;}

#telo .drobnav {margin-top: -1em;}

/*========= podstránky =================================================================*/
.podkat {width: 100%; --sloupce:4; --rozestup:1.5em; row-gap: 1.5em; margin: 1em 0; align-items: stretch; font-weight: bold; }
.podkat a {font-size: 20px; background:#DED6D1; color:#001927; display: grid; grid-template: auto 1fr / 1fr; grid-template-areas: 'pix' 'text'; }
.podkat a:not(:hover) {text-decoration: none; }
.podkat img { display: block; width: 100%; aspect-ratio: 1; object-fit: cover; grid-area: pix; }
.podkat .podtext { display: block; grid-area: text; padding: 1em;}

/*========= fotky ======================================================================*/
.gallery {width: 100%; margin-top: 1em; --sloupce:4; --rozestup:1.5em; text-align: center; row-gap: 1em;}
.gallery .box a {display: block;}
.gallery .box img {vertical-align: middle; }
.gallery img { padding:2%; border: 1px solid #fafafa; box-sizing: border-box; }
.gallery .text { display: block; margin-top: .25em; }

/*========= soubory ====================================================================*/
.files {display:table; max-width: 700px; width: 100%; margin-top: 1em;}
.files a {display: table-row; text-decoration: none}
.files span {display:table-cell; vertical-align: middle; text-align: left; padding: .5em 0; border-bottom: 1px solid #eee;}
.files img {float:left; margin: 0 .5em;}
.files .tail {text-align: right;}

/*========= články =====================================================================*/
.clanky {}
.clanky .clanek { margin-bottom: 2em; }
.clanky .h3 { font-weight: bold; font-size: 1.1em; margin-bottom: 0;}
.clanky .datum {font-size: .9em; color:#777; margin: 0 0 .5em;}

/*========= novinky ====================================================================*/
.novinky {}
.novinky .novinka {margin-bottom: 2em;}
.novinky .h3 {font-weight: bold; font-size: 1.1em; margin-bottom: 0;}
.novinky .datum {font-size: .9em; color:#777; margin: .5em 0 .75em;}

/*========= šablony ====================================================================*/
.respgbg,.respgbg tbody {width: 100%; border-collapse: collapse;}
.respgbg tr td:first-of-type {background:#f3f3f3;}
.respgbg tr td {border-bottom: 1px solid #eee;border-top: 1px solid #eee; padding: 0 .5em;}

.flexcols {display: flex; width:100%; flex-wrap: wrap; justify-content: space-around; align-items: flex-start; }
.flexcols.verticentr {align-items: center;}
.flexcols > div {padding: .5em; box-sizing: border-box; margin-bottom: 1em; }
.flexcols > div > p:last-child {margin-bottom: 0;}
.column2 > div {width: 50%; }
.column3 > div {width: 33.3%; }
.column4 > div {width: 25%; }
.column5 > div {width: 20%; }

/*========= kontaktní formulář =========================================================*/
.kform { text-align: left;}
.kform form { padding: 1.5em 3% .5em; }
.kform p {margin: 0 0 1em; }
.kform .sloup {display: inline-block; vertical-align: top; width: 48%; }
.kform .l { padding-right: 2%; }
.kform .r { padding-left: 2%; }
.kform label {display: block; line-height: 1.5em; padding: 0;}
.kform label.readerhelp {width: 0; height: 0; overflow: hidden; display: block; }
.kform .stretch {width: 100%; padding: .5em; border:0; background: #fff;}
.kform textarea.stretch { height: 4.25em;}
.kform .tlacitko {}
.kform ::placeholder { font-style: italic; color:#777; opacity: 1;}
#telo .kform {padding-top: .5em;}

/*========= normální formuláře =========================================================*/
.simpleform {width: 100%;}
.simpleform p {margin: .5em 0;}
.simpleform p label {display: inline-block; vertical-align: middle; width: 22%; }
.simpleform p input,.simpleform p select {display: inline-block; vertical-align: middle; width: 45%; margin:0; padding: 0 .5em; }
.simpleform p input[type=checkbox],.simpleform p input[type=radio] {width: auto; margin: initial; }
.simpleform p .tlacitko {vertical-align: middle; }

/*========= eshop - spolecne ===========================================================*/
/* Globální, konkrétními identifikátory podstránek doplněny */
.stitky { position: absolute; left: 0; top: 0; text-decoration: none; color: #000; }
.stitky span{ margin:.5em 0; display: block;}
.stitky span.akce{ }
.stitky span.novinka{ }
.stitky span.darek{ }
.stitky span.procenta{ }

/*========= eshop - výpis produktů =====================================================*/
.produkty {clear:both; margin-top: 1.5em; row-gap: 1em; --sloupce:4; --rozestup:1em; }
.produkt {position: relative; background: #DED6D1; display: grid; row-gap: 1em; box-sizing: border-box; text-align: center;   
   grid-template: auto minmax(3.3em,auto) 1fr / 1fr; 
   grid-template-areas: 'foto' 'nazev' 'spodni';}
.produkt .nazev {grid-area:nazev; line-height: 1.1em; display: block; text-align: left; color:#001927; padding: 0 1em; }
.produkt .foto { grid-area: foto; }
.produkt .foto img { width: 100%; aspect-ratio: 1; object-fit: cover; }
.produkt .botmid { grid-area: spodni; }
.produkt .cena {font-weight: bold; margin:0; }
.produkt .sklad {color:#a44; margin:0.5em; }
.produkt .sklad.ok {color:#4a4}
.produkt .stitky { top: 100px;}

.produkt.v2 { flex: 0 0 100%; align-items: center;
   grid-template: auto / 75px 0 1fr auto minmax(6em,auto) auto; 
   grid-template-areas: 'foto . nazev cena sklad pright'; }
.produkt.v2 .foto { aspect-ratio:1; }
.produkt.v2 .nazev { text-align: left; }
.produkt.v2 .cena { grid-area: cena; font-size: 1em; }
.produkt.v2 .sklad { grid-area: sklad; }
.produkt.v2 .pright { grid-area: pright; }

.more.tlacitko {margin: .5em 0;}
.more.tlacitko img {vertical-align: bottom; }

/*========= eshop - detail produktu ====================================================*/
.produkt-det {}
.produkt-det .fotosloupec {width: 59%; margin-right: 1%; display: inline-block; vertical-align: top; position: relative;}
.produkt-det .fotosloupec img { vertical-align: middle;}
.produkt-det .fotka-hlavni { text-align: center; white-space: nowrap; line-height: 400px; height: 400px; }
.produkt-det .fotocontainer { position: relative; padding: 2px 5%; background: #DED6D1; }
.produkt-det .fotocontainer a { width: 23%; margin:0 1%; white-space: nowrap; display: inline-block; text-align: center; }
.produkt-det .fotocontainer .borderer { height: 75px; display: block; line-height: 75px;}
.produkt-det .fragment { text-align: center; }
.produkt-det .vpravo { display: inline-block; width: 40%; }
.produkt-det .vpravo .radek { border-bottom: 1px solid #eee; padding: .33em 2%; }
.produkt-det .vpravo fieldset .radek { padding: .33em 0; }
.produkt-det .vpravo .radek label { width: 40%; display: inline-block; vertical-align: middle; color:#777; }
.produkt-det .vpravo .radek span { width: 60%; display: inline-block; vertical-align: middle; }
.produkt-det .vpravo .cradek {width: 100%; text-align: right;}
.produkt-det .vpravo #procentaDiv {float:left; padding: .5em 1em; width: auto; text-align: left; font-weight: bold; color:#fff}
.produkt-det .vpravo #staracenaDiv,.produkt-det .vpravo #malacenaDiv {color:#777; margin-top:1.5em}
.produkt-det .vpravo #staracenaDiv {text-decoration: line-through;}
.produkt-det .vpravo #cenaDiv {margin-top: 1.25em}
.produkt-det .vpravo #cenaDiv .mensi { font-size: .8em; color:#aaa; }
.produkt-det .vpravo .bigspan,.produkt-det fieldset #summall {font-size: 2em; font-weight: bold; white-space: nowrap; vertical-align: middle; margin-left: .5%;}
.produkt-det fieldset { border:0; padding: 1em 1%; margin: 1.5em 0 0; text-align: right}
.produkt-det fieldset.uzsi { padding: 1em 5%;}
.produkt-det fieldset .omezovac { width: 45%; display: inline-block; vertical-align: top; margin: 0 2.5%;}
.produkt-det fieldset .radek { margin-bottom: 15px; text-align: left }
.produkt-det fieldset .cradek { margin-bottom: 20px;}
.produkt-det fieldset label { width: 40%; display: inline-block; vertical-align: middle; color:#777; }
.produkt-det #bvarianta {vertical-align: middle; display: inline-block;}
.produkt-det fieldset .cradek span{ text-align: right; }
.produkt-det fieldset .cradek.mensi { color:#aaa; margin-top: -10px; }
.produkt-det fieldset select { width: 60%; display: inline-block; vertical-align: middle; padding: .5em 0; }
.produkt-det fieldset .input { width: 40%; display: inline-block; vertical-align: middle; text-align: left; white-space: nowrap; }
.produkt-det fieldset .input input { height: 2em; max-width: 55%; text-align: center; }
.produkt-det fieldset button { width: 55%; margin-left: 5%; display: inline-block; vertical-align: middle; padding:0; padding-top: .5em; padding-bottom: .5em;}
.produkt-det .moznosti {margin: 10px 0; border: 1px solid #eee; border-bottom: 0; }
.produkt-det .moznost {  border-bottom: 1px solid #eee; display: table; width: 100%; height: 60px; cursor: pointer}
.produkt-det .moznost span, .produkt-det .moznost a { display:table-cell; vertical-align: middle }
.produkt-det .moznost .cena { width: 20%; text-align: center;}
.produkt-det .moznost a { width: 15%; text-align: center; }
.produkt-det .moznost .forimg { width: 14.5%; text-align: center; }
.produkt-det .moznost .forimg.b { width: 12%;  }
.produkt-det .moznost .forimg img { max-width: 80%; max-height: 60px; text-align: center; }
.produkt-det .moznost .pcast { display: table-cell; width: 9%; vertical-align: middle;text-align: center; border-left: 1px solid #eee; }
.produkt-det .zalozky {margin: 1.5em 0;}
.produkt-det .zalObsah {margin: .5em 0;}
.produkt-det .paramtab {padding: 1em 5%;}
.produkt-det .paramtab label {display: inline-block; vertical-align: top; width: 30%;}
.produkt-det .paramtab span {display: inline-block; vertical-align: top; width: 70%;}

.produkt-det .fotocontainer .bx-prev,.produkt-det .fotocontainer .bx-next{ text-decoration: none; position: absolute; top:0; display: block; text-align: center; line-height: 79px; height: 79px; width: 5%; white-space: nowrap; margin:0; }
.produkt-det .fotocontainer .bx-prev img,.produkt-det .fotocontainer .bx-next img { display: none; }
.produkt-det .fotocontainer .bx-prev{ left:0; }
.produkt-det .fotocontainer .bx-prev::before{ content: '<' }
.produkt-det .fotocontainer .bx-next{ right:0; }
.produkt-det .fotocontainer .bx-next::before{ content: '>' }

/*========= eshop - filtrace  kategorie ================================================*/
.prodFiltr {width: 96%; padding: .75em 2%;}
.prodFiltr > div,.prodFiltr .settings > * {display: inline-block; vertical-align: middle; margin: .5em 0 0; }
.prodFiltr .settings { width: 83%;}
.prodFiltr .sender { width: 17%; text-align: center }
.prodFiltr .sender .tlacitko{  padding-left: 0; padding-right: 0; width: 100%; }
.prodFiltr .settings > * { margin: 1em 0 0; }
.prodFiltr .h { width: 17%; vertical-align: top; font-weight: bold; margin-right: 1%; }
.prodFiltr .prvky {  width: 82%; }
.prodFiltr .vyrbox {  display: inline-block; vertical-align: top; width: 24%; margin-bottom: .25em; margin-right: 1%;}
.prodFiltr .vyrbox label { display: inline-block;vertical-align: top; max-width: 78%;  }
.prodFiltr .vyrbox label a { display: block;}
.prodFiltr .vyrbox input { vertical-align: top; max-width: 22%; margin-left: 0; margin-right: 0; }

.prodFiltr .jslider {width: 70%; margin-top: -2px;}
.prodFiltr .jslider .jslider-value {font-size: .8em;}

.filt4 { position: relative;}
.filt4inner {overflow: hidden; }
.filt4link {position: absolute; bottom: -1.75em; right: 0;}

/*========= eshop - přepínací záložky ==================================================*/
.radzalozky { width: 100%; border-bottom: 1px solid #eee; margin-top: .5em; position: relative; }
.radzalozky .zalozka { display: inline-block; vertical-align: bottom; border: 1px solid #eee; border-radius: 2px 2px 0 0; line-height: 2em; margin-bottom: -1px; }
.radzalozky .zalozka > * { display: block; padding: 0 .5em; }

.predprodzal { padding-right: 4.5em; box-sizing: border-box; }
.radzalozky.prod { text-align: right; }
.radzalozky.prod.posunute {margin: -2em 0; float: right; width: auto;}
.radzalozky.prod .zalozka  { border: 0; text-align: center;  }
.radzalozky.prod .zalozka > * { padding: 0; width: 26px; margin-left: .5em; }
.radzalozky.prod .zalozka img { vertical-align: middle; }

.produkt-det .radzalozky .zalozka > * { padding: 0 .75em; }

.text4 { position: relative;}
.text4inner {overflow: hidden; }
.text4link {position: absolute; bottom: -1.7em; right: 10%;}

/*========= eshop - stránkování ========================================================*/
.paging {margin: 1em; text-align: right; font-size: 1.1em;}
.paging a,.paging .a{ margin: 0 .25em; }
.paging .curpage{ font-weight: bold; }

/*========= eshop - košík ==============================================================*/
.kos {  }
.kos table { width: 100%; padding-top: .75em; margin-bottom: 2em; text-align: center }
.kos table thead th { height: 1.5em; padding: 0 .5em; background-color: #DED6D1; border:0;}
.kos table td { height: 60px; vertical-align: middle; border:0; }
.kos table td.odkazova,.kos table td.variantni { text-align: left }
.kos table td.inputova { white-space: nowrap; text-align: left; width: 110px;}
.kos table td.cenova { text-align: right }
.kos table td img { max-height: 60px; max-width: 60px; }
.kos table .plusminus { background-color: #DED6D1; display:inline-block; vertical-align: middle; width:1.5em; height: 1.5em; line-height: 1.5em; text-decoration: none; color:#000;  text-align: center;}
.kos table .mnozstevni { width: calc( 100% - 4em ); max-width: 5em; height: 1.5em; vertical-align: middle; text-align: center;}
.kos table .final td { font-weight: bold; }
.kos .linky { text-align: right; }
.kos .linkovy {background: none; border:0; display:inline-block; vertical-align: middle; text-decoration: underline; margin-left: 3.5em; margin-right: 1.5em; padding: 1em 0; margin-bottom: .5em; cursor:pointer;}
.kos .tlacitko {vertical-align: middle; margin-left:2em; padding: 1em 1.5em; margin-bottom: .5em;}
.kos .zpet { padding:1em 0; float: left; display: inline-block; }

/*========= eshop - objednávka =========================================================*/
.objednavka{ margin: 20px 0;  }
.objednavka .tab {display: table; width: 100%; }
.objednavka .adresa{ width: 49%; display: inline-block; vertical-align: top; margin-right: 1%; }
.objednavka .adresa p { margin: .35em 0; line-height: 1.65em }
.objednavka .dodatky p { margin: .35em 0; line-height: 1.65em }
.objednavka .adresa label { width: 42%; display: inline-block; vertical-align: middle;}
.objednavka .adresa input,.objednavka .adresa select { width: 53%; vertical-align: middle;}
.objednavka .adresa input[type=checkbox],.objednavka .adresa input[type=radio] { width: auto; }
.objednavka .dodatky{ width: 100%; display: block;  }
.objednavka .dodatky label { width: 20.58%; display: inline-block; vertical-align: top; }
.objednavka .dodatky label.wider { width: 35%; }
.objednavka .dodatky .cb label { width: 75%; }
.objednavka .dodatky input { width: 50%; }
.objednavka .dodatky input[type=checkbox],.objednavka .dodatky input[type=radio] { width: auto; }
.objednavka .dodatky textarea { vertical-align: top;width: 50%; }
.objednavka .separat{ margin:2.5em 0; }
.objednavka .radioobj .radia { margin:.5em 0; border-bottom: 1px solid #ddd; padding: .5em 0; }
.objednavka .radioobj label {width: 100%; display: flex; flex-wrap: wrap; align-content: stretch; margin: 0 0 .5em; }
.objednavka .radioobj label input { width: 30px; margin: 0; align-self: center;}
.objednavka .radioobj label .tab1 { width: 50%; }
.objednavka .radioobj label .tab2 { flex-grow: 1; flex-shrink: 1; }
.objednavka .radioobj label .tab3 { width: 20%; }
.objednavka .radioobj .specbr { padding: 0 2em; margin: 0.5em 0; }
.objednavka .summary { width: 95%; padding-top: 10px; margin-bottom: 30px; font-weight: bold;}
.objednavka .summary tr { height: 3em; }
.objednavka .summary td { text-align: right; }
.objednavka .summary td.sirsi { text-align: left; }
.objednavka .tlacitko { margin: 1em 0; }

.objednavka .orderbody table {width:100%;}

/*========= prvky patičky ==============================================================*/
#patickabg {background: #403935; padding: 3em 0;}
#paticka { color:#fff; display: grid; column-gap: 3%; grid-template: auto / 136px 1fr 2fr auto; grid-template-areas: 'logo addr kont eu';  }
#paticka p { margin-top: 0; }
#paticka a { color:#fff; }
#paticka a:not(:hover) { text-decoration: none; }
#zakonceni { padding: 2em 0; position: relative; color:#fff; font-size: 14px; text-align: right; }
#zakonceni a { color: #fff; }
#zakonceni a:not(:hover) { text-decoration: none; }

#plogo {grid-area: logo;}
#padr {grid-area: addr; font-size: 16px; }
#pkont {grid-area: kont;}
#peu {grid-area: eu; padding-left: 85px; background: url(/img/eu.png) left top no-repeat; font-size: 16px;}

/*========= pro výměnu odkazů ==========================================================*/
.xch p {border-bottom: 1px solid #ddd; margin: 0; padding: .5em; width: auto;}
#xchlink {}

/*========= ostatní zbytečnosti ========================================================*/
@media (min-width: 689px){
   #cm.cloud {max-width: 800px; padding: 2em; }
   .cc_div .cloud #c-inr {display: flex;}
   .cc_div .cloud #c-inr-i {width: auto; flex-shrink: 1;}
   .cc_div .cloud #c-bns {max-width: 225px; width: 40%; font-size: 1.25em; text-align: center; }
   #cm.cloud #c-bns button + button.c-bn {display: inline-block; font-size: .82em; margin: 1.5em auto; float:none; padding: 0; background: #fff; width: auto; }
   #cm.cloud #c-bns button + button:hover {text-decoration: underline; cursor:pointer; }
}
@media (max-width: 689px){
   .cc_div .cloud #c-bns {display: flex; flex-direction:row; justify-content: space-between;}
   #cm.cloud .c-bn {width:auto; box-sizing: border-box;margin: 0; display: block; flex-basis: 45%; }
   #cm.cloud .c-bn:first-child {margin: 0; order:2}
   #cm.cloud #c-bns button + button.c-bn { background: #fff; order: 1; }
   #cm.cloud #c-bns button + button:hover {text-decoration: underline; cursor:pointer; }
}
:root {--cc-btn-primary-bg:var(--mainbarva); --cc-btn-secondary-hover-bg:#fff; }

.babish { text-align: left;}

#modalbase {position: fixed; top:0; left:0; width: 100vw; bottom: 0; background: rgba(0,0,0,.6); z-index: 10000; }
#modaldialog {background: #fff; padding: 1.5em; box-sizing: border-box; position: absolute; width: 80vw; left: 0; right: 0; text-align: center; max-width: 500px;margin-left: auto; margin-right: auto; overflow:auto; }
#modaldialog .dialogclose {position: absolute; display: block; color:transparent; background: url(/img/ikona-smaz.png) center center no-repeat; right:0; top:0; width: 1.5em; height: 1.5em; }
#modaldialog .tlacitko { margin: 0 1.5em 1em;pointer-events: auto; }

#modaldialog.dialogkosik { top:20vh; }

#modaldialog.dialogparcelshop { top:5vh;bottom:5vh; max-width: none; width: 90vw; }
#modaldialog.dialogparcelshop .pplmapcontain{ height: 100%; box-sizing: border-box; position: relative; }
#modaldialog.dialogparcelshop #ppl-parcel-shop-map { height:100%; }
#modaldialog.dialogparcelshop #ppl-parcelshop-map .ppl-parcelshop-map {height:100%;}
#modaldialog.dialogparcelshop #ppl-parcelshop-map .control-panel {padding-top: 0;}
#modaldialog.dialogparcelshop #ppl-parcelshop-map .control-panel__logo-holder {padding: 20px 0; margin:0;}

#modaldialog.dialogdpdpickup { top:5vh;bottom:5vh; max-width: none; width: 90vw; }
#modaldialog.dialogdpdpickup .iframecontain {position: relative; width: 100%; height: 100%;}
#modaldialog.dialogdpdpickup iframe { width: 100%; height: 100%; border:0; }

#modaldialog.dialogbalikovnapickup { top:5vh;bottom:5vh; max-width: none; width: 90vw; }
#modaldialog.dialogbalikovnapickup .iframecontain {position: relative; width: 100%; height: 100%;}
#modaldialog.dialogbalikovnapickup iframe { width: 100%; height: 100%; border:0; }

#modaldialog.dialogpaymentgateway { top:5vh;bottom:5vh; max-width: none; width: 90vw; }
#modaldialog.dialogpaymentgateway .iframecontain {position: relative; width: 100%; height: 100%;}
#modaldialog.dialogpaymentgateway iframe { width: 100%; height: 100%; border:0; }

/*========= responzivity ===============================================================*/

@media (max-width:1349px) { /* max-sirka + 50px */
   .max-sirka {width: 94%; margin: auto 3%;}
}

@media (max-width:1199px) {
   #hgrid {grid-template: auto / 100px 1fr auto auto auto; grid-template-areas: 'logo . htel kosik xmenu'; }
   #nhmenu {display:none;}
   .hmenu .hider { display:none!important; }
   #hslogan {display: none; }
   #vlajky {display: none; }
   #paticka { row-gap: 1.5em; grid-template: 1fr auto / 100px auto 1fr auto; grid-template-areas: 'logo addr . kont' 'eu eu eu eu';  }
   #peu { margin-top: 1em; }
   .gallery {--sloupce:3; }
}

@media (min-width:1200px) {
   #xhmenu {display:none;}
   .hmenu .shower {display:none!important;}
}

@media (max-width:999px) {
   .uvodni #strankabg { padding-top: 3em; }
   #refsbg {padding-top: 2em;}
   .uvodni #hcontent { min-height: 42vw; }
   .uvodni #hcontent::after { width: 45%; height: auto; aspect-ratio: 490/572; }
   #hcontent .webheading { font-size: 3.25vw; max-width: 45%; }
   #hcontent .webheading .big { font-size: 2em;}
   .podkat,.produkty { --sloupce:3; }
   .prodFiltr .vyrbox { width: 32.3%; }
   .kos table thead {display:none;}
   .kos table tbody {border-top: 1px solid #ccc; display: block;}
   .kos table tr {border-bottom: 1px solid #ccc; display: block; text-align: left;}
   .kos table td {display: inline-block; width: 33%; vertical-align: middle; height: auto; min-height: 2.5em; box-sizing: border-box;}
   .kos table td.pix {width: 25%; float:left; }
   .kos table td.odkazova {width: 75%; padding-top: .33em; }
   .kos table td.variantni {width: 100%; min-height: 0; }
   .kos table td.inputova {width: 45%; }
   .kos table td.cenova {width: 45%; }
   .kos table td.napravo {width: 10%; }
   .kos table tr td.num {text-align: center;}
   .kos table tr.final td.cenova {width: 57%; padding: .33em 0;}
   .kos table tr.final td:first-of-type {width: 33%;}
   .kos table.adresni td.odkazova {width: 90%; }
}

@media (max-width:799px) {
   #fotoflex {--sloupce:2;}
   .gallery {--sloupce:2; }
}

@media (max-width:749px) {
   #hgrid {grid-template: auto / 100px 1fr auto auto; grid-template-areas: 'logo . kosik xmenu'; }
   #htel {display: none;}
   .uvodni #stranka {  display: block; }
   #quotflex {flex-wrap: wrap; row-gap: 1.5em;}
   #quotflex .quotwrap {flex: 0 0 90%;}
   #quotflex blockquote {padding: 1em .75em;}
   .kform {width: auto; margin: auto; float: none;}
   .prodFiltr .jslider { width: 85%; }
}

@media (max-width:649px) {
   #paticka { grid-template: auto 1fr auto / 100px 1fr; grid-template-areas: 'logo addr' 'kont kont' 'eu eu';  }
   .podkat,.produkty { --sloupce:2; }
   .produkt.v2 { 
      grid-template: 1fr auto / 75px 1fr minmax(6em,auto) auto; 
      grid-template-areas: 'foto nazev nazev nazev' 'cena cena sklad pright'; }
   .produkt.v2 .cena {text-align: right;}
}

@media (max-width:599px) {
   html {font-size: 15px;}
   h1 {font-size:22px;}
   h2 {font-size: 20px;}
   h3 {font-size: 18px;}
   .podkat a {font-size: 16px;}
   .neuvodni #strankabg {padding-top: 1px;}
}

@media (max-width:549px) {
   #hcontent .tlacitko {background-image: none; padding-right: 1.5em; font-size: 3.25vw; }
   #vyhody {--sloupce:1;}
   .uvodni #strankabg { padding-top: 2em; }
   .obsah .left,.obsah .right { margin:.5em 0!important; float:none!important; display: block;}
   #hledatObal {min-width: 0; width: 40px;}
   #hledatObal .q {display: none;}
   #hledatObal:not(.xsshow) .tlacitko {width: 100%;}
   #hledatObal.xsshow { width: 95vw; position: fixed; top:70px; left: 2.5vw; z-index: 1000; background: #fff; }
   #hledatObal.xsshow .q {display: inline-block;}
   .objednavka .adresa { width: 99%;}
   .objednavka .dodatky textarea { width: 53%; }
   .objednavka .dodatky label { width: 42%; }
   .objednavka .dodatky .cb label { width: 75%; }
   .simpleform p label {width: 42%;}
   .simpleform p.cb label { width: 75%; }
   .produkt-det .fotosloupec { width: 100%;}
   .produkt-det .vpravo { float:none;width: 100%;}
   .produkt-det .resphid { display:none;}
   .produkt-det fieldset .omezovac {width: 95%;}
   .prodFiltr .vyrbox { width: 49%; }
}

@media (max-width:469px) {
   .podkat,.produkty {--sloupce:1; }
   .prodFiltr > div,.prodFiltr .settings > * {display: block;  }
   .prodFiltr .settings, .prodFiltr .h, .prodFiltr .prvky,.prodFiltr .sender { width: 100%; margin-left: 0; margin-right: 0;}
   .prodFiltr .sender { text-align: right }
   .prodFiltr .sender .tlacitko { padding-right: 1.5em; padding-left: 1.5em; width: auto }
   .objednavka .radioobj label .tab1 { width: 60%; }
   .objednavka .radioobj label .tab2 { display: none; }
   .objednavka .radioobj label .tab3 { width: auto; flex-grow: 1; flex-shrink: 1; text-align: right; }
}

@media (max-width:399px) {
   #hcontent .webheading { font-size: 13px; }
   #hcontent .tlacitko {font-size: 13px; }
   #kosinfo { font-weight: normal; padding-right: .5em; }
   #kosinfo::before { min-width: 30px; min-height: 30px; margin-right: .5em; }
   .kform .sloup {width: 100%;padding:0; }
   #login form { width: 150px; padding: .25em; box-sizing: border-box; text-align: center;}
   #login form .pwrap,#login form > p,#login form button,#login form label,#login form input {width: 100%; float:none; display: block;text-align: center; box-sizing: border-box; }
   #login form > p label {display: none;}
}


@media (max-width:849px) and (min-width:750px), (max-width:549px) {
   .respgbg,.respgbg tbody,.respgbg tr,.respgbg td {display: block; width: 100%;}
}

@media (max-width: 999px) {
   .column5 > div {width: 33%; }
}
@media (max-width: 849px) {
   .column4 > div {width: 50%; }
}
@media (max-width:549px) {
   .column3 > div {width: 50%; }
   .column5 > div {width: 50%; }
}
@media (max-width:469px) {
   .column2 > div {width: 100%; }
}
