/*! normalize.css v3.0.3 | MIT License | github.com/necolas/normalize.css */

/* playfair-display-regular - latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: normal;
  font-weight: 400;
  src: local(''),
       url('../fonts/playfair-display-v21-latin-regular.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/playfair-display-v21-latin-regular.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* playfair-display-italic - latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 400;
  src: local(''),
       url('../fonts/playfair-display-v21-latin-italic.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/playfair-display-v21-latin-italic.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* playfair-display-600italic - latin */
@font-face {
  font-family: 'Playfair Display';
  font-style: italic;
  font-weight: 600;
  src: local(''),
       url('../fonts/playfair-display-v21-latin-600italic.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/playfair-display-v21-latin-600italic.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* source-sans-pro-300 - latin */
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 300;
  src: local('Source Sans Pro Light'), local('SourceSansPro-Light'),
       url('../fonts/source-sans-pro-v13-latin-300.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/source-sans-pro-v13-latin-300.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* source-sans-pro-regular - latin */
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 400;
  src: local('Source Sans Pro Regular'), local('SourceSansPro-Regular'),
       url('../fonts/source-sans-pro-v13-latin-regular.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/source-sans-pro-v13-latin-regular.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* source-sans-pro-700 - latin */
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 700;
  src: local('Source Sans Pro Bold'), local('SourceSansPro-Bold'),
       url('../fonts/source-sans-pro-v13-latin-700.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/source-sans-pro-v13-latin-700.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}

/* source-sans-pro-900 - latin */
@font-face {
  font-family: 'Source Sans Pro';
  font-style: normal;
  font-weight: 900;
  src: local('Source Sans Pro Black'), local('SourceSansPro-Black'),
       url('../fonts/source-sans-pro-v13-latin-900.woff2') format('woff2'), /* Chrome 26+, Opera 23+, Firefox 39+ */
       url('../fonts/source-sans-pro-v13-latin-900.woff') format('woff'); /* Chrome 6+, Firefox 3.6+, IE 9+, Safari 5.1+ */
}


*,
*:after,
*:before {
	-webkit-box-sizing: border-box;
	box-sizing: border-box;
	outline: 0;
}

/**
 * 1. Set default font family to sans-serif.
 * 2. Prevent iOS and IE text size adjust after device orientation change,
 *    without disabling user zoom.
 */

html {
	-ms-text-size-adjust: 100%; /* 2 */
	-webkit-text-size-adjust: 100%; /* 2 */
	font-size: 14px;
	line-height: 1.388;
}

@media only screen and (min-width: 768px) {
	html {
		font-size: 16px;
	}
}

@media only screen and (min-width: 992px) {
	html {
		font-size: 18px;
	}
}

/**
 * Remove default margin.
 */

body {
  margin: 0;
}

html,
body,
button,
input,
select,
textarea,
table,
td {
	font-family: 'Source Sans Pro', sans-serif;
	font-weight: 400;
	color: #293133;
}

/* HTML5 display definitions
   ========================================================================== */

/**
 * Correct `block` display not defined for any HTML5 element in IE 8/9.
 * Correct `block` display not defined for `details` or `summary` in IE 10/11
 * and Firefox.
 * Correct `block` display not defined for `main` in IE 11.
 */

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
  display: block;
}

/**
 * 1. Correct `inline-block` display not defined in IE 8/9.
 * 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
 */

audio,
canvas,
progress,
video {
  display: inline-block; /* 1 */
  vertical-align: middle; /* 2 */
}

/**
 * Prevent modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */

audio:not([controls]) {
  display: none;
  height: 0;
}

/**
 * Address `[hidden]` styling not present in IE 8/9/10.
 * Hide the `template` element in IE 8/9/10/11, Safari, and Firefox < 22.
 */

[hidden],
template {
  display: none;
}

iframe {
	width: 100%;
	border: none;
	background-color: transparent;
}

/* Links
   ========================================================================== */

/**
 * Remove the gray background color from active links in IE 10.
 */

a {
	background-color: transparent;
	color: inherit;
}

/**
 * Improve readability of focused elements when they are also in an
 * active/hover state.
 */

a:active,
a:hover {
	outline: 0;
}

/* Text-level semantics
   ========================================================================== */

/**
 * Address styling not present in IE 8/9/10/11, Safari, and Chrome.
 */

abbr[title] {
  border-bottom: 1px dotted;
}

/**
 * Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
 */

b,
strong {
  font-weight: bold;
}

/**
 * Address styling not present in Safari and Chrome.
 */

dfn {
  font-style: italic;
}

/**
 * Address variable `h1` font-size and margin within `section` and `article`
 * contexts in Firefox 4+, Safari, and Chrome.
 */

h1,
.h1 {
	font-size: 3em;
	margin: .75em 0 .25em;
	font-weight: 900;
	line-height: 1;
	font-family: 'Source Sans Pro', sans-serif;
}
h2,
.h2 {
	font-size: 2em;
	margin: .667em 0 .333em;
	font-weight: 300;
	line-height: 1;
	font-family: 'Source Sans Pro', sans-serif;
}
h3,
.h3 {
	font-size: 1.5em;
	margin: 1em 0 .5em;
	font-weight: 700;
	line-height: 1;
	font-family: 'Source Sans Pro', sans-serif;
}
h4,
.h4 {
	font-size: 1.25em;
	margin: .667em 0;
	font-weight: 400;
	line-height: 1.333;
	font-family: 'Playfair Display', Georgia, serif;
}
h5,
.h5 {
	font-size: 1.25em;
	margin: .667em 0;
	font-weight: 300;
	line-height: 1.333;
	font-family: 'Source Sans Pro', sans-serif;
}
h6,
.h6 {
	font-size: 1em;
	margin: 1em 0;
	font-weight: 900;
	font-family: 'Source Sans Pro', sans-serif;
}

h1,
.h1,
h2,
.h2,
h3,
.h3,
.hyphenation {
	-webkit-hyphens: auto;
	-moz-hyphens: auto;
	-ms-hyphens: auto;
	hyphens: auto;
}
.no-hyphenation {
	-webkit-hyphens: none;
	-moz-hyphens: none;
	-ms-hyphens: none;
	hyphens: none;
}

@media only screen and (min-width: 768px) {
	h1,
	.h1 {
		font-size: 4em;
	}
	h2,
	.h2 {
		font-size: 3em;
	}
	h3,
	.h3 {
		font-size: 2em;
	}
	h4,
	.h4 {
		font-size: 1.5em;
	}
	h5,
	.h5 {
		font-size: 1.5em;
	}
}

/**
 * Address styling not present in IE 8/9.
 */

mark {
  background: #ff0;
  color: #000;
}

/**
 * Address inconsistent and variable font size in all browsers.
 */

small {
  font-size: 80%;
}

/**
 * Prevent `sub` and `sup` affecting `line-height` in all browsers.
 */

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sup {
  top: -0.5em;
}

sub {
  bottom: -0.25em;
}

blockquote {
	font-family: 'Playfair Display', Georgia, serif;
	font-size: 1em;
	font-style: normal;
	margin: 1em 0;
	padding: .25em 1em .25em 3em;
	position: relative;
	color: #808080;
}
blockquote p:first-child {
	margin-top: 0;
}
blockquote p:last-child {
	margin-bottom: 0;
}
blockquote:before {
	display: block;
	content: "\201C";
	font-size: 5em;
	position: absolute;
	left: .05em;
	top: -.25em;
	color: #98A7AB;
}
blockquote cite {
	color: #98A7AB;
	font-size: .778em;
	display: block;
	margin-top: .5em;
}
 
blockquote cite:before {
	content: "\2014 \2009";
}

/* ==========================================================================
   Lists
   ========================================================================== */

dl,
menu,
ol,
ul {
    margin: .66667em 0;
}

dd {
    margin: 0 0 0 2em;
}

menu,
ol,
ul {
    padding: 0 0 0 2em;
}

nav ul,
nav ol {
	margin: 0;
	padding: 0;
    list-style: none;
    list-style-image: none;
}

/* Embedded content
   ========================================================================== */

/**
 * Remove border when inside `a` element in IE 8/9/10.
 */

img {
	border: 0;
	vertical-align: middle;
}

/**
 * Correct overflow not hidden in IE 9/10/11.
 */

svg:not(:root) {
  overflow: hidden;
}

/* Grouping content
   ========================================================================== */

/**
 * Address margin not present in IE 8/9 and Safari.
 */

figure {
  margin: 1em 40px;
}

/**
 * Address differences between Firefox and other browsers.
 */

hr {
	display: block;
	height: 2px;
	border: 0;
	border-top: 2px solid #e0e1e1;
	margin: 1em 0;
	padding: 0;
}

/**
 * Contain overflow in all browsers.
 */

pre {
  overflow: auto;
}

/**
 * Address odd `em`-unit font size rendering in all browsers.
 */

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em;
}

/* Forms
   ========================================================================== */

/**
 * Known limitation: by default, Chrome and Safari on OS X allow very limited
 * styling of `select`, unless a `border` property is set.
 */

/**
 * 1. Correct color not being inherited.
 *    Known issue: affects color of disabled elements.
 * 2. Correct font properties not being inherited.
 * 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
 */

button,
input,
optgroup,
select,
textarea {
	color: inherit; /* 1 */
	font: inherit; /* 2 */
	margin: 0; /* 3 */
	border: none;
	padding: 0;
	border-radius: 0;
}

/**
 * Address `overflow` set to `hidden` in IE 8/9/10/11.
 */

button {
	overflow: visible;
	border: none;
	padding: 0;
	margin: 0;
	background: none;
}

/**
 * Address inconsistent `text-transform` inheritance for `button` and `select`.
 * All other form control elements do not inherit `text-transform` values.
 * Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
 * Correct `select` style inheritance in Firefox.
 */

button,
select {
	text-transform: none;
}

/**
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Correct inability to style clickable `input` types in iOS.
 * 3. Improve usability and consistency of cursor style between image-type
 *    `input` and others.
 */

button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
	-webkit-appearance: button; /* 2 */
	cursor: pointer; /* 3 */
}

/**
 * Re-set default cursor for disabled elements.
 */

button[disabled],
html input[disabled] {
	cursor: default;
}

/**
 * Remove inner padding and border in Firefox 4+.
 */

button::-moz-focus-inner,
input::-moz-focus-inner {
	border: 0;
	padding: 0;
}

/**
 * Address Firefox 4+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */

input {
	line-height: normal;
}

/**
 * It's recommended that you don't attempt to style these elements.
 * Firefox's implementation doesn't respect box-sizing, padding, or width.
 *
 * 1. Address box sizing set to `content-box` in IE 8/9/10.
 * 2. Remove excess padding in IE 8/9/10.
 */

input[type="checkbox"],
input[type="radio"] {
	padding: 0; /* 2 */
}

/**
 * Fix the cursor style for Chrome's increment/decrement buttons. For certain
 * `font-size` values of the `input`, it causes the cursor style of the
 * decrement button to change from `default` to `text`.
 */

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
	height: auto;
}

/**
 * 1. Address `appearance` set to `searchfield` in Safari and Chrome.
 * 2. Address `box-sizing` set to `border-box` in Safari and Chrome.
 */

input[type="search"] {
	-webkit-appearance: textfield; /* 1 */
}

/**
 * Remove inner padding and search cancel button in Safari and Chrome on OS X.
 * Safari (but not Chrome) clips the cancel button when the search input has
 * padding (and `textfield` appearance).
 */

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
	-webkit-appearance: none;
}

