body, h1, h2, h3, p, img, form, ul, li, fieldset, table, tr, td, th { margin:0; padding:0; border:0; }
* { box-sizing: border-box; }
html { overflow: auto; }
a { outline:none; }

body {
  background: radial-gradient(circle at top, #222b3d 0%, #111722 45%, #0a0f18 100%);
  font-family: "Segoe UI", "Trebuchet MS", Verdana, Arial, sans-serif;
  font-size: 92%;
  color: #f2f5fb;
  text-align: center;
  line-height: 1.45;
}

img { max-width: 100%; height: auto; }

#wrapper {
  width: min(955px, 100% - 32px);
  margin: 0 auto;
  padding-top: 28px;
}
#main-top { }
#main { min-height: 642px; position: relative; }

body.page #main-top {  }
body.page #main { }

.break { clear: both; }

.top-menu {
  width: 100%;
  margin: 0 auto 14px;
  padding: 20px 0 15px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
  text-align: center;
  font-size: 1em;
}

.top-menu .logo-banner {
  --logo-band-height: 140px;
  width: 100%;
  height: var(--logo-band-height);
  display: grid;
  grid-template-columns: auto 1fr;
  column-gap: 12px;
  align-items: stretch;
  margin-bottom: 0;
  overflow: visible;
}

.top-menu .logo-text-side {
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 4px;
  height: var(--logo-band-height);
  padding: 0;
  pointer-events: none;
  overflow: hidden;
  grid-column: auto;
}

.top-menu .logo-text-side.right {
  grid-column: 2;
}

.top-menu .tape-line {
  margin: 0;
  white-space: nowrap;
  text-transform: uppercase;
  font-size: clamp(0.56em, 0.95vw, 0.68em);
  font-weight: 700;
  line-height: 0.78;
  color: rgba(233, 243, 255, 0.38);
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.35);
  flex: 0 1 auto;
}

.top-menu .tape-line.line-1 { letter-spacing: 0.12em; word-spacing: 0.5em; }
.top-menu .tape-line.line-2 { letter-spacing: 0.18em; word-spacing: 0.7em; }
.top-menu .tape-line.line-3 { letter-spacing: 0.1em; word-spacing: 0.95em; }
.top-menu .tape-line.line-4 { letter-spacing: 0.16em; word-spacing: 0.6em; }

.top-menu .logo {
  grid-column: 1;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  width: auto;
  height: var(--logo-band-height);
  padding-right: 0;
}

.top-menu .logo img {
  display: block;
  width: auto;
  height: var(--logo-band-height);
  max-height: var(--logo-band-height);
  max-width: min(460px, 95vw);
  filter: drop-shadow(0 3px 10px rgba(0, 0, 0, 0.35));
}

.menu-row {
  display: flex;
  width: 100%;
  align-items: center;
  justify-content: center;
  flex-wrap: wrap;
  gap: 10px 20px;
}

.menu-left {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 22px;
}

.menu-right {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-left: 0;
  gap: 22px;
}

