:root {
	--otax-violet: rgb(128,53,137);
	--otax-violet-lighter: rgb(217,170,222);
	--otax-violet-darker: rgb(93,38,99);
	--otax-green: rgb(151,190,13);
	--otax-green-opaq80: rgba(151,190,13,.8);
	--otax-green-opaq60: rgba(151,190,13,.6);
	--otax-green-opaq50: rgba(151,190,13,.5);
	--otax-green-lighter: rgb(229,248,160);
	--otax-green-darker: rgb(135,166,33);
	--otax-grey: rgb(111,112,114);
	--otax-grey-opaq5: rgba(111,112,114,.05);
	--otax-grey-lighter: rgb(214,214,215);
	--otax-grey-darker: rgb(86,86,86);
}

/* fonts */

/* "DIN W01 Light" */
@font-face{
	font-family:"DIN W01";
	font-weight: 300;
	src:
		url("webfonts/e39ef3e7-91b2-45d0-8c2f-cfdcd0c0ab94.woff2") format("woff2"),
		url("webfonts/83ff78fa-6d76-4fb5-8bff-8af8eec8e368.woff") format("woff");
}
/* "DIN W01 Medium" */
@font-face{
	font-family:"DIN W01";
	font-weight: 500;
	src:
		url("webfonts/398e3e8c-3bf0-4af1-9791-f426a7992711.woff2") format("woff2"),
		url("webfonts/4ba8e512-e6fb-494f-afd3-a7b68b2e5efb.woff") format("woff");
}
/* bad-script-regular - latin */
@font-face {
	font-family: 'Bad Script';
	font-style: normal;
	font-weight: 400;
	src: local(''),
		url('webfonts/bad-script-v9-latin-regular.woff2') format('woff2'),
		url('webfonts/bad-script-v9-latin-regular.woff') format('woff');
}

/* site */

header *, main *, footer * {
	color: var(--otax-grey);
	font-family: 'DIN W01', -apple-system, BlinkMacSystemFont, avenir next, avenir, helvetica neue, helvetica, Ubuntu, roboto, noto, segoe ui, arial, sans-serif;
	font-weight: 300
}

body {
	font-size: 18px;
	background-color: white
}
h1,h2,h3,h4,h5 {
	font-weight: 500
}
b, strong {
	font-weight: 500
}
.display-1, .display-2, .display-3, .display-4 {
	font-weight: 300
}
.back-farbe {
	background-color: rgb(250,250,250);
}
.back-hell {
	background-color: rgb(255,255,255);
}
.back-neutral {
	background-color: rgb(245,245,245);
}
.home-carousel {
	height: calc(95vh - 180px);
}
header {
	border-bottom: 10px solid var(--otax-violet)
}
header figure {
	margin-top: 10px
}
img.logo {
	width: 250px
}

@media (max-width: 767px) {
	*::-ms-backdrop, .navbar {
		width:100%!important;
	}
}
*::-ms-backdrop, .navbar-brand {
	width:100%!important;
}
*::-ms-backdrop, #homeContents, .navbar-brand {
	min-height:80px!important;
}