/**
 * Define consistent border, margin, and padding.
 */

fieldset {
	border: 1px solid #c0c0c0;
	margin: 0 2px;
	padding: 0.35em 0.625em 0.75em;
}

/**
 * 1. Correct `color` not being inherited in IE 8/9/10/11.
 * 2. Remove padding so people aren't caught out if they zero out fieldsets.
 */

legend {
	border: 0; /* 1 */
	padding: 0; /* 2 */
}

/**
 * Remove default vertical scrollbar in IE 8/9/10/11.
 */

textarea {
	overflow: auto;
	resize: vertical;
}

/**
 * Don't inherit the `font-weight` (applied by a rule above).
 * NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
 */

optgroup {
	font-weight: bold;
}

/* Tables
   ========================================================================== */

/**
 * Remove most spacing between table cells.
 */

table {
	border-collapse: collapse;
	border-spacing: 0;
}

td,
th {
	padding: 0;
}

/* selection highlight
   ========================================================================== */

::-moz-selection {
    background: #b3d4fc;
    text-shadow: none;
}

::selection {
    background: #b3d4fc;
    text-shadow: none;
}

/* standard and helper classes
   ========================================================================== */

/* Image replacement */
.ir {
    background-color: transparent;
    border: 0;
    overflow: hidden;
    /* IE 6/7 fallback */
    *text-indent: -9999px;
}
.ir:before {
    content: "";
    display: block;
    width: 0;
    height: 100%;
}

