html { -webkit-text-size-adjust: 100%; -ms-text-size-adjust: 100%; -ms-overflow-style: scrollbar; -webkit-tap-highlight-color: transparent; -webkit-overflow-scrolling: touch; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { background: #222545; width: 100%; font-family: 'Oxygen', sans-serif; color: #151515; font-size: 100%; font-weight: 400; line-height: 1.4; }

*, *::before, *::after { box-sizing: border-box; padding: 0; margin: 0; }
a { color: #585eac; text-decoration: none; font-weight: 700; }
a:hover { color: #b00; }

img, iframe { border: none; }
*:focus { outline: none; }
select:-moz-focusring { color: transparent; text-shadow: 0 0 0 #000; }
a[href^=tel] { color: inherit; text-decoration: none; font-weight: inherit; }
input, button, select, optgroup, textarea { font-family: inherit; font-size: inherit; line-height: inherit; }

.clear { clear: both; height: 0; }
.clearfix::after, .widthFix::after { display: block; content: ""; height: 0; clear: both; visibility: hidden; }

h1, h2, h3, h4, h5, h6 { margin: 0 0 10px 0; line-height: 1.25; }
p, table { margin: 0 0 15px 0; }
h1 { font-size: 28px; font-weight: 700; color: #383d72; margin: 0 0 15px 0; }
h2 { font-size: 22px; font-weight: 400; color: #383d72; padding-top: 10px; }
h1 + h2 { color: #666; font-weight: 400; padding-top: 0; margin: -10px 0 15px 0; }
h3, h4 { font-size: 18px; font-weight: 700; color: #383d72; padding-top: 10px; margin: 0 0 10px 0; }
h3 { border-bottom: 1px solid #ccc; clear: both; }
h2:first-child, h3:first-child, h4:first-child { padding-top: 0; }

#header, #hotline, #emotion, #main, #footer { width: 100%; position: relative; overflow: hidden; z-index: 1; }
.widthFix { max-width: 1440px; position: relative; margin: 0 auto; }
#logo a, #logo img, #emotion img, .box img, .blog img, .navItem img, .gallery img { display: block; width: 100%; height: auto; }
ul.nav { list-style-type: none; }
ul.nav a { font-weight: 400; text-decoration: none; }
#signet, #stickyFix { display: none; }

#header { background: #383d72; z-index: 100; border-bottom: 4px solid #222545; }
	#hotline { background: #222545; width: 100%; padding-right: 15px; font-size: 16px; line-height: 38px; color: #fff; text-align: right; }
		#hotline * { display: inline-block; vertical-align: middle; }
		#hotline span { color: #afb3d7; margin-right: 12px; display: none; }
		#hotline i { line-height: 38px; margin-right: 6px; }
		#hotline a { font-weight: 700; }
	#logo { width: 230px; padding: 15px; position: relative; margin: 0 auto; z-index: 100; }

#emotion .imageContainer { width: 100%; max-height: 800px; position: relative; overflow: hidden; }

#emotion { background: #f6f6f6; }
#main { display: block; /* IE11 kennt kein <main> */ background: #f6f6f6; }
#main .widthFix { padding: 20px 15px; }
#main section { padding-bottom: 15px; }
#main section:last-child { padding-bottom: 0; }

#footer { background: #383d72; font-size: 16px; color: #d6dafc; padding: 20px 0 5px 0; border-top: 1px solid #ededed; }
	#footer a, #ending a { color: #d6dafc; font-weight: 400; text-decoration: none; }
		#footer a:hover { color: #fff; }	
	/* FOOTER ÜBERSCHRIFTEN */
	#footer .column { width: 100%; vertical-align: top; padding: 0 15px 15px 15px; }
		#footer .colHead { margin-bottom: 15px; border-bottom: 1px dotted #fff; }
			#footer .colHead h3 { display: inline-block; text-transform: uppercase; color: #fff; font-size: 19px; line-height: 26px; font-weight: 400; padding: 0; margin: 0 0 -1px 0; border-bottom: 2px solid #fff; }
	/* FOOTER ANSCHRIFT */
	#footer .identity .address, #footer .identity .contact { display: inline-block; }
	#footer .identity .address { margin-right: 30px; }
	/* FOOTER NAVIGATION */
	#footer .nav a { display: block; font-size: 16px; line-height: 40px; padding-left: 10px; position: relative; border-bottom: 1px solid rgba(255,255,255,.2); }
		#footer .nav li:last-child a { border-bottom: none; }
		#footer .nav a::before { content: '\f105'; font-size: 16px; line-height: 39px; position: absolute; top: 0; right: 10px; }
			#footer .nav li.active a, #footer .nav li.active a::before { color: #fff; }
	#footer .nav a::after { content: ''; width: 0; height: 100%; position: absolute; top: 0; left: 0; z-index: -2; background: linear-gradient(to right, rgba(0,0,0,.4) 0%,rgba(0,0,0,0) 100%); }
	#footer .nav a:hover::after, #footer .nav li.active a::after { width: 100%; }

/* FOOTER ENDING */
#ending { background: #222545; font-size: 14px; color: #d6dafc; padding: 15px; text-align: center; }
	#ending * { display: block; line-height: 1.3; }
	#ending span a { color: #d6dafc; }
	#ending a { color: rgba(255,255,255,.5); padding-top: 5px; }
	#ending a:hover { color: #fff; }

/* EFFEKTE */
.fast, #header::before, #footer a, #footer a::after, #ending a { transition: all .4s ease-out; }
.slow, .btn, .btn::after, .navItem::before, .navItem img { transition: all .6s ease-out; }
.fixed #signet { transition: all .4s ease-out .8s; }
#logo { transition: all .2s ease-out; }

/* SUBNAV ÜBERSICHT */
#main .navItem { display: block; width: 100%; max-width: 480px; margin: 0 auto 20px auto; position: relative; overflow: hidden; border-radius: 8px; }
	#main .navItem::before { content: ''; width: 100%; height: 100%; position: absolute; top: 0; left: 0; z-index: 5; 

background: linear-gradient(8deg, rgba(0,0,0,1) 0%,rgba(0,0,0,.7) 25%,rgba(0,0,0,0) 40%,rgba(0,0,0,0) 100%);

		 }
	#main .navItem:hover img { transform: scale(1.05); }
		#main .navItem .boxHead { width: auto; padding: 5px 15px 5px 10px; position: absolute; top: 20px; right: 0; z-index: 10; background: #b00; font-size: 16px; font-weight: 700; color: #fff; border-radius: 6px 0 0 6px; opacity: .9; }
			#main .navItem .boxHead span { font-size: .82em; font-weight: 400; }
		#main .navItem .boxBody { width: 100%; padding: 15px; position: absolute; bottom: 0; left: 0; z-index: 10; }
	 		#main .navItem .boxBody h3 { font-size: 32px; font-size: 9vw; font-weight: 700; line-height: 1.25; color: #fff; border: none; margin: 0 0 4px 0; padding: 0; text-shadow: 0 0 7px rgba(0,0,0,.8); }
			#main .navItem .boxBody p { font-size: 16px; font-weight: 400; color: #fff; margin: 0; text-shadow: 0 0 4px rgba(0,0,0,.8); }
				
/* SEPARATOR */
#main .separator { width: 100%; padding: 10px 0; margin-bottom: 30px; position: relative; text-align: center; clear: both; }
	#main .separator h2 { font-size: 24px; margin: 0; padding: 0; }
		#main .separator::before, #main .separator::after { content:''; background: #dfdfe4; width: 35%; height: 2px; position: absolute; top: 85%; left: 15%; }
		#main .separator::after { left: auto; right: 15%; }
	#main .separator.signet i { display: block; width: 50px; height: 50px; margin: 0 auto; background-image: url(/gfx/logo-ultramar-separator.svg); background-position: center center; background-repeat: no-repeat; background-size: 100% 100%; opacity: .25; }
		#main .separator.signet::before, #main .separator.signet::after { width: calc(40% - 50px); top: 50%; left: 10%; }
		#main .separator.signet::after { left: auto; right: 10%; }


/* Landscape phone to portrait tablet 
---------------------------- */

@media screen and (min-width: 480px) {

h1 { font-size: 30px; }
h2 { font-size: 23px; }

#hotline { padding-right: 20px; }
	#hotline span { display: inline-block; }
#logo { width: 260px; padding: 15px 20px; }

#main .widthFix { padding: 25px 20px; }

#footer .column { padding: 0 20px 15px 20px; }
	#footer .identity .address { padding-left: 86px; position: relative; }
	#footer .identity .address::before { content: ''; background-image: url(/gfx/logo-ultramar-signet.svg); background-repeat: no-repeat; background-size: 100% 100%; width: 66px; height: 66px; position: absolute; top: 2px; left: 0; opacity: .6; }

/* SUBNAV ÜBERSICHT */
#main .navItem { margin-bottom: 25px; }
	#main .navItem .boxBody h3 { font-size: 42px; }

}

/* logo height fix
---------------------------- */

@media screen and (min-width: 600px) {

#footer { padding: 25px 0 0 0; }

#footer .column { padding: 0 20px 10px 20px; }
	#footer .identity .address { padding-left: 0; }
	#footer .identity .address::before { display: none; }
#footer .identity, #footer .legal { width: 50%; display: inline-block; }

/* SEPARATOR */
#main .separator::before, #main .separator::after { width: calc(40% - 100px); top: 50%; left: 10%; }
#main .separator::after { left: auto; right: 10%; }
#main .separator.long::before, #main .separator.long::after { width: calc(40% - 150px); }

}

/* Portrait tablet to landscape and desktop
------------------------------------- */

@media screen and (min-width: 768px) {

h1 { font-size: 34px; }
h2 { font-size: 24px; }

#logo { width: 280px; margin: 0; }
#hotline { background: transparent; padding: 5px 30px 0 30px; position: absolute; top: 0; right: 0; }

#main .widthFix { padding: 30px 20px; }
#main section { padding-bottom: 25px; }

#footer .identity { width: 50%; }
#footer .legal { width: 35%; float: right; }
#footer .legal .colHead { display: none; }

/* SUBNAV ÜBERSICHT */
#subNav { display: flex; flex-wrap: wrap; justify-content: center; margin: 0 -10px; }
#main .navItem { width: calc(50% - 20px); max-width: none; margin: 0 10px 20px 10px; }
#main .navItem .boxBody h3 { font-size: 34px; font-size: 4.2vw; }

/* SEPARATOR */
#main .separator { padding: 0; margin-bottom: 40px; }
	#main .separator h2 { font-size: 28px; }
		#main .separator::before, #main .separator::after { width: calc(40% - 120px); }
	#main .separator.signet i { width: 60px; height: 60px; }
		#main .separator.signet::before, #main .separator.signet::after { width: calc(40% - 70px); }
		#main .separator.long::before, #main .separator.long::after { width: calc(40% - 180px); }

}


/* desktop small
------------------------------------------- */

@media screen and (min-width: 992px) {

body { font-size: 17px; }
h2, h3, h4 { padding-top: 12px; }
h1 { font-size: 36px; margin: 0 0 20px 0; }
h2 { font-size: 25px; }
h3, h4 { font-size: 19px; }
h1 + h2 { margin: -18px 0 17px 0; }

#content .anchor { height: 50px; margin-top: -50px; visibility: hidden; }
#header { position: absolute; top: 0; left: 0; overflow: visible; }

#logo { width: 328px; padding: 20px 30px; }
#hotline { padding: 5px 30px 0 30px; position: fixed; top: 0; right: 0; }

#signet { display: block; background-image: url(/gfx/logo-ultramar.svg); background-repeat: no-repeat; background-size: 100% 100%; width: 137px; height: 24px; position: absolute; top: 77px; left: 30px; opacity: 0; transition: none; }
	#signet a { display: block; width: 100%; height: 100%; }
#stickyFix { display: block; width: 1px; height: 1px; position: absolute; top: 64px; left: 0; }

.fixed #header { position: fixed; top: -64px; }
	.fixed #logo { opacity: 0; pointer-events: none; }
	.fixed #signet { opacity: 1; }

#emotion { padding-top: 118px; }

#main .widthFix { padding: 40px 30px; }
#main section { padding-bottom: 35px; }

#footer, #footer .nav a { font-size: 17px; }
	#footer .column { padding: 0 30px 20px 30px; }

/* SUBNAV ÜBERSICHT */
#subNav { margin: 0 -15px; }
#main .navItem { width: calc(50% - 30px); max-width: none; margin: 0 15px 30px 15px; }
	#main .navItem .boxHead { padding: 6px 20px 6px 12px; top: 30px; font-size: 20px; }
		#main .navItem .boxHead span { font-size: .82em; }
	#main .navItem .boxBody { padding: 20px; }
		#main .navItem .boxBody h3 { font-size: 40px; font-size: 3.9vw; }
		#main .navItem .boxBody p { font-size: 18px; }

/* SEPARATOR */
#main .separator { margin-bottom: 50px; }

}
	
/* desktop 
------------------------------------------- */

@media screen and (min-width: 1200px) {

body { font-size: 18px; }
h2, h3, h4 { padding-top: 15px; }
h1 { font-size: 40px; margin: 0 0 25px 0; }
h2 { font-size: 28px; }
h3, h4 { font-size: 20px; }
h1 + h2 { margin: -22px 0 20px 0; }

#hotline { padding: 8px 40px 0 40px; font-size: 18px; }
#logo { width: 376px; padding: 20px 40px; }

#signet { top: 82px; left: 40px; }
#stickyFix { top: 64px; }

.fixed #header { top: -64px; }

#emotion { padding-top: 126px; }

#main .widthFix { padding: 60px 40px; }
#main section { padding-bottom: 55px; }

#footer { font-size: 18px; padding: 30px 0 10px 0; }
#footer .column { padding: 0 40px 20px 40px; }
#footer .identity { width: 48%; }
	#footer .identity .address { padding-left: 94px; }
		#footer .identity .address::before { display: block; width: 74px; height: 74px; }
#footer .footerNav, #footer .legal { width: 26%; }
	#footer .colHead h3 { font-size: 20px; }
#footer .nav a { font-size: 18px; line-height: 44px; }
	#footer .nav a::before { font-size: 18px; line-height: 44px; }


/* SUBNAV ÜBERSICHT */
#subNav { margin: 0 -20px; }
#main .navItem { width: calc(50% - 40px); margin: 0 20px 40px 20px; }
	#main .navItem .boxHead { padding: 6px 20px 6px 12px; top: 40px; font-size: 24px; }
	#main .navItem .boxBody h3 { font-size: 48px; }
	#main .navItem .boxBody p { font-size: 20px; }

/* SEPARATOR */
#main .separator { margin-bottom: 70px; }
	#main .separator h2 { font-size: 32px; }
		#main .separator::before, #main .separator::after { width: calc(40% - 140px); }
	#main .separator.signet i { width: 70px; height: 70px; }
		#main .separator.signet::before, #main .separator.signet::after { width: calc(40% - 80px); }
		#main .separator.long::before, #main .separator.long::after { width: calc(40% - 210px); }

}

/* MainNav Gradient Fix
------------------------------------------- */

@media screen and (min-width: 1320px) {
body { font-size: 19px; }
#emotion .banner { bottom: 80px; }
#footer .identity { max-width: 634px; margin-right: calc(48% - 634px); }

}

@font-face {
  font-family: 'Oxygen';
  font-style: normal;
  font-weight: 700;
  src: local('Oxygen Bold'), local('Oxygen-Bold'),
       url('../font/oxygen-v9-latin-700.woff2') format('woff2'),
       url('../font/oxygen-v9-latin-700.woff') format('woff');
}
@font-face {
  font-family: 'Oxygen';
  font-style: normal;
  font-weight: 400;
  src: local('Oxygen Regular'), local('Oxygen-Regular'),
       url('../font/oxygen-v9-latin-regular.woff2') format('woff2'),
       url('../font/oxygen-v9-latin-regular.woff') format('woff');
}
@font-face {
  font-family: 'fontello';
  src: url('../font/fontello.eot?43598175');
  src: url('../font/fontello.eot?43598175#iefix') format('embedded-opentype'),
       url('../font/fontello.woff2?43598175') format('woff2'),
       url('../font/fontello.woff?43598175') format('woff'),
       url('../font/fontello.ttf?43598175') format('truetype'),
       url('../font/fontello.svg?43598175#fontello') format('svg');
  font-weight: normal;
  font-style: normal;
}
 
[class^="icon-"]::before, [class*="icon"]::before, #menu span.more::before, #footer .nav a::before, .alert::before, .sitemap a::before, .expand h2.head::after, .expand ul li::before { font-family: "fontello"; font-style: normal; font-weight: normal; font-variant: normal; text-transform: none; speak: none; display: inline-block; text-decoration: inherit; text-align: center; }
 
.icon-clock:before { content: '\e800'; }
.icon-phone:before { content: '\e808'; }
.icon-location:before { content: '\e809'; }
.icon-attention:before { content: '\e80a'; }
.icon-chat:before { content: '\f0e6'; }
.icon-lightbulb:before { content: '\f0eb'; }
.icon-plus-squared:before { content: '\f0fe'; }
.icon-angle-left:before { content: '\f104'; }
.icon-angle-right:before { content: '\f105'; }
.icon-angle-up:before { content: '\f106'; }
.icon-angle-down:before { content: '\f107'; }
.icon-minus-squared:before { content: '\f146'; }