header .claim {
	font-weight: 300;
	font-size: 16px;
	white-space: nowrap;
	color: black
}
header .tel {
	font-size: 20px
}
header .tel i {
	color: var(--otax-violet)
}
header .tel a {
	color: black;
	border-bottom: 2px dotted var(--otax-green);
	transition: all .2s;
}
header .tel a:hover {
	text-decoration: none!important;
	border-bottom-color: black;
}
header .nav-link {
	color: var(--otax-grey);
	text-decoration-line: underline;
	text-decoration-color: transparent;
	margin-bottom: 0.5em;
	padding: 0;
	font-size: 1em;
	transition: all .3s;
}
header .nav-link:hover {
	color: var(--otax-green-darker);
	text-decoration-line: underline;
	text-decoration-color: var(--otax-green)
}
header .nav-link.active {
	font-weight: 500
}
header .navbar-toggler {
	font-size: 1.75em;
}
header .navbar-collapse {
	flex-basis: auto!important;
	flex-grow:0!important;
}
.carousel-wrapper {
	position: relative;
	max-height: calc(97vh - 100px);
	overflow: hidden
}
#slogan {
	font-weight: 300;
	color: rgb(129,51,140);
	font-size: 32px;
	line-height: 1;
	position: absolute;
	/* top: calc(5% + 100px);*/
	bottom: 5%;
	left: 0;
	padding-right: 15px;
	padding-left: 15px;
	margin-bottom: 0;
	z-index: 999;
	overflow: hidden;
	width: 100%;
}
#slogan * {
	font-family: 'Bad Script',cursive;
	font-weight: 400
}
#slogan span {
	color: white;
	background-color: var(--otax-green-opaq80);
	display: inline-block;
	padding-left: .2em;
	padding-right: .2em;
	box-decoration-break: clone;
	-webkit-box-decoration-break: clone;
	line-height: 1;
	margin-left: -.2em;
	margin-right: -.2em;
	padding-bottom: .1em;
	padding-top: .3em;
}
#slogan span:nth-of-type(1) {
	display: table;
	margin-bottom: .1em;
	white-space: nowrap
}
#slogan span em {
	font-style: normal;
	font-weight: bold;
	color: var(--otax-violet)
}
a.content-down {
	display: block;
	line-height: 60px;
	position: absolute;
	left: calc(50% - 30px);
	bottom: 5px;
	font-size: 60px;
	transition: all .2s;
}
#downer {
	color: var(--otax-green);
	animation-duration: 3s;
	animation-delay: 2s;
	animation-iteration-count: infinite;
}
main {
	position: relative;
}
main h1, .display-1 {
	font-size: 1.75rem;
	line-height: 1.1;
	font-weight: 500;
	margin-bottom: .5em;
}
main h2, .display-2 {
	font-size: 1.6rem;
	line-height: 1.5rem;
	font-weight: 500;
	margin-bottom: .5em;
	margin-top: .5em;
}
main h3, main h4, main h5, .display-3, .display-4 {
	font-size: 1.4rem;
	line-height: 1.1rem;
	margin-bottom: .25em;
	margin-top: .25em;
}
main h1::first-letter, main h2::first-letter {
	color: var(--otax-violet)
}
.display-3, .display-4 {
	margin-bottom: .5rem;
	margin-top: .5rem;
}
main blockquote {
	color: var(--otax-grey);
	display: table;
	font-size: 1.4em;
	line-height: 1.3;
	margin: .5rem 0;
	padding: 0.3rem;
}
main blockquote * {
	color: var(--otax-grey)
}
main b, main strong {
	font-weight: 500;
	color: var(--otax-violet)
}
main p {
	margin-bottom: 1rem
}
main ul {
	margin-bottom: 1.4rem;
	display: inline-block
}
main blockquote p {
	margin-bottom: 0!important
}
main figure {
	border: 1px solid var(--otax-violet)
}
main img {
	border: .5rem solid white
}
main img.w-50 {
	width: 100%!important
}
main a, footer a {
	text-decoration-line: underline;
	text-decoration-color: transparent;
	font-weight: 500;
	color: var(--otax-violet);
	transition: all .3s;
}
main a:hover, footer a:hover {
	color: var(--otax-green);
	text-decoration-color: var(--otax-green-opaq80)
}
main a.active {
	color: var(--otax-green)
}
main a.active:hover {
	color: var(--otax-green-darker)
}
table .lead {
	font-size: .75rem;
}

.news .list-group-item > p > a {
	font-size: 1.4rem;
	font-weight: 500
}
.news .list-group-item > p > date {
	margin-left: -1.25rem;
	margin-right: .5rem
}

.services {
	padding-top: 1em;
}
.services li {
	list-style-type: none;
	color: rgba(173,196,68,1);
	margin-bottom: .75em ;
	background-image: url('/_shared/img/otax-o.png');
	background-repeat: no-repeat;
	background-size: 1em;
	background-position: 0 0.5em;
	padding-left: 1.5em;
}
.services a,
.services span.service-title {
	font-size: 1.4rem;
	font-weight: 500;
	line-height: 1.1;
}
footer {
	background-color: rgb(237,242,213);
}
.btn-outline-success {
	color: var(--otax-green-darker);
	border-color: var(--otax-green)
}
.btn-outline-success:focus,
.btn-outline-success:hover {
	background-color: var(--otax-green);
	border-color: var(--otax-green)
}
.back-to-top {
	cursor: pointer;
	position: fixed;
	bottom: 20px;
	right: 20px;
	display:none;
	border: none!important;
	color: white!important;
	background-color: rgb(149,193,26)!important;
}
.back-to-top:hover {
	background-color: rgba(149,193,26,0.5)!important;
}
.back-to-top i {
	color: white!important;
}
.sp-image {
	width: 100%;
	height: auto
}
img.lazy {
	display: none;
}
.no-flex {
	flex: none!important;
}
div[class^="column-count"] {
	-webkit-column-count: unset;
	-moz-column-count: unset;
	column-count: unset;
	-webkit-column-gap: unset;
	-moz-column-gap: unset;
	column-gap: unset
}
.accordion .card-header {
	background-color: var(--otax-grey-opaq5)
}
.accordion .btn-link {
	text-decoration: none
}
.accordion .btn-link :first-child {
	color: var(--otax-grey);
	text-decoration-line: underline;
	text-decoration-color: transparent;
	transition: all .3s
}
.accordion .btn-link:hover, .accordion .btn-link:focus {
	box-shadow: unset
}
.accordion .btn-link:hover :first-child, .accordion .btn-link:focus :first-child {
	text-decoration-color: var(--otax-green)
}
.accordion .card-header i {
	color: var(--otax-green);
	text-decoration-color: red;
	font-size: 2em;
	display: inline-block;
	transform: rotate(180deg);
	transition: transform .3s, color .3s;
	transition-timing-function: ease-in-out
}
.accordion .card-header .collapsed i {
	color: var(--otax-violet);
	transform: rotate(0deg)
}