/* Hide from both screenreaders and browsers: h5bp.com/u */
.hidden, .versteckt {
    display: none !important;
    visibility: hidden;
}

/* Hide only visually, but have it available for screenreaders: h5bp.com/v */
.visuallyhidden {
    border: 0;
    clip: rect(0 0 0 0);
    height: 1px;
    margin: -1px;
    overflow: hidden;
    padding: 0;
    position: absolute;
    width: 1px;
}

/* Extends the .visuallyhidden class to allow the element to be focusable, when navigated to via the keyboard: h5bp.com/p */
.visuallyhidden.focusable:active,
.visuallyhidden.focusable:focus {
    clip: auto;
    height: auto;
    margin: 0;
    overflow: visible;
    position: static;
    width: auto;
}

/* Hide visually and from screenreaders, but maintain layout */
.invisible {
    visibility: hidden;
}

/* Clearfix: contain floats */
.clearfix:before,
.clearfix:after {
    content: " ";
    display: table;
}
.clearfix:after {
    clear: both;
}

/* For IE 6/7 only; Include this rule to trigger hasLayout and contain floats. */
.clearfix {
    *zoom: 1;
}

.clear {
	clear: both;
	display: block;
	height: 0;
	overflow: hidden;
	visibility: hidden;
	width: 0;
}

