/* ==========================================================================
   HTML5 Boilerplate styles - h5bp.com (generated via initializr.com)
   ========================================================================== */
@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,300;0,400;1,300;1,400&display=swap');


html {
    height: 100%
}

html,
button,
input,
select,
textarea {
    color: #222;
}

body {
    font-size: 14px;
    line-height: 1.4;
    background: #fff;
    font-family: 'Roboto', sans-serif;
    height: 100%;
    background: url('../Images/bg_body2.gif') repeat-y;
    margin: 0;
    padding:0;
    -moz-osx-font-smoothing: auto;
    -webkit-font-smoothing: antialiased;
}

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

.btn {
    cursor: pointer;
}

hr {
    display: block;
    height: 1px;
    border: 0;
    border-top: 1px solid #ccc;
    margin: 1em 0;
    padding: 0;
}

img {
    vertical-align: middle;
}

fieldset {
    border: 0;
    margin: 0;
    padding: 0;
}

textarea {
    resize: vertical;
}

.chromeframe {
    margin: 0.2em 0;
    background: #ccc;
    color: #000;
    padding: 0.2em 0;
}

h1, h2, h3, h4 {
    text-transform: uppercase;
    margin-top: 0;
    font-weight: 300;
}

/* ==========================================================================
   Author's custom styles
   ========================================================================== */
#ui-datepicker-div {
    display: none;
}

a {
    color: #205eb4;
    text-decoration: none;
    -webkit-transition: color 1s;
    -moz-transition: color 1s;
    transition: color 1s;
}

a:hover {
    color: #999;
    -webkit-transition: color 0.5s;
    -moz-transition: color 0.5s;
    transition: color 0.5s;
}

p {
    margin: 0 0 10px 0;
}

iframe {
    border: none;
}

#leftBar {
    height: 100%;
    color: #fff;
    /*background: #183962 url('../img/bg_left.jpg') no-repeat;*/
    background: #0a3b71 url('../Images/bg_left2.jpg') no-repeat;
    width: 265px;
    position: absolute;
    z-index: 100;
    padding: 0;
    min-height: 640px;
    left: 0;
    box-shadow: 0 -25px 25px black;
    border-right: 1px solid rgba(255,255,255,0.1);
    box-sizing: border-box;
}

#logo {

    width: 176px;
    margin: 40px auto;
}

#bookingLeft {
    margin: 20px;
    padding-bottom: 60px;
}

#wrapper {
    min-width: 780px;
    padding-left: 265px;
    height: 100%;
    position: relative;
}

/*  ##########  HEADER  ###########  */

#header {
    background: rgba(0, 0, 0, 0.85);
    height: 40px;
    position: absolute;
    z-index: 99;
    width: 100%;
}

#navigation {
    color: #fff;
    font-weight: 300;
    font-size: 18px;
    padding-left: 20px;
}

#navigation ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

#navigation ul li {
    display: block;
    float: left;
    text-transform: uppercase;
    margin-right: 40px;
    margin-top: 9px;
    letter-spacing: 1px;
}

#navigation ul li a, #iconNav a {
    color: #fff;
}

#navigation ul li a:hover, #iconNav a:hover {
    color: #b3d4fc;
}

#navigation ul li.activeNav a {
    color: #b3d4fc;
}

#iconNav {
    float: right;
    margin-top: 10px;
}

#iconNav ul {
    list-style: none;
    padding: 0;
    margin: 0;
}

#iconNav ul li {
    display: block;
    height: 20px;
    float: left;
    margin-right: 20px;
    position: relative;
}

#iconNav i {
    display: block;
    height: 20px;
}

.iconHome {
    width: 20px;
    background: url('../Images/iconHome.png') no-repeat;
}

.iconLage {
    width: 21px;
    background: url('../Images/iconMap.png') no-repeat;
}

.iconKontakt {
    width: 18px;
    background: url('../Images/iconPhone.png') no-repeat;
}

#lageHover {
    position: absolute;
    z-index: 999;
    width: 200px;
    height: 70px;
    background-color: rgba(0, 0, 0, 0.85);
    top: 40px;
    left: -100px;
    padding: 10px;
    -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
    -o-border-radius: 5px;
    -ms-border-radius: 5px;
    border-radius: 5px;
    display: none;
}

#lageHover:after {
    position: absolute;
    top: -10px;
    left: 100px;
    content: "";
    display: block;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 10px solid rgba(0, 0, 0, 0.85);
}

#lageHover input {
    width: 190px;
    border: none;
    padding: 0 5px;
    margin-bottom: 10px;
    height: 30px;
}

#lageHover button {
    display: block;
    width: 200px;
    height: 30px;
    background-color: #205eb4;
    border: none;
    color: #fff;
    font-size: 14px;

    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    transition: all 1s;
}