/**** Loader Animation
*********************************/
.no-js #loader {
	display:none;
}
#loader {
	width: 100vw;
	height: 100vh;
	position: fixed;
	z-index: 999999;
	left: 0;
	top: 0;
	background-color: rgba(255,255,255,1);
	display: flex;
	align-items: center;
	justify-content: center
}
#loader img {
	width: 80px;
	height: auto;
}
#loader .lay-over {
	top: 0;
	left: 0;
	background-color: white;
	animation: move 1.0s 1 ease-in both; 
}
@keyframes move {
	100% { 
		transform: translateY(-100%);
	}
	0% {
		transform: translateY(0);
	}
}

/* #### cookieconsent #### */
.cc-message {
	color: white!important;
}

/* #### media queries #### */

@media (min-width: 576px) {
	.order-1 {
		border-bottom: 10px solid var(--otax-green);
		margin-bottom: -10px
	}
	header .claim {
		font-size: 12.5px
	}
	header nav .nav-link:before {
		color: var(--otax-violet);
		display: block;
		content:"|";
		width: 0.5em;
		margin: 0 .5em;
		float: left
	}
	header nav .nav-link:first-of-type:before {
		display: unset;
		content: "";
		width: unset;
		float: unset;
		margin-left: unset;
	}
	#slogan {
		font-size: 48px
	}
	main h1, .display-1 {
		font-size: 3.2em;
		line-height: 1.2
	}
	main h2, .display-2 {
		font-size: 2.2em;
		line-height: 1.2
	}
	main h3, .display-3 {
		font-size: 1.7em;
		line-height: 1.2;
	}
	main h4, .display-4 {
		font-size: 1.4em;
		line-height: 1.2;
	}
	main h5 {
		font-size: 1.2em;
		line-height: 1.2;
	}
	main img {
		border: 1em solid white;
	}
}

@media (min-width: 768px) {
	img.logo {
		width: 315px
	}
	header .claim {
		font-size: 13.5px;
		letter-spacing: 0.5px
	}
	header {
		flex-direction: inherit;
	}
	header .tel {
		font-size: 1.5em
	}
	#slogan {
		font-size: 64px
	}
	main img.w-50 {
		width: 50%!important;
	}
	.no-flex { /* verhalten für col 3 wieder herstellen */
		-webkit-box-flex: 0!important;
		-ms-flex: 0 0 25%!important;
		flex: 0 0 25%!important;
		max-width: 25%!important;
	}
	div.column-count-2, div.column-count-3, div.column-count-4 {
		-webkit-column-count: 2;
		-moz-column-count: 2;
		column-count: 2;
		-webkit-column-gap: 30px;
		-moz-column-gap: 30px;
		column-gap: 30px
	}
}

@media (min-width: 992px) {
	header {
		position: fixed;
		z-index: 1000;
		background-color: white;
		top: 0;
		left: 0
	}
	header .tel {
		font-size: 32px
	}
	header .nav-link {
		font-size: 1.25em;
	}
	table .lead {
		font-size: 1.25rem;
	}
	div.column-count-3, div.column-count-4 {
		-webkit-column-count: 3;
		-moz-column-count: 3;
		column-count: 3
	}
}

@media (min-width: 1200px) {
	header .claim {
		font-size: 15px
	}
	.order-1 {
		border-bottom: unset;
		margin-bottom: unset
	}
	header figure {
		border-bottom: 10px solid var(--otax-green)
	}
	#slogan {
		font-size: 90px;
		letter-spacing: -1.5px;
		padding-right: calc(3rem + 15px);
		padding-left: calc(3rem + 15px);
	}
	div.column-count-4 {
		-webkit-column-count: 4;
		-moz-column-count: 4;
		column-count: 4
	}
}