/*
	Theme Name: qvest-hotel.com 1.1
	Version: 1.1
	
	Farben:
	black
	white
*/





/* ! 1. IMPORTS */

@font-face {
    font-family: 'HelveticaProRoman';
    src: url('_assets/fonts/HelveticaProRoman/font.woff') format('woff'),
         url('_assets/fonts/HelveticaProRoman/font.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'HelveticaProLight';
    src: url('_assets/fonts/HelveticaProLight/font.woff') format('woff'),
         url('_assets/fonts/HelveticaProLight/font.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}

@font-face {
    font-family: 'HelveticaProBold';
    src: url('_assets/fonts/HelveticaProBold/font.woff') format('woff'),
         url('_assets/fonts/HelveticaProBold/font.woff2') format('woff2');
    font-weight: normal;
    font-style: normal;
}
 





/* ! 1. RESET (v2.5.3) */

html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre, abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, figcaption, figure, footer, header, hgroup, menu, main, nav, section, summary, time, mark, audio, video {
	font-size: 100%;
	font: inherit;
	padding: 0;
	margin: 0;
	list-style: none;
	vertical-align: baseline }

main { display: block }

a, a:hover,
.button,
.button__menu,
nav#highlights li.anfragen {
	-moz-transition: all 0.3s linear;
	-o-transition: all 0.3s linear;
	-ms-transition: all 0.3s linear;
	-webkit-transition: all 0.3s linear;
	transition: all .3s linear }



img, embed, object, .wp-caption {
	max-width: 100% !important;
	height: auto }

audio { width: 100% }

iframe { max-width: 100% }

button, input, select, textarea { margin: 0 }

::-moz-selection { background: #ffff91 }
::selection { background: #ffff91 }

* { overflow: visible }





/* ! 2. ADJUSTMENTS ➜ hacks */

html { scroll-behavior: smooth }

img {
	display: block;
	border: 1px solid # }

a img { border: none }





/* ! 2. ADJUSTMENTS ➜ text sizes */

body,
#toc nav li {
	font-size: 18px;
	line-height: 1.5em }

figcaption,
.note {
	font-size: .7em;
	line-height: 1.5em }

.suggestion {
	font-size: .85em;
	line-height: 1.5em }

.button {
	font-size: .95em;
	line-height: 1em }

#block--header nav,
#toc .close_toc,
#toc nav,
#book_now {
	font-size: 1.3em;
	line-height: 1em }

#toc nav {
	font-size: 1.6em;
	line-height: 1em }

#block--footer {
	font-size: .75em;
	line-height: 1.5em }

h2,
.liste_mit_bild h1 {
	font-size: 1.66em;
	line-height: 1.5em }

h1,
.big,
.intro {
	font-size: 2em;
	line-height: 1.5em }


@media
(max-width: 1500px) {
	body {
		font-size: 16px;
		line-height: 1.5em }
	
	#block--header nav { font-size: 1.2em }
}/**/


@media
(max-width: 1000px) {
	body {
		font-size: 14px;
		line-height: 1.5em }
	
	#block--header nav { font-size: 1.2em }
}/**/





/* ! 3. ADJUSTMENTS ➜ text styling */

body {
	font-family: 'HelveticaProRoman', Helvetica, sans-serif;
 }

em,
i { font-style: italic }

strong, b { font-family: 'HelveticaProBold' }

#block--header { font-family: 'HelveticaProLight' }

nav#highlights { font-weight: lighter !important }





/* ! 4. LAYOUT */

body { margin: 0 1.5rem }

#block--main { text-align: left }

#block--header > div,
#block--main,
#block--footer {
	margin: auto;
	max-width: 2000px }


/* vertical */

#block--main { padding-top: 6em }

#block--footer {
	margin-top: 3.5rem;
	margin-bottom: 6rem }


@media
(max-width: 1000px) {
	body { margin: 0 1rem }
}/**/





/* ! ELEMENT ➜ img */

img {  }






/* ! ELEMENT ➜ a (links) */

a,
a:active,
a:visited,
a:hover {
	display: inline-block;
	text-decoration: underline;
	color: inherit }

a:hover {  }

a[href^="tel:"] {
	color: inherit }

h1 a:hover { color: inherit }





/* ! ELEMENT ➜ buttons */

.button,
.button:visited {
	line-height: 1em;
	text-decoration: none;
	padding: .6em .8em .6em;
	margin: .1em .2em .1em 0;
	border: 1px solid black;
	border-radius: .6em;
	color: black;
	background: white }

.button:hover {
	text-decoration: none;
	color: white;
	background: black }



.button.dunkel,
.button.dunkel:visited {
	color: white;
	background: black }

.button.dunkel:hover {
	color: black;
	background: white }





/* ! BLOCK ➜ body */

body {
	overflow-x: hidden;
	overflow-y: scroll;
	color: black;
	background: white }