#lageHover button:hover {
    background-color: #b3d4fc;
    color: #205eb4;
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    transition: all 1s;
}

#contactHover {
    color: #fff;
    position: absolute;
    z-index: 999;
    width: 260px;
    height: 70px;
    background-color: rgba(0, 0, 0, 0.85);
    top: 40px;
    left: -190px;
    padding: 10px;
    -moz-border-radius: 5px;
    -webkit-border-radius: 5px;
    -o-border-radius: 5px;
    -ms-border-radius: 5px;
    border-radius: 5px;
    display: none;
}

#contactHover a {
    color: #b3d4fc;
}

#contactHover a:hover {
    color: #205eb4;
}

#contactHover h3 {
    text-align: center;
    color: #fff;
}

#contactHover:after {
    position: absolute;
    top: -10px;
    left: 170px;
    content: "";
    display: block;
    border-left: 10px solid transparent;
    border-right: 10px solid transparent;
    border-bottom: 10px solid rgba(0, 0, 0, 0.85);
}

/*  ##########  PICAREA  ###########  */

#picArea {
    background: url('../Images/bg_main1b.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    position: relative;
    margin-left: -1px;
    min-height: 420px;
}

#textArea {
    background: rgba(0, 0, 0, 0.6);
    color: #fff;
    position: absolute;
    top: 63%;
    width: 100%;
    padding: 0;
}

#textArea h1 {
    margin: 10px 20px 5px;
    text-transform: uppercase;
    font-size: 34px;
    letter-spacing: -1px;
    line-height: 40px;

    color: #fff;
}

#textArea h2 {
    margin: 0 20px 10px;
    text-transform: uppercase;
    font-size: 26px;
    letter-spacing: -1px;
    color: #fff;
}

.picAreaFollow {
    background: url('../Images/bg_main1b.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
    position: relative;
    height: 450px;
    margin-left: -1px;
    background-position-y: -30px;
}

/*  ##########  CONTENT  ###########  */
#content {
    position: relative;
}

#ctHomeWrapper {
    overflow: auto;
    padding: 20px 0 10px 0;
}

#ctHomeWrapper div.ctColumn {
    padding-bottom: 0;
}

#ctHomeWrapper div.ctColumn h2 {
    margin-bottom: 4px;
}

#ctHomeWrapper div.csc-textpic-text p {
    margin-top: 0;
}

#ctHomeWrapper figure.csc-textpic-image {
    margin-bottom: 0;
}

#ctMainWrapper {
    overflow: auto;
    padding: 20px;
    max-width: 1000px;
}

.row {
    padding: 0 20px;
    overflow: auto;
    position: relative;
}

.columnFull {
    /*    padding-bottom: 20px;*/
    margin: 0 20px 20px 20px;
}

.ctColumn {
    width: 47%;
    height: 100%;
    padding-bottom: 20px;
    padding-right: 2%;
}

.ctColumn23 {
    width: 75%
}

.ctColumn13 {
    width: 24%
}

.ctColumn h2 {
    margin-top: 0;
}

.columnInner {
    padding: 0 20px 0 0;
}

.columnLeft {
    float: left;
    border-right: 1px dotted #999;
}

.ctColumn div.csc-textpic-text {
    padding-left: 130px;
}

.columnRight {
    float: right;
}

#ctMainWrapper h1, h2 {
    color: #205eb4;
}

.featureItem {
    margin-right: 2%;
    margin-bottom: 30px;
}

.fiL {

    width: 45%;
    float: left;
    clear: left;
}

.fiR {

    width: 45%;
    float: right;
}

/* MAIN*/
.special img {
    width: 20%;
    float: left;
    margin: 0 10px 10px 0;
}

/* Philosophie*/
.headerImage {
    width: 100%;
    height: 120px;
    position: relative;
}