.top-menu a {
  display: inline-block;
  padding: 10px 16px;
  font-size: 1.05em;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  border-radius: 8px;
  border: 1px solid #4b5d7d;
  background: linear-gradient(180deg, #314662 0%, #25364e 100%);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.35);
  transition: background 0.15s ease, color 0.15s ease, transform 0.08s ease;
}

.top-menu a:hover {
  background: linear-gradient(180deg, #3a577d 0%, #2c4463 100%);
  color: #fff;
  transform: translateY(-1px);
}

.ceny {
  max-width: 600px;
  margin: 5px 0;
  padding-bottom: 7px; 
  text-align: left;
}

.ceny ul {
  margin-left: 0;      
  padding-left: 20px;  
}

.info-sloupec {
  max-width: 520px;    
  margin: 0 0 0 20px;      
  text-align: left;    
}


/*#content { text-align: left; padding: 20px 0px 0px 70px; width: 665px; xfloat: left; }*/
#content {
  width: 100%;
  max-width: 955px;
  margin: 0 auto;
  padding: 24px 14px 0;
  text-align: left;
}
  #content h1 { font-size: clamp(1.7em, 3.4vw, 2.2em); padding-bottom: 20px; text-shadow: none; color: #ffffff; }
  #content h1 span { font-size: 0.7em; }
  #content h2 { font-size: clamp(1.3em, 2.6vw, 1.75em); text-shadow: none; color: #ffffff; padding-bottom: 8px; padding-top: 5px; }
  #content h2 { margin-top: 30px; margin-bottom: 15px; }
  #content h2 span { font-weight: normal; font-size: 0.7em; }
  #content h2.galerie { background: url('images/photo.png') no-repeat left top; border-bottom: 1px solid rgba( 255, 255, 255, 0.5); padding-left: 58px; margin-bottom: 10px; }
  #content h2.galerie a { color: #9bc3ff; }
  #content h2.galerie a:hover { color: #c1dcff; }
  #content h3 { font-size: clamp(1.15em, 2.1vw, 1.45em); text-shadow: none; color: #e9f1ff; }
  #content p { font-size: 0.94em; padding-bottom: 6px; margin-bottom: 8px; text-shadow: none; color: #dbe5f6; }
  #content p.zpet { font-size: 1.1em; padding-bottom: 12px; } 
  #content p a { color: #9bc3ff; font-weight: bold; }
  #content p.zpet a { font-weight: normal; }  
  #content p a:hover { color: #c1dcff; }
  #content p.tym { border-bottom: 1px solid rgba(255, 255, 255, 0.18); margin-bottom: 7px; }
  #content p.tym span { font-size: 0.8em; }
  
  #content p.error { background: #fff6bf url('images/error.png') 5px 50% no-repeat; padding: 5px 5px 5px 28px;border: 1px solid #ffd324; margin-bottom: 15px; font-size: 1.02em; color: #d6095e; }	
  #content p.ok { background: #e5fab1 url('images/ok.png') 5px 50% no-repeat; padding: 5px 5px 5px 28px; border: 1px solid #b0e62a; margin-bottom: 15px; font-size: 1.02em; color: #151c28; }
  
  #content div.komentar { border-top: 1px solid rgba(255, 255, 255, 0.2); border-bottom: 1px solid rgba(255, 255, 255, 0.2); background: rgba(255, 255, 255, 0.06);
                          padding: 10px 15px; margin-bottom: 10px; } 
  #content div.komentar p { font-size: 1.2em; }
  #content div.komentar p.titulek { font-style: italic; padding-bottom: 0px; }
  #content div.komentar p.vlozeno { color: #9fb1cc; }

  #content div.admin p.titulek { color: #c00; }
  #content div.admin p.text { font-weight: bold; }
  
  #content form legend { font-size: 1.2em; color: #ffffff; }
  #content form label { font-size: 1.02em; color: #e2ecff; }
  #content form label span { color: #c00; }
  #content form input.text { margin-bottom: 2px; width: min(100%, 380px); }
  #content form textarea { width: min(100%, 480px); height: 100px; }
  
  #content form.registrace { margin-top: 10px; }
  #content form.registrace fieldset { padding: 20px 20px 10px 0; border: 1px solid rgba(255, 255, 255, 0.2); margin-bottom: 10px; border-radius: 10px; background: rgba(255, 255, 255, 0.03); }
  #content form.registrace legend { color: #d6e7ff; line-height: 2em; margin-left: 0; padding: 0; font-weight: bold;}
  /*#content form.registrace label { width: 130px; float: left; text-align: right; margin-right: 10px; } */
  #content form.registrace label { width: 180px; float: left; text-align: right;  margin-right: 10px; line-height: 1.4em; }
  #content form.registrace input.text:focus { background: #1f2c40; }
  #content form.registrace textarea {margin-bottom: 2px;  }
  #content form.registrace textarea:focus { background: #1f2c40; }
  #content form.registrace p { font-size: 1.03em; }
  #content form.registrace p.startovne-info { margin-left: 20px; }
  #content form.registrace input,
  #content form.registrace textarea,
  #content form.registrace select {
    vertical-align: top;
  }
  #content form.registrace br { clear: both; }
  #content form.penzion fieldset { padding: 5px 20px; border: 1px solid rgba(255, 255, 255, 0.2); margin-bottom: 10px; border-radius: 10px; background: rgba(255, 255, 255, 0.03); }
  #content form.penzion legend { color: #d6e7ff; line-height: 2em; margin: 0; padding: 0 10px; font-weight: bold;}
  #content form.penzion label { width: 550px; float: left; text-align: right; margin-right: 10px; }
  #content form.penzion select { margin-bottom: 2px; }
  #content form.penzion input.pocet { margin-bottom: 2px; width: 40px; }    
  #content form.penzion input.pocet:focus { background: #1f2c40; }
  #content form.penzion textarea:focus { background: #1f2c40; }
  #content form.penzion p { font-size: 1.03em; }

  #content form.order fieldset,
  #content fieldset.payment-section {
    padding: 20px 20px 10px 0;
    border: 1px solid rgba(255, 255, 255, 0.2);
    margin-bottom: 10px;
    border-radius: 10px;
    background: rgba(255, 255, 255, 0.03);
  }

  #content form.order legend,
  #content fieldset.payment-section legend {
    font-size: 1.2em;
    color: #d6e7ff;
    line-height: 2em;
    margin: 0;
    padding: 0 10px;
    font-weight: bold;
  }

  #content form.order fieldset.order-actions {
    border: 0;
    background: transparent;
    padding: 10px 0 0;
    margin: 0;
  }

  #content fieldset.payment-section {
    margin-top: 16px;
  }

  #content fieldset.payment-section p {
    margin-left: 50px;
  }

  #content form.order fieldset:nth-of-type(1) {
    padding-left: 0;
  }

  #content form.order fieldset:nth-of-type(1) > :not(legend) {
    margin-left: 20px;
  }

  #content form.order .startovne-text {
    margin-left: 20px;
  }

  #content form.order fieldset:nth-of-type(4) table.tricka {
    width: calc(100% - 100px);
    margin-left: 100px;
  }

