/*  include font definitions  */
@font-face {
	font-family: 'Open Sans';
	font-style: normal;
	font-weight: 400;
	src: url('type/open-sans-v18-latin-regular.eot'); /* IE9 Compat Modes */
	src: url('type/open-sans-v18-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
		 url('type/open-sans-v18-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
		 url('type/open-sans-v18-latin-regular.woff') format('woff'), /* Modern Browsers */
		 url('type/open-sans-v18-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
		 url('type/open-sans-v18-latin-regular.svg#OpenSans') format('svg'); /* Legacy iOS */
}
@font-face {
	font-family: 'Open Sans';
	font-style: normal;
	font-weight: 600;
	src: url('type/open-sans-v18-latin-600.eot'); /* IE9 Compat Modes */
	src: url('type/open-sans-v18-latin-600.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
		 url('type/open-sans-v18-latin-600.woff2') format('woff2'), /* Super Modern Browsers */
		 url('type/open-sans-v18-latin-600.woff') format('woff'), /* Modern Browsers */
		 url('type/open-sans-v18-latin-600.ttf') format('truetype'), /* Safari, Android, iOS */
		 url('type/open-sans-v18-latin-600.svg#OpenSans') format('svg'); /* Legacy iOS */
}

@font-face {
	font-family: Oswald;
	font-style: normal;
	font-weight: 400;
	src: url('type/oswald-v35-latin-regular.eot'); /* IE9 Compat Modes */
	src: url('type/oswald-v35-latin-regular.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
	     url('type/oswald-v35-latin-regular.woff2') format('woff2'), /* Super Modern Browsers */
	     url('type/oswald-v35-latin-regular.woff') format('woff'), /* Modern Browsers */
	     url('type/oswald-v35-latin-regular.ttf') format('truetype'), /* Safari, Android, iOS */
	     url('type/oswald-v35-latin-regular.svg#Oswald') format('svg'); /* Legacy iOS */
}

/*  attributes for all  */
body, h1, h2, h3, h4, h5, h6, p, div, img, a, address, b, i, u, sup, div, span, ul, li {
	margin: 0;
	padding: 0;
	border: 0;
}

/*  tags  */
body
{
	font-family: 'Open Sans', Verdana, Arial, Helvetica, sans-serif;
	background: #FFFFFF;
	color: #333333;
	font-size: 16px;
	text-align: center;
}

a
{
	font-weight: normal;
	color: #DC006B;
	text-decoration: underline;
	transition: color 0.2s ease, border 0.2s ease, background-color 0.2s ease;
}
a:hover
{
	color: #000000;
	text-decoration: none;
}

input, textarea
{
	font-family: inherit;
	font-size: 0.9em;
	padding: 4px;
	border: 1px solid #CCCCCC;
	border-radius: 2px;
	box-shadow: none;
	outline: none;
	transition: color 0.2s ease, background 0.2s ease, border 0.2s ease, box-shadow 0.2s ease;
}
input:focus, textarea:focus
{
	border: 1px solid #DC006B;
	box-shadow: 0 0 3px rgba(102, 153,0, 0.5);
}

p
{
	margin: 0 0 0.9em 0;
	line-height: 1.45em;
	/*hyphens: auto;*/
}

ol, ul
{
	margin: 0 0 0.9em 1.25em;
}
ul{
	list-style-type: square;
}
ul ::marker
{
	color: #DC006B;
}

h1
{
	font-family: Oswald, sans-serif;
	color: #DC006B;
	font-size: 2.2em;
	/*font-weight: 300;*/
	font-weight: normal;
	padding-bottom: 0.5em;
}

h2
{
	font-family: Oswald, sans-serif;
	color: #000000;
	font-size: 1.7em;
	/*font-weight: 300;*/
	font-weight: normal;
	padding-bottom: 0.75em;
	padding-top: 0.75em;
}

h3
{
	font-family: Oswald, sans-serif;
	color: #000000;
	font-size: 1.5em;
	font-weight: normal;
	padding-bottom: 0.25em;
	padding-top: 0.75em;
}

/*  ids  */
#header
{
	position: relative;
	display: block;
	overflow: hidden;
	padding: 0;
	box-sizing: border-box;
	margin-bottom: -1px;
	z-index: 1;
}
#header:before
{
	content: ' ';
	position: absolute;
	display: block;
	width: 100%;
	height: 1px;
	background: #000000;
	opacity: 0.25;
	bottom: 0;
	left: 0;
}
#header .center
{
	height: 110px;
}

#logo
{
	position: relative;
	display: block;
	float: left;
	padding: 25px 0 20px 0;
}
#logo img
{
	height: 60px;
}

#content > dl.imagenormal
{
	position: relative;
	display: block;
	overflow: hidden;
	width: 100%;
	max-height: 200px;
	background: #EEEEEE;
}
#content > dl.imagenormal img
{
	float: left;
	min-width: 100%;
}
#content > dl.imagenormal:after
{
	content: ' ';
	position: absolute;
	display: block;
	width: 100%;
	height: 1px;
	background: #000000;
	opacity: 0.25;
	bottom: 0;
	left: 0;
}

#footer
{
	position: relative;
	display: block;
	overflow: hidden;
	background: #666666;
	color: #FFFFFF;
	padding: 40px 0;
	font-size: 0.9em;
}
#footer .center
{
	display: flex;
	align-self: stretch;
	flex-flow: column nowrap;
	justify-content: flex-start;
	align-items: flex-start;
	gap: 3rem;
}
#footer .columns
{
	display: flex;
	align-self: stretch;
	flex-flow: row wrap;
	justify-content: space-between;
	align-items: flex-start;
	gap: 2rem;
}

#footer h2
{
	font-size: 1.25rem;
	color: #FFFFFF;
}

#footer ul
{
	position: relative;
	display: flex;
	flex-flow: column nowrap;
	gap: .25rem;
	margin: 0 0 0 1.25em;
	padding: 0;
}
#footer li
{
	margin: 0;
	padding: 0;
}
#footer a
{
	color: #FFFFFF;
	text-decoration: none;
}
#footer a:hover
{
	text-decoration: underline;
}

#social-media
{
	display: flex;
	flex-flow: row wrap;
	gap: 1rem;
}
#social-media a
{
	display: flex;
	justify-content: center;
	align-items: center;
	width: 2.5rem;
	aspect-ratio: 1;
	padding: .5rem;
	border-radius: 99em;
	color: #FFFFFF;
	background: #DC006B;
	transition: color .3s ease, background .3s ease;
}
#social-media a svg
{
	width: 100%;
	stroke: transparent;
	fill: #FFFFFF;
	transition: stroke .3s ease, fill .3s ease;
}
#social-media a:hover
{
	background: #FFFFFF;
}
#social-media a:hover svg
{
	fill: #DC006B;
}

#copyright
{
	position: relative;
	display: block;
	float: none;
	text-align: center;
}


/*  classes  */
.center
{
	position: relative;
	display: block;
	overflow: hidden;
	width: 1060px;
	margin: 0 auto 0 auto;
	text-align: left;
}

.parallaxcolumn
{
	background-image: url(../images/design/Steuerberaterin-Alina-Bruckelt-v2.jpg);
	background-color: #D1CCD0;
	background-size: auto 100%;
	min-height: 160px;
	max-height: 560px;
}
.parallaxcolumn:before
{
	content: '';
	position: relative;
	display: block;
	overflow: hidden;
	padding: 0 0 40% 0;
	height: 0;
}

.parallaxcolumn:after
{
	content: ' ';
	position: absolute;
	display: block;
	width: 100%;
	height: 1px;
	background: #000000;
	opacity: 0.25;
	bottom: 0;
	left: 0;
}

.parallaxcolumn > .column
{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.available-capacity a
{
    position: relative;
    display: block;
    overflow: hidden;
    background: #244491;
    color: #FFFFFF;
    text-decoration: none;
}
.available-capacity a > span
{
    display: block;
}
.available-capacity a > span:not(:last-child)
{
    margin-bottom: 5px;
}
.available-capacity a > .title
{
    font-weight: bold;
    font-size: 1.125em;
}
.available-capacity.desktop-only a
{
    float: left;
    padding: 15px 10px;
    margin-bottom: 180px;
    border-radius: 4px;
    max-width: 50%;
    text-align: left;
    animation: pulsate 5s ease infinite;
}
.available-capacity.mobile-only a {
    padding: 10px 20px;
}
.available-capacity.mobile-only a:before
{
    content: '';
    position: absolute;
    display: block;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    animation: button-animation 5s ease-in-out infinite;
    background-image: linear-gradient(120deg, rgba(255, 255, 255, 0.0) 50%, rgba(255, 255, 255, 0.5) 70%, rgba(255, 255, 255, 0.0) 77%);
    transition: opacity 0.5s ease;
}
@keyframes pulsate
{
    0%, 30% { transform: scale(1.00); }
    10%     { transform: scale(0.95); }
    20%     { transform: scale(1.05); }
}

.cta
{
    position: relative;
    display: grid;
    grid-template-rows: 1fr auto auto;
    align-items: flex-end;
    overflow: hidden;
    width: 100%;
    max-width: 1100px;
    height: 100%;
    margin: 0 auto;
	padding: 20px 20px;
    gap: 10px;
    box-sizing: border-box;
	text-align: left;
}
.cta .phone,
.cta .email
{
	display: block;
	float: left;
	margin: 0;
	padding: 5px 10px;
	border-radius: 4px;
	background: #DC006B;
	color: #FFFFFF;
	text-decoration: none;
}
.cta div > span
{
	cursor: default;
}

.greycolumn > .column > :first-child
{
	padding-top: 0;
}
.greycolumn > .column > :last-child,
.whitecolumn > .column > :last-child
{
	padding-bottom: 0;
	margin-bottom: 0;
}

.whitecolumn > .column,
.greycolumn > .column
{
	width: 1060px;
	margin: 0 auto 0 auto;
	text-align: left;
}

.threecolumn > .column
{
	width: 28%;
	margin-right: 8%;
	float: left;
}
.threecolumn > .column img
{
	max-height: 100px;
}

.h1center, .h2center, .h3center, .h4center
{
	text-align: center;
}

.googlemaps-wrapper
{
	position: relative;
	display: block;
	overflow: hidden;
	width: 100%;
	padding-top: 50% !important;
}
.googlemaps
{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.video-wrapper
{
	position: relative;
	display: block;
	overflow: hidden;
	width: 100%;
	padding-top: 56.4%;
	margin-bottom: 1em;
}
.video
{
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.cta-phone
{
	font-size: 2rem;
	font-weight: bold;
	margin-bottom: 1rem;
}

.buttonwrapper
{
	text-align: center;
	padding-top: 1em;
}
.button,
.mailformsubmit,
.newslettersubscribesubmit
{
	padding: 5px 7px 5px 7px;
	color: #FFFFFF;
	background: #DC006B;
	text-transform: uppercase;
	border: 1px solid #DC006B;
	border-radius: 2px;
	font-weight: bold;
	font-size: 1em;
}
.button:hover, .button:focus,
.mailformsubmit:hover, .mailformsubmit:focus,
.newslettersubscribesubmit:hover, .newslettersubscribesubmit:focus
{
	background: #FFFFFF;
	color: #DC006B;
}

.button {
	position: relative;
	display: inline-block;
	overflow: hidden;
	color: #FFFFFF;
	text-decoration: none;
	padding: .75rem 1.25rem;
	font-size: 1.25rem;
}
.cta-button:before
{
	content: '';
	position: absolute;
	display: block;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
	animation: button-animation 5s ease-in-out infinite;
	background-image: linear-gradient(120deg, rgba(255, 255, 255, 0.0) 50%, rgba(255, 255, 255, 0.5) 70%, rgba(255, 255, 255, 0.0) 77%);
	transition: opacity 0.5s ease;
}
@keyframes button-animation {
	0% { transform: translateX(-100%); }
	25% { transform: translateX(75%); }
	100% { transform: translateX(75%); }
}
.cta-button:hover:before
{
	opacity: 0;
}

.mailformabort
{
	padding: 5px 7px 5px 7px;
	color: #AAAAAA;
	background: #EEEEEE;
	text-transform: uppercase;
	border: 1px solid #EEEEEE;
	border-radius: 2px;
	font-weight: bold;
	font-size: 1em;
}
.mailformabort:hover, .mailformabort:focus
{
	background: #FFFFFF;
	color: #992200;
}

.mailformsent, .mailformnotsent
{
	border-radius: 2px;
}

.accordion-head:after
{
	color: #DC006B;
}