/* CSS Document */
*,
*::before,
*::after {
  box-sizing: border-box;
}
@media (prefers-reduced-motion: no-preference) {
  :root {
    scroll-behavior: smooth;
  }
}

.visually-hidden,
.visually-hidden-focusable:not(:focus):not(:focus-within) {
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: -1px !important;
  overflow: hidden !important;
  clip: rect(0, 0, 0, 0) !important;
  white-space: nowrap !important;
  border: 0 !important;
}
.visually-hidden:not(caption),
.visually-hidden-focusable:not(:focus):not(:focus-within):not(caption) {
  position: absolute !important;
}
.visually-hidden *,
.visually-hidden-focusable:not(:focus):not(:focus-within) * {
  overflow: hidden !important;
}

body {
	margin: 0;
	padding: 0;
	font-family: 'Inter', sans-serif;
	font-weight: 300;
	font-size: 1em;
	color: #000;
	background: #fff;
}
h1, h2, h3, h4, h5, h6 {
	font-family: 'Inter', sans-serif;
	font-weight: 300;
	line-height: 1.2;
	color: #388600;
	text-align: center;
	text-transform: uppercase;
}
h1 {
	font-size: 2em;
	font-weight: 700;
}
h2 {
	font-size: 1.75em;
}
h3 {
	font-size: 1.5em;
}
.carousel-caption h3 {
	font-size: 2em;
	font-weight: 700;
}
h4 {
	font-size: 1.25em;
	font-weight: 500;
}
h5 {
	font-size: 1.125em;
}
h6 {
	font-size: 1.125em;
	font-weight: 500;
}
p, li {
	font-size: 1em;
	line-height: 1.5;
}
a {}
a:hover {
	text-decoration: none;
}
strong {
	font-weight: 700;
}
.button:focus:not(:focus-visible) {
  outline: 0;
}
.button a {
	display: block;
	width: 100%;
	max-width: 400px;
	height: 60px;
	margin: 20px auto;
	border-radius: 5px;
	background: #388600;
	border: 1px solid #388600;
	color: #fff;
	font-weight: 300;
	font-size: 1em;
	text-decoration: none;
	padding: 17px 10px 12px;
}
.button:hover a {
	color: #388600;
	background: rgba(255,255,255,1);
}
.carousel .button a {
	margin-top: 80px;
}

/* ----- HEADER ----- */
header .logo img {
	width: 200px;
	height: auto;
}
header a {
	color: #388600;
	text-decoration: none;
	text-transform: uppercase;
}
header a:hover {
	color: #666;
}

.nav {
	display: inline-flex;
	flex-wrap: wrap;
	justify-content: center;
	padding: 0;
	margin-top: 0;
	margin-bottom: 0;
	list-style: none;
}
.nav-link {
	display: block;
 	padding: 0.5rem;
	background: none;
	border: 0;
	transition: color 0.15s ease-in-out, background-color 0.15s ease-in-out, border-color 0.15s ease-in-out;
}
.nav.language,
.nav.main {
	width: 100%;
	max-width: 600px;
}
.nav.main {
	margin-top: 34px;
}

/* ----- CONTENT ----- */
.container {
	width: 100%;
	max-width: 1280px;
	margin: 0 auto;
	padding: 20px 10px;
	text-align: center;
}
.container.full {
	padding: 20px 0;
}
.container .portrait {
	width: 194px;
	height: auto;
	border: 4px solid #388600;
	border-radius: 50%;
}
.intro p {
	max-width: 860px;
	padding: 0 10px;
	margin-left: auto;
	margin-right: auto;
}
.bg-white {
	background: #fff;
	padding: 2px 5px;
}
.asa img {
	width: 280px;
	height: auto;
}
.asa p,
.asa a {
	color: #0f70b7;
	font-weight: 500;
}
.asa h3 {
	color: #0f70b7;
}
.impressum p, 
.impressum h3, 
.impressum h4, 
.impressum h5, 
.impressum ul, 
.impressum ol {
	text-align:left;
}
.impressum a {
	color:#388600;
}
.impressum a:hover {
	color:#388600;
	text-decoration:none;
}

