@font-face {
    font-family: 'Ubuntu-Medium';
    src: url('../fonts/Ubuntu-Medium.eot');
    src: url('../fonts/Ubuntu-Medium.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Ubuntu-Medium.woff2') format('woff2'),
        url('../fonts/Ubuntu-Medium.woff') format('woff'),
		url('../fonts/Ubuntu-Medium.ttf') format('truetype'),
        url('../fonts/Ubuntu-Medium.svg#Ubuntu-Medium') format('svg');
    font-weight: 500;
    font-style: normal;
}

@font-face {
    font-family: 'Ubuntu';
    src: url('../fonts/Ubuntu.eot');
    src: url('../fonts/Ubuntu.eot?#iefix') format('embedded-opentype'),
        url('../fonts/Ubuntu.woff2') format('woff2'),
        url('../fonts/Ubuntu.woff') format('woff'),
		url('../fonts/Ubuntu.ttf') format('truetype'),
        url('../fonts/Ubuntu.svg#Ubuntu-Medium') format('svg');
    font-weight: 500;
    font-style: normal;
}

html, body { margin: 0px; padding: 0px; font-family: 'Ubuntu'; font-size: 17px; }

h1, h2, h3, h4 { color: #00B7FD; }

body.with-slider #header { border-bottom: none; }
body.with-slider #slider { margin-top: 125px; }
body.with-slider #content { margin-top: 0px; }
body.header-minimized #header { box-shadow: 0px 0px 10px #666; border-bottom: none; }
body.header-minimized #header .logo { width: 200px; }
body.header-minimized #header .inner { padding: 5px 20px; }
body.header-minimized #navigation { top: 60px; }
body.nav-active #navigation { right: 0px; }
body.nav-active #content, body.nav-active #slider, body.nav-active #footer { transform: translateX(-320px); }

.cidemos_cookie_msg { box-shadow: 0px 0px 10px #000 !important; padding: 10px; border: 1px solid #EF7F1A !important; }
.cidemos_cookie_msg .cookie_text a { color: #EF7F1A !important; }
.cidemos_cookie_msg .cookie_button button { color: #FFF !important; background: #EF7F1A !important; }

.flex-container { justify-content: space-between; }
.flex-item.w33 { width: 33%; flex: unset; }
.flex-item.w66 { width: 66%; flex: unset; }

#header .inner, #content .inner, #footer .inner { width: 100%; max-width: 1280px; margin: 0 auto; }
#content .full-width { position: relative; width: 100%; margin: 30px 0px; }
#content .full-width iframe { width: 100%; }

#whole-page { display: flex; flex-direction: column; min-height: 100vh; }
#header { position: fixed; top: 0px; left: 0px; right: 0px; z-index: 10; background: rgba(255,255,255,1); border-bottom: 1px solid #00B7FD; transition: all 0.5s; }
#header .inner { display: flex; justify-content: space-between; align-items: center; padding: 20px 20px; transition: all 0.5s; }
#header .logo { width: 350px; transition: all 0.5s; }
#header .logo img { width: 100%; }
#header .mini-nav { display: flex; justify-content: space-between; align-items: center; }
#header .mini-nav .top-link { padding: 0px 30px; }
#header .mini-nav .top-link a { color: #1B2B5C; text-decoration: none; }
#header .mini-nav .top-link a svg { color: #00B7FD; }
#header .mini-nav .hamburger-button { padding-left: 20px; }
#navigation { position: fixed; z-index: 10; top: 125px; right: -320px; bottom: 0px; width: 320px; background: #119ED6; transition: all 0.5s; }
#navigation .inner { position: absolute; top: 0px; left: 0px; bottom: 0px; right: 0px; overflow-x: hidden; overflow-y: auto; -webkit-overflow-scrolling: touch; }
#navigation ul { margin: 0px; padding: 0px; }
#navigation li { list-style-type: none; line-height: 2.8em; padding: 0px; }
#navigation li a { position: relative; text-decoration: none; cursor: pointer; display: block; color: #FFF; padding-left: 3em; padding-right: 0.5em; background-size: 10%; background-position: 0.5em center; background-repeat: no-repeat; transition: background-color 0.3s; }
#navigation li a:hover { background-color: #0b698e !important; }
#navigation li a.nav-site-6 { background-image: url(../images/icon_umzuege.png); }
#navigation li a.nav-site-7 { background-image: url(../images/icon_liftvermietung.png); }
#navigation li a.nav-site-8 { background-image: url(../images/icon_kuechenmontage.png); }
#navigation li a.nav-site-9 { background-image: url(../images/icon_handwerkerservice.png); }
#navigation li a.nav-site-10 { background-image: url(../images/icon_moebelmontage.png); }
#navigation li a.nav-site-11 { background-image: url(../images/icon_entruempelungen.png); }
#navigation li a.nav-site-12 { background-image: url(../images/icon_packservice.png); }
#navigation li a.nav-site-13 { background-image: url(../images/icon_wohnungsuebergabe.png); }
#navigation .nav_level1>li { border-bottom: 2px solid #00B7FD; }
#navigation .nav_level1>li a.has-sub.closed:after { content: '✚'; width: 3em; font-weight: bold; text-align: center; position: absolute; right: 0px; top: 0px; }
#navigation .nav_level1>li a.has-sub.opened:after { content: '✖'; width: 3em; font-weight: bold; text-align: center; position: absolute; right: 0px; top: 0px; }
#navigation .nav_level2 { max-height: 0px; overflow: hidden; transition: all 0.4s; }
#navigation .nav_level2.opened { max-height: 100px; }
#navigation .nav_level2>li { border-top: 2px solid #00B7FD; }
#navigation .nav_level2>li a { background-color: #0f8cbd; }
#slider { position: relative; width: 100%; padding-bottom: 28%; z-index: 2; text-align: center; transition: transform 0.5s; overflow: hidden; }
#slider .swiper-slide { background-position: center; background-size: cover; }
#slider .swiper-slide.home {
	font-size: 100vw;
	position: relative;
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#6ed6ff+36,00b7fd+100 */
	background: #6ed6ff; /* Old browsers */
	background: -moz-radial-gradient(center, ellipse cover, #6ed6ff 36%, #00b7fd 100%); /* FF3.6-15 */
	background: -webkit-radial-gradient(center, ellipse cover, #6ed6ff 36%,#00b7fd 100%); /* Chrome10-25,Safari5.1-6 */
	background: radial-gradient(ellipse at center, #6ed6ff 36%,#00b7fd 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#6ed6ff', endColorstr='#00b7fd',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
}
#slider .swiper-slide.home .logo { position: absolute; top: 55%; left: 20%; width: 33%; }
#slider .swiper-slide.home .logo img { width: 100%; z-index: 10; }
#slider .swiper-slide.home .slogan { position: absolute; top: 50%; left: 55%; color: #FFF; text-align: right; transform: translate(0%, -50%); }
#slider .swiper-slide.home .slogan .row-1 { font-family: 'Ubuntu-Medium'; font-size: 0.04em; line-height: 1.0em; }
#slider .swiper-slide.home .slogan .row-2 { font-family: 'Ubuntu-Medium'; font-size: 0.025em; line-height: 1.0em; }
#slider .swiper-slide.home .slogan .row-3 { font-size: 0.01em; padding-top: 10px; line-height: 1.2em; }
#slider .slide-overlay { position: absolute; width: 100%; max-width: 1280px; background-color: rgba(59, 97, 170, 0.85); bottom: -200px; left: 50%; transition: all 1s; transform: translateX(-50%); padding: 10px; }
#slider .slide-overlay h2 { margin: 0px 0px 10px 0px; color: #FFF; font-weight: normal; }
#slider .slide-overlay div { color: #FFF; font-size: 20px; }
.swiper-container-horizontal>.swiper-pagination-bullets, .swiper-pagination-custom, .swiper-pagination-fraction { bottom: 10px; z-index: 10; }
.swiper-pagination-bullet { width: 18px; height: 18px; display: inline-block; border-radius: 100%; background: #000; opacity: .3; }
.swiper-pagination-bullet-active { opacity: 1; background-color: #1B2B5C; }
#slider .swiper-slide-active .slide-overlay { bottom: 0px; }
#content { flex: 1; margin-top: 125px; color: #666; transition: transform 0.5s; }
#content .USERtext { line-height: 1.5em; }
#content .grey { background: #F5F5F5; padding: 30px 0px; }
#content .flex-item.boxed { background: #F5F5F5; }
#content li { list-style: none; }
#content li::before { content: "\2022"; color: #00B7FD; font-weight: bold; display: inline-block; width: 1em; margin-left: -1em; }
#footer { background: #434242; color: #FFFFFF; transition: transform 0.5s; }
#footer .inner { display: flex; flex-wrap: wrap; justify-content: space-between; padding: 30px 20px; align-items: center; }
#footer .col1 { width: 40%; }
#footer .col2 { width: 30%; }
#footer .col3 { width: 30%; }
#footer .logo { width: 100%; }
#footer .logo img { width: 50%; }
#footer .logo-sub b { font-weight: normal; font-family: 'Ubuntu-Medium'; }
#footer .col2 { display: flex; flex-wrap: wrap; }
#footer .nav { width: 50%; }
#footer .nav a { display: block; text-decoration: none; color: #FFF; line-height: 2em; }
#footer .col3 .title { font-family: 'Ubuntu-Medium'; text-align: right; }
#footer .col3 .icons { padding-top: 15px; text-align: right; }
#footer .col3 .icons img { width: 32px; margin-left: 22px; }
#footer .col3 .icons a { text-decoration: none; }
#footer .copyright { background: #5B5B5B; color: #C6C6C6; padding: 10px 0px; text-align: center; font-size: 14px; border-bottom: 20px solid #434242; }
#footer .copyright a { color: #C6C6C6; text-decoration: none; }
#footer .copyright span { color: #00B7FD; }

.home-icons-title { width: 100%; text-align: center; color: #00B7FD; }
.home-icons { display: flex; flex-wrap: wrap; width: 100%; max-width: 750px; margin: 0 auto 20px auto; }
.home-icons a { width: 25%; text-align: center; display: block; padding: 2% 2%; text-decoration: none; color: #666; }
.home-icons a .icon {
	width: 100px;
	padding-bottom: 100px;
	height: 0px;
	margin: 5px auto;
	border-radius: 100%;
	position: relative;
	/* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#00b7fd+12,119ed6+60 */
	background: #00b7fd; /* Old browsers */
	background: -moz-radial-gradient(center, ellipse cover, #00b7fd 12%, #119ed6 60%); /* FF3.6-15 */
	background: -webkit-radial-gradient(center, ellipse cover, #00b7fd 12%,#119ed6 60%); /* Chrome10-25,Safari5.1-6 */
	background: radial-gradient(ellipse at center, #00b7fd 12%,#119ed6 60%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00b7fd', endColorstr='#119ed6',GradientType=1 ); /* IE6-9 fallback on horizontal gradient */
}
.home-icons a .icon>div { position: absolute; top: 0px; right: 0px; bottom: 0px; left: 0px; background-size: 60%; background-position: center; background-repeat: no-repeat; }
.home-icons a .text { width: 100%; text-align: center; }

.tab-container { }
.tab-container .tabs { display: flex; justify-content: flex-start; }
.tab-container .tabs a { display: block; text-decoration: none; background: #BBB; border: 1px solid #00B7FD; color: #FFF; line-height: 40px; padding: 0px 10px; margin: 0px 10px; }
.tab-container .tabs a.active { border-bottom: 1px solid #FFF; background: #FFF; color: #00B7FD; }
.tab-container .tab-content { border-top: 1px solid #00B7FD; display: none; margin-top: -1px; }
.tab-container .tab-content.active { border-top: 1px solid #00B7FD; display: block; }

form h3 { padding: 0px 5px; margin: 5px 0px 5px 0px; width: 100%; }
form h3 img { vertical-align: middle; margin-right: 10px; }
.contact-form, .umzugsanfrage-box { display: flex; flex-wrap: wrap; padding: 10px; width: 100%; background: #F5F5F5; margin: 20px 0px; }
.contact-form>div, .umzugsanfrage-box>div { min-width: 200px; padding: 5px; }
.contact-form .label, .umzugsanfrage-box .label { color: #888; font-size: 14px; padding-bottom: 3px; }
.contact-form .input { }
form .input.captcha { display: flex; align-items: center; padding: 15px 0px 0px 30px; }
form .input.captcha>div:nth-child(2) { padding: 0px 10px; font-size: 32px; }
form .input.captcha>div:nth-child(3) input { width: 50px; font-size: 32px; text-align: center; }
.contact-form .salutation, .contact-form .input-100, .umzugsanfrage-box .salutation { flex: 1 0 100%; }
.contact-form .salutation select, .umzugsanfrage-box .salutation select { width: 40%; min-width: 180px; }
form .input-100 { flex: 1 0 100%; }
form .input-50 { flex: 1 0 50%; }
form .input-100.submit { text-align: center; padding-top: 20px; }
form .input-100.submit button { max-width: 280px; }
form .checkbox-flex { display: flex; align-items: flex-start; }
form .checkbox-flex>div:first-child { padding-right: 10px; }
form .checkbox-flex>div:last-child { padding: 5px 0px 0px 0px; color: #888; font-size: 14px; }
form .checkbox-flex>div:last-child a { text-decoration: none; color: #00B7FD; }
form .checkbox-flex>div:last-child a:hover { text-decoration: underline; }

@media only screen and (max-width: 950px) {
	#header .logo { height: 82px; }
	#header .logo img { width: 70%; margin-top: 15px; }
	#header .mini-nav .top-link { text-align: center; padding: 0px 15px; font-size: 15px; }
	#footer .col1 { width: 100%; order: 3; padding-top: 20px; margin-top: 20px; border-top: 1px solid #222; }
	#footer .col2 { width: 50%; order: 1; }
	#footer .col3 { width: 50%; order: 2; }
	#footer .logo { width: 100%; text-align: center; }
	#footer .logo img { width: 200px; }
	#footer .logo-sub { text-align: center; }
}

@media only screen and (max-width: 800px) {
	#header { box-shadow: 0px 0px 10px #666; height: 60px; border-bottom: none; }
	#header .inner { padding: 5px 20px; }
	#header .logo { height: auto; width: 200px; }
	#header .logo img { width: 100%; margin-top: 0px; }
	#header .mini-nav .top-link { text-align: center; padding: 0px 15px; font-size: 13px; }
	#navigation { top: 60px; }
	#slider { padding-bottom: 50%; }
	#content { margin-top: 60px; }
	#content .flex-item.boxed { display: none; }
	body.with-slider #slider { margin-top: 60px; }
	body.with-slider #content { margin-top: 0px; }
	#slider .swiper-slide.home { font-size: 200vw; }
	#slider .swiper-slide.home .logo { position: absolute; top: 55%; left: 5%; width: 43%; }
	#slider .swiper-slide.home .slogan { top: 50%; left: auto; right: 5%; }
	.home-icons a { width: 50%; }
}

@media only screen and (max-width: 620px) {
	#header .mini-nav .top-link { display: none; }
	#content .flex-container { padding: 0px 1em; }
	.flex-item>div { padding: 0; }
	#footer .col1 { width: 100%; order: 2; }
	#footer .col2 { width: 100%; order: 1; text-align: center; }
	#footer .col3 { width: 100%; order: 3; padding-top: 20px; margin-top: 20px; border-top: 1px solid #222; }
	#footer .col3 .title { text-align: center; }
	#footer .col3 .icons { text-align: center; }
	#footer .col3 .icons img { margin: 0px 11px; }
	.contact-form>div { padding: 5px 0px; }
}