/* login form vlevo jako registrace */
form.login {
    max-width: 665px;      /* stejné jako registrace */
    margin: 0;             /* vlevo pod h2 */
    padding: 0;
}

form.login .form-row {
    margin-bottom: 10px;
    overflow: hidden;      /* aby floaty držely layout */
}

form.login label {
    float: left;
    width: 180px;          /* stejná šířka jako registrace */
    text-align: right;
    margin-right: 10px;
    line-height: 1.4em;
}

form.login input[type="text"],
form.login input[type="password"] {
    float: left;
    width: 300px;
}

form.login input[type="submit"] {
    display: block;
    margin-left: 190px;    /* zarovnání tlačítka pod inputy */
    clear: both;
}

#content input[type="submit"],
#content input.submit,
#content button {
    padding: 10px 18px;
    font-size: 1.08em;
    font-weight: bold;
    color: #fff;
    background: linear-gradient(180deg, #4c77be 0%, #355a96 100%);
    border: 1px solid #8bb2ef;
    border-radius: 8px;
    cursor: pointer;
    box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
}

#content input[type="submit"]:hover,
#content input.submit:hover,
#content button:hover {
    background: linear-gradient(180deg, #5d88cf 0%, #4068a8 100%);
}

#content form.order input[type="submit"] {
    margin-bottom: 26px;
}

p.error {
    background: #fff6bf url('images/error.png') 5px 50% no-repeat;
    padding: 5px 5px 5px 28px;
    border: 1px solid #ffd324;
    margin-bottom: 15px;
    font-size: 1.02em;
}

#content form.login br {
    clear: both;
}

form.login p {
    font-size: 1em;
    clear: both;        /* aby bloky p byly pod formulářem */
}

form.login a {
    color: #9bc3ff;
}
  
  #content table.tricka { margin-bottom: 10px; width:100%; }
  #content table.tricka td { font-size: 1em; text-shadow: none; color: #e7efff; }
  #content table.tricka th { font-size: 1em; text-align: center; }
  #content table.tricka label { display: none; }
  #content table.tricka input.pocet { width: 52px; max-width: 100%; }
  
  #content table { width: 100%; border-collapse: collapse; display: block; overflow-x: auto; }
  #content table.galerie { display: table; width: 100%; }
  #content table.galerie td { padding: 4px; }
  
  