#hIreception {
    background: url('../Images/tmp_reception.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#hIbreakfast {
    background: url('../Images/tmp_breakfast.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#hIinternet {
    background: url('../Images/tmp_internet.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#hIcleaners {
    background: url('../Images/tmp_cleaners.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#hIhousekeeping {
    background: url('../Images/tmp_housekeeping.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

#hIparking {
    background: url('../Images/tmp_parking.jpg') no-repeat center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover;
}

.hIheadline {
    position: absolute;
    bottom: 10px;
    background: rgba(0, 0, 0, 0.6);
    width: 100%;
}

.hIheadline h2 {
    margin: 0 0 0 20px;

    color: #fff;
}

/** APARMENTS **/
.columnList {
    border-bottom: 1px dotted #999;
    overflow: auto;
    padding-bottom: 20px;
}

.listInner {
    padding-left: 200px;
}

.columnList h2 {
    margin-top: 0;
    margin-bottom: 10px;
}

.columnList ul {
    padding: 0;
    margin: 0;
}

.columnList ul li {
    list-style: none;
    margin-bottom: 5px;
}

div.columnFull img {
    float: left;
    width: 180px;
    margin: 0 20px 20px 0;
}

.apartment {
    border-bottom: 1px dotted #999;
    margin-bottom: 30px;
    padding-bottom: 15px;
}

.apartment h2 {
    margin-bottom: 10px;
    line-height: 16px;
}

.apartment img {
    width: 200px;
    float: left;
}

.aptInner {
    margin-left: 220px;
}

.aptInner ul {
    margin: 0 0 15px 0;
    padding: 0;
    list-style: none;
}

.aptInner li {
    margin-bottom: 10px;
}

.aptPicArea {
    width: 200px;
    float: left;
    height: 150px;
    position: relative
}

.aptPicArea div.pic {
    width: 200px;
    height: 150px;
    background: #999;
    position: absolute;
}

.aptPicArea div.availability {
    height: 22px;
    padding: 4px 10px 4px 10px;
    background: rgba(0, 0, 0, 0.5);
    color: #fff;
    position: absolute;
    top: 120px;
    width: 180px;
}

.aptPicArea div.availability a, .aptPicArea div.availability a:hover {
    color: #fff;
    text-decoration: none;
}

/* Kontakt */

.csc-mailform ol {
    list-style: none;
}

#ctMainWrapper label {
    width: 80px;
    display: block;
    padding-top: 5px;
    float: left;
}

#ctMainWrapper li.csc-form-element-textarea label {
    width: 400px;
}

#ctMainWrapper input {
    border: 1px solid #205eb4;
    height: 30px;
    width: 168px;
    padding: 0 5px;
    margin-bottom: 10px;
}

#ctMainWrapper textarea {
    border: 1px solid #205eb4;
    height: 240px;
    width: 640px;
    margin-bottom: 10px;
}

#ctMainWrapper button {
    display: block;
    width: 180px;
    height: 35px;
    background-color: #205eb4;
    border: none;
    color: #fff;
    font-size: 14px;
    -webkit-transition: background-color 1s, color 1s;
    transition: background-color 1s, color 1s;
}

#ctMainWrapper button:hover {
    background-color: #b3d4fc;
    color: #205eb4;
    -webkit-transition: background-color 1s, color 1s;
    transition: background-color 1s, color 1s;
}

#ctMainWrapper input.submitButton {
    display: block;
    width: 180px;
    height: 35px;
    background-color: #205eb4;
    border: none;
    color: #fff;
    font-size: 14px;
    -webkit-transition: background-color 1s, color 1s;
    transition: background-color 1s, color 1s;
}

#ctMainWrapper input.submitButton:hover {
    background-color: #b3d4fc;
    color: #205eb4;
    -webkit-transition: background-color 1s, color 1s;
    transition: background-color 1s, color 1s;
}

.formRow {
    overflow: auto;
}

.formerror {
    float: left;
    width: 250px;
    color: red;
    margin: 8px 0 20px 93px;
    font-size: 11px;
}

.txtareaLabel {
    overflow: auto;
}

#ctMainWrapper div.txtareaLabel label {
    width: auto;
}

/*  ##########  BOOKING  ###########  */

#bookingLeft label {
    font-size: 14px;
    margin-bottom: 5px;
}

#bookingLeft input {
    height: 32px;
    border: none;
    color: #191e23;
    margin-bottom: 10px;
}

#bookingLeft select {
    -webkit-appearance: button;
    -webkit-border-radius: 0;
    -webkit-box-shadow: 0 1px 3px rgba(0, 0, 0, 0.1);
    -webkit-padding-end: 20px;
    -webkit-padding-start: 2px;
    -webkit-user-select: none;
    background: none;
    /*
    background-image: url(../img/pulldown-arrow.png),
      -webkit-linear-gradient(#FAFAFA, #F4F4F4 40%, #E5E5E5);*/
    background-position: center left;
    background-repeat: no-repeat;
    border: none;
    color: #555;
    font-size: inherit;
    margin: 0;
    overflow: hidden;
    padding-top: 2px;
    padding-bottom: 2px;
    text-overflow: ellipsis;
    white-space: nowrap;
}

.selectGroup {
    overflow: auto;
    position: relative;
    height: 30px;
    float: left;
}

.selectGroup select {

    height: 28px;
    width: 45px;
    left: 0;
    position: absolute;
    z-index: 10;
}

.iconPulldown {
    float: left;
    width: 45px;
    height: 28px;
    display: block;
    background: #fff url('../Images/pulldown-arrow.png') no-repeat center right;
    position: absolute;
    z-index: 1;
}

#bookingLeft button {
    display: block;
    width: 180px;
    height: 35px;
    background-color: #205eb4;
    border: none;
    color: #fff;
    margin: 10px auto 0;
    font-size: 14px;

    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    transition: 1s all;
}