/* SPRITES */
.sprt,
.btnLook:after,
.btnContainer button:after {
	background: url('../img/sprt.png?v=3') no-repeat left top;
	display: inline-block;
	text-align: left;
	text-indent: -999em;
}
@media only screen and (-webkit-min-device-pixel-ratio: 1.5),
       only screen and (min-resolution: 144dpi) {
	.sprt,
	.btnLook:after,
	.btnContainer button:after {
		background-image:url('../img/sprt@2x.png?v=3');
		background-size:992px 160px;
	}
}

.btnLook:after,
.btnContainer button:after {
	background-position: -160px -64px;
	height: 32px;
	width: 32px;
}
.playIcon {
	background-position: 0 0; 
	height: 64px;
	width: 80px;
}
*:hover > .playIcon {
	background-position: -80px 0; 
}
.icon3d {
	background-position: -161px -97px; 
}
.iconArrowRedDown {
	background-position: -192px -64px; 
}
.iconArrowRedLeft {
	background-position: -224px -64px; 
}
.iconArrowRedRight {
	background-position: -160px -64px; 
}
.iconArrowRedUp {
	background-position: -256px -64px; 
}
.iconBranding {
	background-position: -353px -97px; 
}
.nav-aktiv .iconSrcDark,
.iconCloseDark {
	background-position: -704px -64px;
}
.iconDatenbankentwicklung {
	background-position: -449px -97px; 
}
.iconGrafik-print {
	background-position: -193px -97px; 
}
.iconOeffentliche {
	background-position: -385px -97px; 
}
.iconPortal {
	background-position: -481px -97px; 
}
.iconPrint {
	background-position: -257px -97px; 
}
.iconShops {
	background-position: -417px -97px; 
}
.iconSrcDark {
	background-position: -672px -64px;
}
.iconTourismus {
	background-position: -321px -97px; 
}
.iconUnternehmen {
	background-position: -289px -97px; 
}
.iconWeb {
	background-position: -225px -97px; 
}
.darkSection .iconWebsiteRed,
.iconWebsiteWhite {
	background-position: -516px -100px; 
}