#footer {
  width: min(955px, 100% - 32px);
  border-top: 1px solid rgba(255, 255, 255, 0.2);
  padding-top: 10px;
  margin: 50px auto 20px;
}
  #footer p { font-size: 11px; color: #b9c8de; }
  
  .PravidlaMarked {color:#c00;}    
  
  img.flag { position: absolute; left: 380px; top: 30px; }
  
  table.galerie a img { border: 1px solid #fff; }
  table.galerie a:hover img { border: 1px solid #3568A6; box-shadow: 2px 2px 2px #555; }

#content input[type="text"],
#content input[type="password"],
#content input.text,
#content input.pocet,
#content select,
#content textarea {
  font-family: inherit;
  min-height: 40px;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid #5a6f91;
  background: #1a2536;
  color: #f3f7ff;
}

#content textarea {
  min-height: 110px;
}

#content input[type="text"]:focus,
#content input[type="password"]:focus,
#content input.text:focus,
#content input.pocet:focus,
#content select:focus,
#content textarea:focus {
  outline: none;
  border-color: #92b9f6;
  box-shadow: 0 0 0 2px rgba(146, 185, 246, 0.2);
}

/* Order page layout */
#content form.order fieldset:nth-of-type(3) label {
  float: none;
  display: inline-block;
  width: min(100%, 520px);
  text-align: right;
  margin: 0 10px 2px 0;
  vertical-align: middle;
}

#content form.order fieldset:nth-of-type(2) label {
  float: none;
  display: inline-block;
  width: min(100%, 520px);
  text-align: right;
  margin: 0 10px 2px 0;
  vertical-align: middle;
}

#content form.order fieldset:nth-of-type(2) select {
  display: inline-block;
  width: 120px;
  margin-bottom: 2px;
  vertical-align: middle;
}

#content form.order fieldset:nth-of-type(3) input.pocet {
  display: inline-block;
  width: 58px;
  min-height: 36px;
  margin-bottom: 2px;
  text-align: center;
  vertical-align: middle;
}

#content form.order fieldset:nth-of-type(4) table.tricka td,
#content form.order fieldset:nth-of-type(4) table.tricka th {
  text-align: left;
}

@media (max-width: 959px) {
  .top-menu {
    font-size: 1.05em;
    padding: 12px 0 8px;
  }

  .menu-left,
  .menu-right {
    gap: 8px 12px;
  }

  .top-menu a {
    padding: 9px 13px;
  }

  #content {
    padding-top: 14px;
  }

  #content form.registrace label,
  #content form.penzion label,
  form.login label {
    float: none;
    display: block;
    width: auto;
    text-align: left;
    margin-right: 0;
    margin-bottom: 3px;
  }

  #content form.registrace input.text,
  #content form.registrace select,
  #content form.registrace textarea,
  #content form.penzion input,
  #content form.penzion select,
  #content form.penzion textarea,
  form.login input[type="text"],
  form.login input[type="password"] {
    float: none;
    width: min(100%, 500px);
  }

  form.login input[type="submit"] {
    margin-left: 0;
  }

  #content form.registrace p,
  #content form.penzion p {
    font-size: 1em;
  }

  #content form.order fieldset:nth-of-type(2) label {
    display: block;
    width: auto;
    text-align: left;
    margin: 0 0 4px;
  }

  #content form.order fieldset:nth-of-type(2) select {
    display: block;
    width: min(100%, 220px);
  }

  #content form.order fieldset:nth-of-type(3) label {
    display: block;
    width: auto;
    text-align: left;
    margin: 0 0 4px;
  }

  #content form.order fieldset:nth-of-type(3) input.pocet {
    display: block;
  }

  #content form.order fieldset:nth-of-type(1) {
    padding-left: 0;
  }

  #content form.order fieldset:nth-of-type(1) > :not(legend) {
    margin-left: 0;
  }

  #content form.order fieldset:nth-of-type(4) table.tricka {
    width: 100%;
    margin-left: 0;
  }
}

@media (max-width: 640px) {
  #wrapper,
  #footer {
    width: calc(100% - 20px);
  }

  .top-menu .logo-banner {
    --logo-band-height: 110px;
    height: var(--logo-band-height);
    grid-template-columns: auto 1fr;
    column-gap: 8px;
  }

  .top-menu .logo img {
    height: var(--logo-band-height);
    max-height: var(--logo-band-height);
  }

  .top-menu .tape-line {
    font-size: 0.5em;
  }

  #content h2.galerie {
    padding-left: 0;
    background: none;
  }
}
