﻿html {
    height: 100%;
    margin: 0;
    padding: 0;
}

body {
    background-color: #fff;
    color: #434343;
    font-size: .85em;
    font-family: "Segoe UI", Verdana, Helvetica, Sans-Serif;
    margin: 0;
    padding: 0;
    height: 100%;
}

a:link, a:visited,
a:active, a:hover {
    color: #333;
    outline: none;
    padding-left: 3px;
    padding-right: 3px;
    text-decoration: underline;
}

a:hover {
    background-color: #c7d1d6;
}

header{
    background-color: #FFF;
}

header, footer, hgroup
nav, section {
    display: block;
}

.float-left {
    float: left;
}

.float-right {
    float: right;
}

.highlight {
    background-color: #a6dbed;
    padding-left: 5px;
    padding-right: 5px;
}

.clear-fix:after {
    content: ".";
    clear: both;
    display: block;
    height: 0;
    visibility: hidden;
}

h1, h2, h3,
h4, h5, h6 {
    color: #000;
    margin: 0;
    padding: 0;
}

h1 {
    font-size: 2em;
}

h2 {
    font-size: 1.75em;
}

h3 {
    font-size: 1.2em;
}

h4 {
    font-size: 1.1em;
}

h5, h6 {
    font-size: 1em;
}


/* main layout
----------------------------------------------------------*/
/*@media only screen and (min-width: 650px) {*/
.outer-wrapper{
    min-height: 100%;
	background-color: darkgrey;	
}
.content-wrapper {
    margin: 0;
    padding:  10px 20px;
    /*height:  100%;*/
}

#main {
    clear: both;
    margin-top:  0;
    overflow:auto;
	padding: 30px 0px 50px;
    margin-left: 30px;
    max-width: 900px;
	margin-left: auto;
    margin-right: auto;
    background-color: #efeeef;
	text-align: center;
}
/*}*/
    .main-content {
        background: url("../Images/asterisk.png") no-repeat;
        padding-left: 10px;
        padding-top: 30px;
    }

    .featured + .main-content {
        background: url("../Images/heroAccent.png") no-repeat;
    }

	#main table{
		text-align: left;
		margin-right: auto;
		margin-left: auto;
	}
.visit{
    font-size: 18pt;
}

.visit a:link, .visit a:visited,
.visit a:active, .visit a:hover {
    color: #4A91CE;
    outline: none;
    padding-left: 3px;
    padding-right: 3px;
    text-decoration: none;
}


footer {
    background-color: #E2E2E2;
    clear: both;
    font-size: 0.8em;
    height: 50px;
    margin-top: -50px; /* negative value of footer height */
    position: relative;
    text-align: center;         
}

footer .footer-wrapper {
    margin: 0;
    padding:  3px 20px;
}

.highlighted {
    color: #f34c4c;
    font-size: 1.3em;
    margin: 0px 0;
	text-align: center;
    font-weight: bold;
}


/* site title
----------------------------------------------------------*/
.site-title {
    color: #f34c4c;
    font-family: Rockwell, Consolas, "Courier New", Courier, monospace;
    font-size: 2.3em;
    margin: 0px 0;
	text-align: center
}

.site-title a, .site-title a:hover, .site-title a:active {
    background: none;
    color: #c8c8c8;
    outline: none;
    text-decoration: none;
}

.oeffnungszeiten{
    border-collapse: collapse;
    margin: 25px 0;
    font-size: 0.9em;
    font-family: sans-serif;
    min-width: 400px;
    box-shadow: 0 0 20px rgba(0, 0, 0, 0.15);
}

.oeffnungszeiten thead tr {
    background-color: #009879;
    color: #ffffff;
    text-align: left;
}

.oeffnungszeiten th,
.oeffnungszeiten td {
    padding: 12px 15px;
}

.oeffnungszeiten tbody tr {
    border-bottom: 1px solid #dddddd;
}

.oeffnungszeiten tbody tr:nth-of-type(even) {
    background-color: #f3f3f3;
}

.oeffnungszeiten tbody tr.active-row {
    font-weight: bold;
    color: #eb2d2d;
}

