/*
 * Grau: #333333
 * Grün: #2B3328
 * Braun: #332B28
 */
html, body
{
    /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#333333+50,ffffff+50 */
    background: #332B28; /* Old browsers */
    background: -moz-linear-gradient(left, #332B28 50%, #ffffff 50%); /* FF3.6+ */
    background: -webkit-gradient(linear, left top, right top, color-stop(50%,#332B28), color-stop(50%,#ffffff)); /* Chrome,Safari4+ */
    background: -webkit-linear-gradient(left, #332B28 50%,#ffffff 50%); /* Chrome10+,Safari5.1+ */
    background: -o-linear-gradient(left, #332B28 50%,#ffffff 50%); /* Opera 11.10+ */
    background: -ms-linear-gradient(left, #332B28 50%,#ffffff 50%); /* IE10+ */
    background: linear-gradient(to right, #332B28 50%,#ffffff 50%); /* W3C */
    filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#332B28', endColorstr='#ffffff',GradientType=1 ); /* IE6-9 */

    min-height: 100%;
    height: 100%;
    font-weight: normal;

    font-smooth: always;
    font-smoothing: antialiased;
    -moz-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    -webkit-font-smoothing: subpixel-antialiased;
    text-shadow: 1px 1px 1px rgba(0,0,0,0.004);
}
html
{
    /* permanent scrollbar, avoid "jumping" page width at ajax page change */
    overflow-y:scroll;
}

@media (max-width:767px)
{
    html, body
    {
        background-color: #fff;
        background-image: none;
        filter: none;
        max-width: 100%;
        overflow-x: hidden;
    }
}

h1, h2, h3, h4, h5, h6, .h1, .h2, .h3, .h4, .h5, .h6
{
    font-weight: 400 !important;
}
h1, .h1
{
    font-size: 38px;
}
h2, .h2
{
    font-size:25px;
}

.min100
{
    min-height: 100%;
}


.bg-primary
{
    color: #fff;
    background-color: #4177B2;
}

#maincontent
{
    position: relative;
    min-height: 620px;
    background-color: #fff;
}
#loading
{
    position: fixed;
    right: 50%;
    bottom: 0;
    left: 50%;
    top: 500px;
}
@media(max-width:767px)
{
    #loading
    {
        top: 200px;
    }
}
#loading img
{
    margin: 0 auto;
    display: block;
    position: relative;
    left: -12px;
}
#content
{
    height: auto;
    opacity: 1.0;
    transition: 0.3s opacity;
    padding: 30px;
}
@media(max-width:767px)
{
    #content
    {
        padding-left: 0;
        padding-right: 0;
    }
}
.leftside
{
    background-color: #332B28;
    color: #fff;
    padding-top: 15px;
    padding-bottom: 15px;
}
@media (min-width: 768px)
{
    .leftside
    {
        position: relative;
        left: -30px;
        padding-top: 30px;
    }
}
.rightside
{
    background-color: #ffffff;
}

.leftside .align-helper
{
    width: 400px;
    position: relative;
    max-width: 100%;
    background-color: #fff;
    border-radius: 200px;
}
@media(max-width: 767px)
{
    .leftside .align-helper
    {
        width: 100px;
    }
}
.leftside .align-helper .headerlink
{
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    position: relative;
    display: block;
}
.leftside .align-helper .headerlink h1
{
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: 0;
    padding: 0;
}
.leftside .align-helper .headerlink h1:before
{
    display: inline-block;
    content: " ";
    width: 0;
    height: 100%;
    vertical-align: middle;
}
.leftside .align-helper .headerlink h1 img
{
    display: inline-block;
    vertical-align: middle;
    width: 90%;
    padding-bottom: 5%;
}


.rightside
{
    min-height: 100vh;
}

.leftside h2.subheading
{
    font-size: 17px;
    margin-top: 30px;
    text-align: right;
    line-height: 1.8;
    padding-right: 10px;
}
@media(max-width:767px)
{
    .leftside h2.subheading
    {
        display: none;
    }
}

h2.h1
{
    text-transform: uppercase;
    border-bottom: 2px solid #4177B2;
    margin-bottom: 30px;
}
@media(max-width: 767px)
{
    h2.h1
    {
        font-size: 20px;
        line-height: 1.8;
        margin-bottom: 20px;
        margin-top: 0;
    }
}
.footer
{
    margin-bottom: 0;
    padding: 10px 30px;
}

.social-footer
{
    display: inline-block;
    margin-top: 15px;
    margin-right: 15px;
}
.like-footer
{
    position: relative;
    top: -6px;
}

@media(max-width:767px)
{
    .footer
    {
        padding-right: 0;
        padding-left: 0;
    }
    .footernav-container li
    {
        text-align: right;
    }
}
hr
{
    border-width: 2px 0 0;
    border-color: #4177b2;
}
.footer hr
{
    margin: 0;
}

a:focus
{
    outline: none;
}

.sahidden
{
    opacity: 0.0 !important;
    transition: 0.3s opacity;
}


em
{
    font-style: italic;
}



/* Navigation */
.navbar-collapse
{
    padding-left: 0;
    padding-right: 0;
    border-top: none !important;
    box-shadow: none !important;
}
.navbar-toggle
{
    float: right;
    margin: 35px 0 0 0;
}
.navbar-toggle .icon-bar
{
    background-color: #ffffff;
}
#mainnav
{
    position: relative;
    right: -23px;
    font-size: 16px;
}
@media(max-width: 767px)
{
    #mainnav
    {
        position: static;
        right: 0;
    }
}
#mainnav li a
{
    transition: 0.3s color;
}
#mainnav li a span
{
    transition: 0.3s color, 0.3s opacity;
    position: relative;
    left: 5px;
    top: 3px;
}
#mainnav li a:link,
#mainnav li a:visited
{
    text-align: right;
}

#mainnav li a:link span,
#mainnav li a:visited span
{
    opacity: 0;
    color: #999999;
}
#mainnav li a:hover,
#mainnav li a:active,
#mainnav li a:focus
{
    outline: none;
    background-color: transparent;
    color: #DDD;
}
#mainnav li a:hover span,
#mainnav li a:active span,
#mainnav li a:focus span
{
    opacity: 1.0;
    color: #DDD !important;
}
#mainnav li.active a span
{
    opacity: 1.0;
    color: #41871E;
}
@media(max-width:767px)
{
    #mainnav li a span
    {
        display: none !important;
    }
    #mainnav li.active a
    {
        color: #DDD !important;
    }
}


/* fb stuff */
.fb-comments
{
    border-top: 1px solid #EEE;
}
#fbComments
{
    min-height: 150px;
    padding-bottom: 20px;
}
.carousel-indicators
{
    bottom: -10px;
}
.carousel-indicators li
{
    background-color: #333333;
    border: none;
}
.carousel-indicators li.active
{
    background-color: #41871E;
}

a.fb-box:link,
a.fb-box:visited
{
    color: #333;
}
a.fb-box:hover,
a.fb-box:active,
a.fb-box:focus
{
    outline: none;
    text-decoration: none;
}
.fb-box h4
{
    line-height: 1.5;
}
.fb-box img
{
    border: 5px solid #4177B2;
}
.fb-likes
{
    color: #999999;
    text-align: right;
    font-size: 16px;
}
.fb-likes.colored
{
    color: #E7C400;
}
.fb-comment
{
    font-style: italic;
    font-size: 16px;
    padding-left: 30px;
}
.fb-comment:before
{
    content:"„";
}
.fb-comment:after
{
    content:"“";
}
.fb-namedate small
{
    color: #777;
    display: inline-block;
    padding-left: 5px;
}

/* googlemap */

#googlemap
{
    width: 100%;
    height: 500px;
    margin-top: 30px;
    opacity: 1.0;
    transition: 0.3s opacity;
    transition-delay: 0.5s;
}
.needgooglemap
{
    opacity: 0.0 !important;
}

/* impressionen */
.carousel-thumbnails
{
    position: static;
    margin: 0;
    width: 100%;
}
.carousel-thumbnails li
{
    height: auto !important;
    border: none;
    margin: 0;
    width: 20% !important;
    border-radius: 0 !important;
    background-color: transparent !important;
}

.carousel-thumbnails .thumbnail
{
    opacity: 0.5;
    transition: 0.3s opacity;
}
.carousel-thumbnails li.active .thumbnail
{
    opacity: 1.0 !important;
}

#impressionenCarousel h4
{
    margin: 15px 0 30px 0;
}

/* speisen */
.meal-date
{
    font-size: 14px;
    color: #4177B2;
    font-weight: bold;
    margin: 0;
}
.meal-price-container
{
    text-align: right;
}
.meal-price
{
    background-color: #EEEEEE;
    width: 60px;
    height: 60px;
    line-height: 60px;
    border-radius: 30px;
    display: inline-block;
    text-align: center;
}
.today .meal-price
{
    background-color: #41871E;
    color: #fff;
}
.highlight
{
    margin: 0 -15px;
    padding: 10px 15px;
    border-radius: 2px;
}
.highlight.today
{
    background-color: rgba(65, 135, 30, 0.1);
}

.top-buttons
{
    text-align: right;
    height: 0;
    overflow: visible;
}
.top-buttons a
{
    color: #fff;
    background-color: #42881F;
    width: 30px;
    height: 30px;
    line-height: 30px;
    display: inline-block;
    margin-left: 15px;
    text-align: center;
    font-size: 12px;
    border-radius: 15px;
    position: relative;
    bottom: -15px;
}

/**
 * Kontakt
 */

textarea.form-control
{
    resize: vertical;
    width: 100%;
    min-width: 100%;
    max-width: 100%;
    height: 300px;
}
.btn
{
    background-image: none;
    filter: none;
}
.form-control:focus
{
    transition: 0.3s border-color;
    box-shadow: none;
    border-color: #4177B2;
}

input[type=file]
{
    padding: 0;
    height: 38px;
    width: 100%;
}
form .adminbox
{
    padding: 0;
}
form .adminbox .form-control
{
    height: 50px;
}

/**
 * Adminseite
 */

.adminbox
{
    background-color: #EEE;
    text-align: center;
    padding: 15px;
}

/**
 * Image classes
 */

img.fadeIn
{
    opacity: 0.0;
    transition: 1.0s opacity;
}
img.fadedIn
{
    opacity: 1.0 !important;
}

/**
 * Helper classes
 */
.margin-sm
{
    margin: 5px;
}
.margin-x-sm
{
    margin: 0 5px;
}
.margin-y-sm
{
    margin: 5px 0;
}
.margin-md
{
    margin: 20px;
}
.margin-x-md
{
    margin: 0 20px;
}
.margin-y-md
{
    margin: 20px 0;
}


/*
    Colorbox Core Style:
    The following CSS is consistent between example themes and should not be altered.
*/
#colorbox, #cboxOverlay, #cboxWrapper{position:absolute; top:0; left:0; z-index:9999; overflow:hidden;}
#cboxWrapper {max-width:none;}
#cboxOverlay{position:fixed; width:100%; height:100%;}
#cboxMiddleLeft, #cboxBottomLeft{clear:left;}
#cboxContent{position:relative;}
#cboxLoadedContent{overflow:auto; -webkit-overflow-scrolling: touch;}
#cboxTitle{margin:0;}
#cboxLoadingOverlay, #cboxLoadingGraphic{position:absolute; top:0; left:0; width:100%; height:100%;}
#cboxPrevious, #cboxNext, #cboxClose, #cboxSlideshow{cursor:pointer;}
.cboxPhoto{float:left; margin:auto; border:0; display:block; max-width:none; -ms-interpolation-mode:bicubic;}
.cboxIframe{width:100%; height:100%; display:block; border:0; padding:0; margin:0;}
#colorbox, #cboxContent, #cboxLoadedContent{box-sizing:content-box; -moz-box-sizing:content-box; -webkit-box-sizing:content-box;}

/* 
    User Style:
    Change the following styles to modify the appearance of Colorbox.  They are
    ordered & tabbed in a way that represents the nesting of the generated HTML.
*/
#cboxOverlay{background:#000; opacity: 0.8; filter: alpha(opacity = 80);}
#colorbox{outline:0;}
    #cboxContent{margin-top:32px; overflow:visible; background:#000;}
        .cboxIframe{background:#222;}
        #cboxError{padding:50px; border:1px solid #ccc;}
        #cboxLoadedContent{background:#000; padding:1px;}
        #cboxLoadingGraphic{background:url(../images/ajax-loader.gif) no-repeat center center;}
        #cboxLoadingOverlay{background:#222;}
        #cboxTitle{position:absolute; top:-22px; left:0; color:#00BBFF; font-size: 18px;}
        #cboxCurrent{position:absolute; top:-22px; right:205px; text-indent:-9999px;}

        /* these elements are buttons, and may need to have additional styles reset to avoid unwanted base styles */
        #cboxPrevious, #cboxNext, #cboxSlideshow, #cboxClose {
            border: 2px solid #00bbff;
            padding:2px 3px;
            margin:0;
            margin-left: 20px;
            overflow:visible;
            text-indent:-9999px;
            width:30px;
            height:30px;
            position:absolute;
            top:-20px;
            background:url(../images/controls.png) no-repeat 0 0;
            background-origin: content-box;
            
            background-color: #222;
            border-radius: 40px;
            }
            
        
        /* avoid outlines on :active (mouseclick), but preserve outlines on :focus (tabbed navigating) */
        #cboxPrevious:active, #cboxNext:active, #cboxSlideshow:active, #cboxClose:active {outline:0;}

        #cboxPrevious{background-position:0px 0px; right:84px;}
        #cboxPrevious:hover{background-position:0px -25px;}
        #cboxNext{background-position:-25px 0px; right:42px;}
        #cboxNext:hover{background-position:-25px -25px;}
        #cboxClose{background-position:-50px 0px; right:0;}
        #cboxClose:hover{background-position:-50px -25px;}
        .cboxSlideshow_on #cboxPrevious, .cboxSlideshow_off #cboxPrevious{right:66px;}
        .cboxSlideshow_on #cboxSlideshow{background-position:-75px -25px; right:44px;}
        .cboxSlideshow_on #cboxSlideshow:hover{background-position:-100px -25px;}
        .cboxSlideshow_off #cboxSlideshow{background-position:-100px 0px; right:44px;}
        .cboxSlideshow_off #cboxSlideshow:hover{background-position:-75px -25px;}