/* ! BLOCK ➜ block--header */

#block--header {
	position: fixed;
	width: calc(100% - 5em);
	top: 0;
	left: 0;
	padding: .5em 2.5em 2em 2.5em;
	padding: 1.9em 2.5em 1.2em 2.5em;
	text-align: center;
	background: white;
	background: rgba(255, 255, 255, 0.95) }

#block--header a { text-decoration: none }

#block--header a:hover { border-bottom: 1px solid black }

#block--header nav { text-transform: uppercase }
	
#block--header nav a + a { margin-left: 2em }

#block--header nav.mobile { display: none }

#block--header #burger {
	font-size: .8em;
	width: 100px }

#block--header #burger svg { margin-top: .5em; cursor: pointer }

/* active */ .page-info #block--header a#info  { background: #ccc }


@media
(max-width: 1300px) {
	#block--header .highlights #gallery { display: none }
}/**/

@media
(max-width: 1100px) {
	#block--header .highlights #book { display: none }
}/**/


@media
(max-width: 1000px) {
	#block--header {
		width: calc(100% - 2em);
		padding: 1.5em 1em 1.2em 1em }
	
	#block--header nav.desktop { display: none }
	#block--header nav.mobile { display: block }
}/**/


@media
(max-width: 700px) {
	#block--header #burger { width: 24px }
	
	#block--header nav a + a { margin-left: 1em }
}/**/


@media
(max-width: 500px) {
	#block--header #apartments { display: none }
}/**/





/* ! BLOCK ➜ toc */

#toc {
	position: fixed;
	top: 0;
	left: -100vw;
	z-index: 2;
	opacity: 0;
	width: 100vw;
	height: 100vh;
	overflow: auto;
	min-height: 100vh;
	text-align: center;
	-moz-transition: opacity 0.15s linear;
	-o-transition: opacity 0.15s linear;
	-ms-transition: opacity 0.15s linear;
	-webkit-transition: opacity 0.15s linear;
	transition: opacity .15s linear;
	background: white;
	background: rgba(255, 255, 255, 0.95) }

#toc nav {
	display: inline-block;
	width: auto;
	margin: auto;
	text-align: left }

#toc nav a { text-decoration: none }

#toc .close_toc {
	position: fixed;
	top: 0;
	left: -100vw;
	opacity: 0;
	width: 100vw;
	padding-top: .9em;
	padding-bottom: .9em;
	text-align: center;
	background: white;
	border-bottom: 1px solid black;
	cursor: pointer }

#toc nav .logo {
	width: 100%;
	text-align: center;
	margin-top: 120px;
	margin-bottom: 30px }

#toc nav .logo img { width: 250px }

#toc nav a,
#toc nav span { padding: 0 5px }

#toc .quicklinks {
	padding-top: 50px;
	padding-bottom: 50px }

#toc nav .cl { padding-top: 40px }

#toc nav ul { padding-top: 30px }

#toc nav li + li {
	padding-top: 6px;
	margin-top: 6px;
	border-top: 1px solid #c3c3c3 }

#toc nav > div {
	display: flex;
	justify-content: center;
	align-items: top }

#toc nav div + div { margin-left: 5vw }

#toc .quicklinks { font-size: .8em }

body.show_toc { overflow: hidden }

.show_toc #toc,
.show_toc #toc .close_toc {
	left: 0;
	opacity: 1 }


@media
(max-width: 900px) {
	#toc nav,
	#toc .quicklinks { padding: 0 1em }
	
	#toc nav .logo {
		margin-top: 80px;
		margin-bottom: 30px }
	
	#toc nav .logo img { width: 150px }

	#toc nav > div { display: block }
	
	#toc nav div + div { margin-left: 0 }
	
	#toc nav .cl {
		padding-top: 20px;
		margin-top: 20px;
		border-top: 1px solid #c3c3c3 }
	
	#toc nav ul { padding-top: 10px }
	
	#toc nav li {
		display: inline-block;
		font-size: .6em }
	
	#toc nav li + li {
		padding-top: 0;
		margin-top: 0;
		border-top: 0 }
		
	#toc nav li::after { content: " / " }
	
	#toc nav li:last-of-type::after { content: "" }
	
	#toc .quicklinks {
		margin-left: 10px;
		margin-bottom: 150px;
		text-align: left }

	#toc nav > a { padding-top: 80px }
	
	#toc .quicklinks {
		padding-top: 30px;
		font-size: 1em }
	
	#toc .quicklinks a {
		margin-bottom: .5em }
}/**/





/* ! BLOCK ➜ burger */

#burger {
	position: fixed;
	top: 1.4rem;
	right: 100px;
	z-index: 1;
	cursor: pointer }


@media
(max-width: 1000px) {
	#burger {
		top: .9rem;
		right: .8rem }
	
	#burger svg { width: 1.5em; }
}/**/