#bookingLeft button:hover {
    background-color: #b3d4fc;
    color: #205eb4;
    -webkit-transition: all 1s;
    -moz-transition: all 1s;
    transition: 1s all;
}

/** LAGE **/
#map-canvas {
    width: 100%;
    height: 460px;
}

#mapControl button {
    display: inline;
}

#directionsBox {
    display: none;
    margin-bottom: 20px;
}

.adp-legal {
    font-size: 11px;
}

.adp-substep b {
    color: #205eb4;
}

/*  ##########  FOOTER  ###########  */

#footer {
    background: #8c8c8c;
    color: #fff;
    height: 30px;
    font-size: 12px;
    padding: 0 20px;
}

#footer div {
    margin-top: 8px;
    height: 22px;

}
#footer div > div {
    margin-top: 0;
    display: inline-block;
}

#ftImprint {
    float: left;
}

#ftAddress {
    float: right;
}

#footer a {
    color: #fff;
}

#footer a:hover {
    color: #b3d4fc;
}
#ftImprint a { margin-right: 10px;}

/* EXTRAS */
.more a {
    color: #205eb4;
}

.more a:hover {
    color: #191e23;
    text-decoration: underline;
}

.csc-frame-frame1 {
    float: left;
    border-right: 1px dotted #999;
    width: 49%;
}

.csc-frame-frame2 {
    float: right;
    width: 49%;
}

a.fancybox {
    display: inline-block;
    margin: 0 5px 5px 0;
}

/* ==========================================================================
   Media Queriesim
   ========================================================================== */

@media only screen and (min-width: 35em) {

}

@media print,
(-o-min-device-pixel-ratio: 5/4),
(-webkit-min-device-pixel-ratio: 1.25),
(min-resolution: 120dpi) {

}

/* ==========================================================================
   Helper classes
   ========================================================================== */

.ir {
    background-color: transparent;
    border: 0;
    overflow: hidden;
    *text-indent: -9999px;
}

.ir:before {
    content: "";
    display: block;
    width: 0;
    height: 150%;
}

.hidden {
    display: none !important;
    visibility: hidden;
}

.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

.invisible {
    visibility: hidden;
}

.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}

.clearfix:after {
    clear: both;
}

.clearfix {
    *zoom: 1;
}

/* ==========================================================================
   Print styles
   ========================================================================== */

@media print {
    * {
        background: transparent !important;
        color: #000 !important; /* Black prints faster: h5bp.com/s */
        box-shadow: none !important;
        text-shadow: none !important;
    }

    a,
    a:visited {
        text-decoration: underline;
    }

    a[href]:after {
        content: " (" attr(href) ")";
    }

    abbr[title]:after {
        content: " (" attr(title) ")";
    }

    /*
     * Don't show links for images, or javascript/internal links
     */
    .ir a:after,
    a[href^="javascript:"]:after,
    a[href^="#"]:after {
        content: "";
    }

    pre,
    blockquote {
        border: 1px solid #999;
        page-break-inside: avoid;
    }

    thead {
        display: table-header-group; /* h5bp.com/t */
    }

    tr,
    img {
        page-break-inside: avoid;
    }

    img {
        max-width: 100% !important;
    }

    @page {
        margin: 0.5cm;
    }

    p,
    h2,
    h3 {
        orphans: 3;
        widows: 3;
    }

    h2,
    h3 {
        page-break-after: avoid;
    }
}


/* FORM */
#ctMainWrapper .csc-form-7
{
    margin-left: 80px;
    padding: 10px;
    border: 1px solid grey;
    background: rgba(0,0,0,0.03);
    margin-bottom: 30px;
    width: 625px;
}
#ctMainWrapper .csc-form-7 label {
    width: 580px;
    float: right;
    margin-bottom: 4px;
}
#ctMainWrapper .csc-form-7 input {
    width: 20px;
}

#ctMainWrapper .graybox {
    width: 625px;
    margin-left: 80px;
    padding: 10px;
    border: 1px solid grey;
    background: rgba(0,0,0,0.03);
    overflow: auto;
}

#ctMainWrapper .graybox label.dsgvocheck {
    width: auto;
    margin-right: 15px;
    float: left;
}

#ctMainWrapper .graybox input {
    width: auto;
    margin-right: 10px;
    vertical-align: top;
}

.frame-type-form_formframework .actions {
    clear: both;
    margin: 30px 0 10px;
    padding-left: 80px;
}



#online-reservation {
  text-align:center;
}

.buchungsButton {
  display: inline-block;
    padding: 10px 15px;
    background: white;
    margin: 40px 15px;
    box-shadow: 1px 3px 4px rgba(0,0,0,0.2);
  border: 1px solid #205eb4;
  transition: 0.5s all;
}

.buchungsButton:hover {
  background-color: #205eb4;
  color: white;
  border-color: white;
}