.iconWebsiteRed {
	background-position: -740px -68px;
}

.iconWebsiteWhite,
.iconWebsiteRed {
	display: inline-block;
	height: 24px;
	width: 24px;
}

.icon3d,
.iconBranding,
.iconDatenbankentwicklung,
.iconGrafik-print,
.iconOeffentliche,
.iconPortal,
.iconPrint,
.iconShops,
.iconTourismus,
.iconUnternehmen,
.iconWeb {
	display: block;
	height: 30px;
	width: 30px;
}
.iconArrowRedDown,
.iconArrowRedLeft,
.iconArrowRedRight,
.iconArrowRedUp,
.iconCloseDark,
.iconSrcDark {
	height: 32px;
	width: 32px;
}

/* BUTTONS */
.btn,
.btnLook,
.btnContainer button {
	display: inline-block;
	box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
	background: #FAFBFB;
	border-radius: 1px;
	color: #293133 !important;
	padding: .835em 55px .835em 15px;
	font-family: 'Playfair Display', Georgia, serif;
	font-style: italic;
	font-size: 1em;
	line-height: 1.667;
	text-decoration: none;
	position: relative;
	cursor: pointer;
}
.btn {
	padding-right: 15px;
}
.btnRaised {
	background: #E2001A;
	color: #fff !important;
	font-weight: 600;
}
.btnLook:after,
.btnContainer button:after {
	content: '>';
	color: #E2001A;
	position: absolute;
	margin-top: -16px;
	right: 9px;
	top: 50%;
	text-align: center;
	vertical-align: middle;
}
.btnLook,
.btnLook:after,
.btnContainer button:after{
	-webkit-transition: all .2s;
	transition: all .2s;
}
.btn:hover,
.btn.hover,
.btnLook:hover,
.btnLook.hover,
.btnContainer button:hover,
.btnContainer button.hover {
	box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
	background-color: #EDF1F2;
}
.btnRaised:hover,
.btnRaised.hover {
	box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
	background-color: #4A0008;
}

.btnLook:hover:after,
.btnLook.hover:after,
.btnContainer button:hover:after,
.btnContainer button.hover:after  {
	right: 4px;
}

.btnWrap {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: flex-start;
    align-content: stretch;
    align-items: center;
	margin-right: -1em;
}
.btnWrap .btn {
	margin-right: 1em;
	flex: 0 1 auto;
}

/* MARGINS */
.noMargin {
	margin: 0;
}
.noMarginChildren > :first-child {
	margin-top: 0 !important;
}
.noMarginChildren > :last-child {
	margin-bottom: 0 !important;
}

/* TABELLEN */
.stdTable {
	border: none;
	border-spacing: 0;
	background: #FFF;
	width: 100%;
	margin: 1em 0;
}

.stdTable tr th,
.stdTable tr td {
	padding:4px 5px;
	border-bottom: 1px solid #EDF1F2;
	-webkit-transition: background .3s;
	transition: background .3s;
}
.stdTable tr:first-child th,
.stdTable tr:first-child td {
	border-top: none;
}
.stdTable tr th,
.stdTable thead tr td {
	font-style: normal;
	font-weight: 700;
	font-size: .833em;
	text-align: left;
	vertical-align: top;
	color: #FFF;
	line-height: 1.71429;
	border-bottom: 1px solid #b90015;
	padding-top: 15px; 
	padding-bottom: 5px;
	background-color: #e2001a;
}
.stdTable tr:nth-child(2n+1) td {
	background-color: #FFFFFF;	
	font-size: 1em;
}
.stdTable tr:nth-child(2n) td {
	background-color: #FAFBFB;
	font-size: 1em;
}

@media only screen and (min-width: 480px) {
	.stdTable tr th,
	.stdTable tr td {
		padding: 8px 10px;
	}
}