/* ! BLOCK ➜ book_now */

#book_now {
	position: fixed;
	bottom: 20px;
	right: 16px }

#book_now .button {
	color: white;
	background: #000000 }

#book_now .button:hover {
	color: black;
	background: white;
	border: 1px solid black }





/* ! BLOCK ➜ block--main */

#block--main { }





/* ! BLOCK ➜ block--footer */

#block--footer {
	display: flex;
	justify-content: center;
	align-items: top;
	flex-wrap: wrap }

#block--footer .cl.logo { margin-right: -40px }

#block--footer div + div { margin-left: 8em }

#block--footer .logo img { width: 180px }


@media
(max-width: 1000px) {
	/* #block--footer { display: block } */
	
	#block--footer { justify-content: space-between }
	
	#block--footer .cl { flex-basis: 45% }
	
	#block--footer .logo { display: none }
	
	#block--footer div + div {
		margin-top: 2em;
		margin-left: 0 }
}/**/







/* ! MODULES */

.modules {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	flex-wrap: wrap }

.full { flex-basis: 100% }
.full.txt { max-width: 1050px }
.half { flex-basis: calc(50% - 2rem) }
.third { flex-basis: calc(33% - 2rem) }

.module + .module { margin-top: 2em }

.module.txt .buttons { margin-top: 1.5em }


@media
(max-width: 1000px) {
	.modules { display: block }
}/**/







/* ! MODULE ➜ format */

.format h1 { margin-bottom: 1rem }
.format h2 { margin-bottom: 1rem }
.format * + h2 { padding-top: .5em }
.format p + *,
.format ul + *,
.format ol + * { margin-top: .75em }
.format li + li { margin-top: .25em }

.format ul,
.format ol { padding-left: 1em }

.format ul li { list-style: disc }
.format ol li { list-style: decimal }







/* ! MODULE ➜ liste_mit_bild */

.liste_mit_bild {
	display: flex;
	width: 100%;
	justify-content: justify;
	align-items: center }

.liste_mit_bild .info {
	order: 1;
	flex-basis: calc(50% - 2em) }

.liste_mit_bild figure {
	order: 2;
	flex-basis: 50% }

.liste_mit_bild .info > div {
	margin: auto;
	width: 1000px;
	max-width: 550px }


@media
(max-width: 1000px) {
	.liste_mit_bild { display: block }
	
	.liste_mit_bild .info { margin-top: 1em }
	.liste_mit_bild + .liste_mit_bild { margin-top: 4em }
}/**/


@media
(max-width: 700px) {
	.liste_mit_bild .info > div { max-width: 100% }
}/**/







/* ! MODULE ➜ img */

.img {
	position: relative;
	z-index: -1 }

.img figcaption { margin-top: .5em }

.img .note {
	position: absolute;
	top: .7em;
	right: 1em;
	color: white;
	opacity: .75 }







/* ! MODULE ➜ suggestion */

.suggestion {
	width: 100%;
	padding: 3rem;
	background: #e2e4c3 }

.suggestion h1 {
	margin-bottom: 2rem;
	text-align: center }

.suggestion > div {
	margin: auto;
	max-width: 1100px;
	display: flex;
	justify-content: space-between;
	align-items: flex-start }

.suggestion h2 { margin-bottom: .6rem }

.suggestion .button { margin-top: 1em }


@media
(max-width: 1000px) {
	.suggestion { padding: 2rem 0 3rem 0}
	
	.suggestion > div {
		display: block;
		padding: 0 2rem }
	
	.suggestion .half + .half { margin-top: 3rem }
}/**/







/* ! MODULE ➜ slider */

.flexslider {
	margin: 0 auto !important;
	background: none !important;
	border: 0 !important;
	-webkit-border-radius: none !important;
	-moz-border-radius: none !important;
	border-radius: none !important;
	-webkit-box-shadow: none !important;
	-moz-box-shadow: none !important;
	-o-box-shadow: none !important;
	box-shadow: none !important;
	overflow: visible !important }





/* ! PAGE */

.page {}





/* ! PAGE ➜ / (Startseite) */

.home .hero {
	overflow: hidden;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	width: 100vw;
	height: 93vh;
	height: calc(100vh - 7rem);
	background: black }

.home .hero video {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%) }

.home .hero .no_video {
	display: none;
	position: absolute;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat }

.home .hero .logo {
	position: absolute;
	width: 30vw;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	filter: drop-shadow(5px 5px 5px #000); }

.home #block--footer { margin-top: calc(100vh - 5rem) }

.home .hero .desktop { display: block }
.home .hero .mobile { display: none }


@media
(max-width: 600px) {
	.home .hero .desktop { display: none }
	.home .hero .mobile { display: block }

	.home .hero .logo { width: 40vw }
}/**/





/* ! PAGE ➜ /404 */

.error404 { }