/* login
----------------------------------------------------------*/
#login {
    display: block;
    font-size: .85em;
    margin: 7px 0 12px;
    text-align: right;
}

    #login a {
        background-color: #d3dce0;
        margin-left: 10px;
        margin-right: 3px;
        padding: 2px 3px;
        text-decoration: none;
    }

    #login a.username {
        background: none;
        margin-left: 0px;
        text-decoration: underline;
    }

    #login ul {
        margin: 0;
    }

    #login li {
        display: inline;
        list-style: none;
    }

@media only screen and (min-width: 800px) {
/* menu
----------------------------------------------------------*/
ul#menu {
    font-size: 16pt;
    font-weight: bold;
    margin: 0;
    padding-left: 25px;
    display: flex;
    align-items: center;
    justify-content: center;
}

    ul#menu li {
        display:block;
        float: left;
        text-align:center;
        padding-right: 28px
    }

        ul#menu li a {
            background: none;
            color: #FDFEFF;
            text-decoration: none;
        }

        ul#menu li a:hover {
            color: #66ffff;
            text-decoration: none;
        }
	.nav-trigger {
		position: absolute;
		clip: rect(0, 0, 0, 0);
	}

/* page elements
----------------------------------------------------------*/
/* welcome message */


/* Navigation */
.navigation, #menu {
    border-top: 5px solid #6D0323;
    /*background-color: #fff;*/
    
    margin: 0;
    padding:  0;
    
    display: table;
    width: 100%;
    
    background-color: #e80c4d;
    background-image: -ms-linear-gradient(left, ##e80c4d 0%, #a4d4e6 100%);
    background-image: -o-linear-gradient(left, ##e80c4d 0%, #a4d4e6 100%);
    background-image: -webkit-gradient(linear, left top, right top, color-stop(0, ##e80c4d), color-stop(1, #a4d4e6));
	background-image: -webkit-linear-gradient(left, #e80c4d 0%, #c82c1f 100%);
    background-image: linear-gradient(left, ##e80c4d 0%, #a4d4e6 100%);
    color: #3e5667;
}}

.welcomeMessage {
    padding-top: 5px;
}
/* page titles */
hgroup.title {
    margin-bottom: 10px;
}

hgroup.title h1, hgroup.title h2 {
    display: inline;
}

hgroup.title h2 {
    font-weight: normal;
    margin-left: 3px;
}

/* features */
section.feature {
    /*width: 300px;*/
    float: left;
    padding: 10px;
}

/* ordered list */
ol.round {
    list-style-type: none;
    padding-left: 0;
}

    ol.round li {
        margin: 20px 0;
        padding-left: 45px;
    }

        ol.round li.one {
            background: url("../Images/orderedListOne.png") no-repeat;
        }

        ol.round li.two {
            background: url("../Images/orderedListTwo.png") no-repeat;
        }

        ol.round li.three {
            background: url("../Images/orderedListThree.png") no-repeat;
        }

        ol.round li.asterisk {
            background: url("../Images/asterisk.png") no-repeat;
        }

/* content */
article {
    float: left;
    width: 70%;
}

aside {
    float: right;
    width: 25%;
}

    aside ul {
        list-style: none;
        padding: 0;
    }

        aside ul li {
            background: url("../Images/asterisk.png") no-repeat 0 50%;
            padding: 2px 0 2px 20px;
        }

.label {
    font-weight: 700;
}

/* login page */
#loginForm {
    border-right: solid 2px #c8c8c8;
    float: left;
    width: 45%;
    text-align: center;
}

    #loginForm .validation-error {
        display: block;
        margin-left: 15px;
    }

#socialLoginForm {
    margin-left: 40px;
    float: left;
    width: 50%;
}

/* contact */
.contact h3 {
    font-size: 1.2em;
}

.contact p {
    margin: 5px 0 0 10px;
}

.contact iframe {
    border: solid 1px #333;
    margin: 5px 0 0 10px;
}

/* forms */
fieldset {
    border: none;
    margin: 0;
    padding: 0;
}

    fieldset legend {
        display: none;
    }
    
    fieldset ol {
        padding: 0;
        list-style: none;
    }

        fieldset ol li {
            padding-bottom: 5px;
        }

    fieldset label {
        display: block;
        font-size: 1.2em;
        font-weight: 600;
    }

    fieldset label.checkbox {
        display: inline;
    }

    fieldset input[type="text"],
    fieldset input[type="password"] {
        border: 1px solid #e2e2e2;
        color: #333;
        font-size: 1.2em;
        margin: 5px 0 6px 0;
        padding: 5px;
        width: 300px;
    }

        fieldset input[type="text"]:focus,
        fieldset input[type="password"]:focus {
            border: 1px solid #7ac0da;
        }

    fieldset input[type="submit"] {
        background-color: #d3dce0;
        border: solid 1px #787878;
        cursor: pointer;
        font-size: 1.2em;
        font-weight: 600;
        padding: 7px;
    }

/* ajax login/registration dialog */
.modal-popup {
    font-size: 0.7em;
}

    .modal-popup input[type="text"],
    .modal-popup input[type="password"] {
        width: 90%;
    }

/* info and errors */
.message-info {
    border: solid 1px;
    clear: both;
    padding: 10px 20px;
}

.message-error {
    clear: both;
    color: #e80c4d;
    font-size: 1.1em;
    font-weight: bold;
    margin: 20px 0 10px 0;
}

.message-success {
    color: #7ac0da;
    font-size: 1.3em;
    font-weight: bold;
    margin: 20px 0 10px 0;
}

.success {
    color: #7ac0da;
}

.error {
    color: #e80c4d;
}

/* styles for validation helpers */
.field-validation-error {
    color: #e80c4d;
    font-weight: bold;
}

.field-validation-valid {
    display: none;
}

input[type="text"].input-validation-error,
input[type="password"].input-validation-error {
    border: solid 1px #e80c4d;
}

.validation-summary-errors {
    color: #e80c4d;
    font-weight: bold;
    font-size: 1.1em;
}

.validation-summary-valid {
    display: none;
}

ul#social li {
    display: inline;
    list-style: none;
}

    ul#social li a {
        color: #999;
        text-decoration: none;
    }

    a.facebook, a.twitter {
        display: block;
        float: left;
        height: 24px;
        padding-left: 17px;
        text-indent: -9999px;
        width: 16px;
    }

    a.facebook {
        background: url("../Images/facebook.png") no-repeat;
    }

    a.twitter {
        background: url("../Images/twitter.png") no-repeat;
    }