/* ----- CONTENT LEISTUNGEN ----- */
.grid-leistungen .leistung01,
.grid-leistungen .leistung02,
.grid-leistungen .leistung03 {
	width: 600px;
	height: 600px;
	margin: 10px;
	display: inline-flex;
	align-content: flex-start;
	flex-wrap: wrap;
}
.grid-leistungen .leistung01 h3,
.grid-leistungen .leistung02 h3,
.grid-leistungen .leistung03 h3 {
	
	opacity: 1;
	z-index: 9;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 5px;
}
.grid-leistungen p {
	margin: 10px auto;
}
.grid-leistungen ul {
	text-align: left;
}
.grid-leistungen .leistung01 p,
.grid-leistungen .leistung02 p,
.grid-leistungen .leistung03 p,
.grid-leistungen .leistung01 li,
.grid-leistungen .leistung02 li,
.grid-leistungen .leistung03 li {
	font-weight: 500;
	color: #388600;
	padding: 0 10px;
	opacity: 1;
}
.grid-leistungen img {
	width: 260px;
}

.grid-leistungen a:link,
.grid-leistungen a:visited,
.grid-leistungen a:hover {
	color: #388600;
}

/* ----- CONTENT THEMEN ----- */
.splide__slide__container {
	width: 400px;
	height: 300px;
	margin-left: 10px;
	margin-right: 10px;
}
.splide__slide__container img {
	width: 100%;
	height: auto;
}
.splide__slide__container span.bg-white {
	font-size: 1.25em;
	text-transform: uppercase;
	color: #388600;
	background: #fff;
	padding: 2px 5px;
	position: relative;
    z-index: 9;
    bottom: 50px;
}
.splide__arrow {
	background: rgba(255,255,255,0.50);
	border-radius: 5px !important;
	width: 60px !important;
	height: 60px !important;
	padding: 10px !important;
}

/* ----- CONTENT ÜBER MICH ----- */
table.ueber-mich {
	width: 100%;
	max-width: 860px;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
	color: #388600;
}
table.ueber-mich th {
	font-weight: 300;
	width: 15%;
	vertical-align: top;
	padding-bottom: 20px;
}
table.ueber-mich td {
	vertical-align: top;
	padding-bottom: 20px;
}

/* ----- CONTENT TÄTIGKEITEN ----- */
.grid-taetigkeiten .grid-inner {
	width: 293px;
	height: 293px;
	margin: 10px;
	border: 1px solid #388600;
	border-radius: 5px;
	display: inline-grid;
}
.grid-taetigkeiten .grid-inner h3 {
	font-size: 1.25em;
}
.grid-taetigkeiten .grid-inner img {
	width: 260px;
	height: auto;
}
.grid-taetigkeiten .grid-inner p {
	color: #388600;
}

/* ----- BOTTOM FOOTER ----- */
aside .container {
	color: #fff;
	background: #388600;
}
aside .container ul {
	text-align: center !important;
}
aside .container a {
	color: #fff;
}
aside .container .portrait {
	border: 4px solid #fff;
}
footer {
	color: #388600;
	background: #fff;
	text-align: center;
}

@media (min-width: 960px) {
	.container {
		padding: 40px 10px;
	}
	header {
		position: fixed;
		z-index: 99;
		width: 100%;
		background: #fff;
	}
	header .container {
		text-align: right;
		padding: 20px 0;
	}
	.logo {
		float: left;
		margin-left: 10px;
		flex: 20%;
	}
	.nav.language,
	.nav.main {
		justify-content: right;
		font-size: 1.25em;
	}
	.nav-link {
	 	padding: 0 0.5rem;
	}
	main,
	#leistungen,
	#themen,
	#ueber-mich {
		padding-top: 134px;
	}
	aside .container ul {
		margin-top: 80px;
	}
	.button a {
		font-size: 1.25em;
	}

}
@media (min-width: 1280px) {
	.container {
		padding: 40px 0;
	}
}
@media (max-width: 959px) {
	.nav.language {
		position: absolute;
		top: 10px;
		right: 10px;
		max-width: 80px;
	}
}
@media (max-width: 419px) {
	.button {
		width: auto;
		max-width: 300px;
		margin: 20px auto;
	}
	.grid-leistungen .leistung01,
	.grid-leistungen .leistung02,
	.grid-leistungen .leistung03 {
		width: 90%;
		height: 630px;
		margin: 10px auto;
		display: inline-grid;
	}
	.grid-leistungen .leistung01 .bg-overlay,
	.grid-leistungen .leistung02 .bg-overlay,
	.grid-leistungen .leistung03 .bg-overlay {
		width: 90%;
		height: 400px;
	}
	table.ueber-mich th,
	table.ueber-mich td {
		width: 100%;
		display: block;
	}
	table.ueber-mich th {
		padding-bottom: 0;
	}
	.grid-taetigkeiten .grid-inner {
		margin: 10px auto;
		display: inline-grid;
	}
}