body { 
    background-color: #fff; 
    color: #000; 
    font-family: Arial, Verdana, sans-serif; 
}

a { 
    text-decoration: underline; 
    color: #000; 
}
#content { 
    background-position: top; 
    background-repeat: no-repeat; 
    margin: auto; width: 998px; 
    height: 380px; 
    font-weight: bold; 
    font-size: 90%; 
    line-height: 120%; 
}

#text { 
    position: relative; 
    float: left; 
    left: 0px; 
    text-align: left; 
}

#text1 { 
    position: relative; 
    left: 0px; 
    color: #C82C1F; 
    font-size: 110%; 
}

#text2 { 
    position: relative; 
	left: 0px; 
    color: #C82C1F; 
    font-size: 110%; 
}

#text3 { 
    position: relative; 
    left: 0px;
}

#text4 { 
    position: relative;
    left: 0px; 
    font-size: 80%
}

.hidden {
    display: none;
}

.notice {
    font-size: xx-large;
    font-weight: bold;
    color:red;
}

.geschenke {
	margin-top: 10px;
	text-align: center;
	list-style-type: none;
	width: 500px;
	margin-left: auto;
	margin-right: auto;
}

.geschenke ul
{
	list-style-type: none;
}

.geschenke img
{
	float: left;
}

/********************
*   Mobile Styles   *
********************/
@media only screen and (max-width: 800px) {

	body {
		overflow-x: hidden;
	}
    /* header
    ----------------------------------------------------------*/
    header .float-left,
    header .float-right {
        float: none;
    }

    /* logo */
    header .site-title {
        margin: 10px;
        text-align: center;
    }

    /* login */
    #login {
        font-size: .85em;
        margin: 0 0 12px;
        text-align: center;
    }

        #login ul {
            margin: 5px 0;
            padding: 0;
        }

        #login li {
            display: inline;
            list-style: none;
            margin: 0;
            padding: 0;
        }

        #login a {
            background: none;
            color: #999;
            font-weight: 600;
            margin: 2px;
            padding: 0;
        }

        #login a:hover {
            color: #333;
        }

    /* menu */
    .navigation, #gmenu {
		  /* critical sizing and position styles */
		  width: 100%;
		  height: 100%;
		  position: absolute;
		  top: 0;
		  right: 0;
		  /*bottom: 0;*/
		  left: 0;
		  z-index: 0;
		  /* non-critical appearance styles */
		  list-style: none;
		  background: rgb(53, 53, 53);
	}
	
	.nav-trigger {
		position: absolute;
		clip: rect(0, 0, 0, 0);
	}
	
	label[for="nav-trigger"] {
		position: fixed;
		top: 15px;
		left: 15px;
		width: 30px;
		height: 30px;
		cursor: pointer;
		background-size: contain;
		z-index: 2;
	}
	
	.nav-trigger:checked + label {
		left: 215px;
	}

	.nav-trigger:checked ~ .main {
		left: 200px;
		box-shadow: 0 0 5px 5px rgba(0,0,0,0.5);
	}
	
	.nav-trigger + label, .main {
		transition: left 0.2s;
	}

    ul#menu {
        margin: 0;
        padding: 0;
        text-align: center;
      
    }

        ul#menu li {
            margin: 0;
            padding: 0;
            padding-right: 12px
        }


    /* main layout
    ----------------------------------------------------------*/
    .main-content,
    .featured + .main-content {
        background-position: 10px 0;
    }
	
	#main {
		/* Critical position and size styles */
		min-height: 100%;
		min-width: 100%;
		background-color: white; /* Needs a background or else the nav will show through */
		position: relative;
		top: 0;
		bottom: 100%;
		left: 0;
		z-index: 1;
		text-align: center;
		background-color: #efeeef;
		
		/*clear: both;
		margin-top:  0;
		overflow:auto;
		padding: 30px 0px 50px;
		margin-left: 30px;
		margin-left: auto;
		margin-right: auto;
		
		*/
	}

    .content-wrapper {
        padding-right: 10px;
        padding-left: 10px;
		z-index: 2;
    }

    .featured .content-wrapper {
        padding: 10px;
    }

    /* page content */
    article, aside {
        float: none;
        width: 100%;
    }

    /* ordered list */
    ol.round {
        list-style-type: none;
        padding-left: 0;
    }

        ol.round li {
            padding-left: 10px;
            margin: 25px 0;
        }

            ol.round li.one,
            ol.round li.two,
            ol.round li.three, 
        ol.round li.asterisk {
                background: none;
            }

     /* features */
     section.feature {
        float: none;
        padding: 10px;
        width: auto;
     }

        section.feature img {
            color: #999;
            content: attr(alt);
            font-size: 1.5em;
            font-weight: 600;
        }

    /* forms */
    fieldset input[type="text"],
    fieldset input[type="password"] {
        width: 90%;
    }

    /* login page */
    #loginForm {
        min-height: 100%;
		min-width: 100%;
		position: relative;
		top: 0;
		bottom: 100%;
		left: 0;
		text-align: center;
		background-color: #efeeef;
    }

        #loginForm .validation-error {
            display: block;
            margin-left: 15px;
        }

    #socialLoginForm {
        margin-left: 0;
        float: none;
        width: auto;
    }

    /* footer
    ----------------------------------------------------------*/
    footer .float-left,
    footer .float-right {
        float: none;
    }

    footer {
        text-align: center;
        height: auto;
        padding: 10px 0;
    }

        footer p {
            margin: 0;
        }

        ul#social {
            padding: 0;
            margin: 0;
        }

         a.facebook, a.twitter {
            background: none;
            display: inline;
            float: none;
            height: auto;
            padding-left: 0;
            text-indent: 0;
            width: auto;
        }
}
