/* BEGIN - CUSTOM CSS */
.header_bottom {
	background: #b3bbc3;
	padding-top: 1rem;
	padding-bottom: 1rem;
	color: #000000;
}
.header_bottom a {
	color: #000000;
	font-weight: bold;
	margin: 0 10px;
}
.header_bottom a:first-child {
	margin-left: 0;
}
.header_bottom a:last-child {
	margin-right: 0;
}
.content h1, .content  h2, .content h3, .content h4, .content h5, .content h6 {
	font-size: 1.6rem!important;
}
.content ul {
	margin-left: 15px!important;
	line-height: 1.75;
}
blockquote {
	position: relative;
	margin: 0 25px;
	font-style: italic;
}
blockquote:before {
	content: "„";
    left: -25px;
    top: -11px;
    position: absolute;
    color: #005ea8;
    display: inline-block;
    font-size: 50px;
    line-height: 0;
}
blockquote:after {
	content: "“";
    right: 0;
    bottom: -7px;
    position: absolute;
    color: #005ea8;
    display: inline-block;
    font-size: 50px;
    line-height: 0;
}
table th {
	background: #dbdbdb;
	color: #ffffff;
	border: 1px solid #005ea8;
}
table th, table td {
	padding: 10px;
}
table td {
	border: 1px solid #dbdbdb!important;
}
.schema-faq {
    margin-top: 2em;
}
.schema-faq br {
    display: none;
}
.schema-faq:before {
    content: "Das Wichtigste in Kürze";
    background-color: #005ea8;
    font-family: helvetica;
    font-weight: 600;
    padding: 12px;
    color: white;
    border-radius: 4px;
}
.schema-faq .schema-faq-section {
    background: #f5f5f5 !important;
    margin: 8px 0px 16px 0px !important;
    padding: 12px 16px 2px 25px !important;
    border-style: solid !important;
    border-width: 0px 0px 0px 4px !important;
    border-color: #005ea8 !important;
    border-radius: 0px 4px 4px 4px !important;
}
.schema-faq-section p {
	margin-bottom: 10px!important;
}
.tipp {
	background: #f5f5f5;
	float: right;
    width: 300px;
    margin-left: 1em;
    margin-bottom: 1em;
    line-height: 1.75;
}
.tipp-titel {
	color: #ffffff;
	background: #005ea8;
	font-weight: bold;
	padding: 10px;
}
.tipp-inhalt {
	padding: 10px;
}
.clear {
	display: block;
	clear: both;
}
figure {
	margin: 0;
}
.wp-caption {
	background: #f5f5f5;
}
.wp-caption-text {
	padding: 5px 10px 10px 10px;
}
.alignleft {
	float: left;
	margin-right: 1em;
	margin-bottom: 1em;
}
.alignright {
	float: right;
	margin-left: 1em;
	margin-bottom: 1em;
}
.aligncenter {
	margin: 0 auto 1em auto;
}
ul.pro-contra {
	list-style: none;
	margin-left: 0!important;
}
li.pro:before {
	font-family: "Font Awesome 5 Free";
	font-weight: 600;
	content: "\f055";
	margin-right: 10px;
	color: #239212;
}
li.contra:before {
	font-family: "Font Awesome 5 Free";
	font-weight: 600;
	content: "\f056";
	margin-right: 10px;
	color: #db0000;
}
.clk-widget {
	border: 1px solid #005ea8;
	background: #f5f5f5;
}
.clk-widget a {
	color: #000000;
}
.clk-widget a:hover {
	text-decoration: none;
}
.clk-widget .top {
	padding: 10px 10px 0 10px;
	color: #005ea8;
	display: block;
	font-size: 1.6rem;
	font-weight: 500;
}
.clk-widget .bottom {
	display: block;
	padding: 10px;
}
.clk-widget .button {
	background: #005ea8;
    color: #fff;
    font-weight: bold;
    border: 1px solid #000;
}
.clk-widget .button:hover {
	text-decoration: underline;
}
#toc_container {
	background: #f5f5f5;
    padding: 10px;
	margin-bottom: 1em;
}
#toc_container .toc_title {
	//font-size: 1.6rem!important;
    font-weight: bold;
    margin: 0;
}
#toc_container ol {
	margin: 0;
	padding: 0 0 0 16px;
	line-height: 1.75;
}
#comments label {
	display: block;
}
#comments textarea, #comments input[type=text], #comments input[type=email] {
	width: 500px;
	font-size: 14px;
	padding: 10px;
	outline: 0;
	border: 1px solid #ccc;
}
#comments textarea:focus, #comments input[type=text]:focus, #comments input[type=email]:focus {
	border-color: #005ea8;
}
#comments input[type=submit] {
	background: #005ea8;
    color: #fff;
    font-weight: bold;
	border: 1px solid #000;
	padding: 10px;
	font-size: 14px;
}
#comments input[type=submit]:hover {
	cursor: pointer;
	text-decoration: underline;
}
ol.comment-list {
	padding: 0;
	list-style: none;
}
.comment-meta {
	margin-bottom: 10px;
}
#respond {
	border-top: 1px solid #ccc;
    padding-top: 10px;
}
.post {
	clear: both;
	display: block;
	margin-bottom: 25px;
}
.post img {
	width: 200px;
	float: left;
	margin-right: 25px;
}
.share-btns {
	margin-bottom: 1em;
}
@media print, screen and (max-width: 768px) {
	.tipp {
		float: none;
		width: 100%;
		margin-left: 0;
		display: block;
	}
	figure.wp-caption, figure.wp-caption img {
		width: 100%!important;
	}
	#comments textarea, #comments input[type=text], #comments input[type=email] {
		width: 100%;
	}
}
.no-margin-bottom {
	margin-bottom:0!important;
}
.margin-top-half {
	margin-top:.5em!important;
}
.title.is-7 {
    font-size: .9285714286rem!important;
}
ul.mb-advantages {
	margin-left: 0!important;
}
ul.mb-advantages li {
	list-style: none;
}
ul.mb-advantages li:before {
	font-family: 'Font Awesome 5 Free';
    content: "\f058";
	color: #18a31c;
	margin-right: 5px;
}
span.note {
	position: relative;
}
span.note svg {
	color: #005ea8;
	font-size: 12px;
	margin-top: -1px;
}
span.note span.text {
	display: none;
}
span.note:hover span.text {
	display: block;
    background: #f5f5f5;
    border: 1px solid #ddd;
    padding: 5px 10px;
    position: absolute;
    bottom: 20px;
    left: 0;
    width: 300px;
}
@media screen and (max-width:639px) {
	span.note:hover span.text {
		position: unset;
		width: 100%;
	}
}
.accordion-container {
  margin-top: 2rem;
  border: 1px solid #e0e0e0;
}
.accordion-item + .accordion-item {
  border-top: 1px solid #e0e0e0;
}
.accordion-header {
  width: 100%;
  background: none;
  border: none;
  text-align: left;
  padding: 1rem;
  font-size: 1.1rem;
  font-weight: 600;
  cursor: pointer;
  position: relative;
  transition: background-color 0.3s;
}
.accordion-header:hover {
  background-color: #f5f5f5;
}
.accordion-header::after {
  content: "+";
  position: absolute;
  right: 1rem;
  font-size: 1.3rem;
  transition: transform 0.3s ease;
  color: #333333;
}
.accordion-header.active {
	background: #f5f5f5;
	border-bottom: 1px solid #e0e0e0;
}
.accordion-header.active::after {
  content: "−";
}
.accordion-content {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.3s ease;
  padding: 0 1rem;
}
.accordion-content p {
  margin: 1rem 0;
}
.a-seal {
	float: right;
	margin-left: 100px;
}
@media screen and (max-width:639px) {
	.a-seal {
		margin: 0 0 .6666rem 0;
	}
}
a.button {
	border-radius: 3px;
	border: 0;
	background: #005ea8;
	color: #fff;
	font-weight: bold;
	font-size: 16px;
}
a.button:hover {
	color: #fff;
	text-decoration: underline;
}
table.schritte tr th {
	vertical-align: top;
	text-align: center!important;
	background: none;
	border: none!important;
	font-size: 16px;
}
table.schritte tr td {
	vertical-align: top;
	text-align: center!important;
	border: none!important;
}
#schritte h2 {
	margin-top: 0;
}
#schritte p {
	display: none;
}
/* ===== Schritte-Box ===== */
.steps-box {
  background-color: #fff;
  border: 1px solid #ededed;
  padding: 25px;
  color: #333;
  margin-bottom: 1rem;
}

.steps-box p {
  display: none;
}

/* Titel */
.steps-box__title {
  font-weight: bold;
  text-align: center;
  margin-bottom: 2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
}

.steps-box__icon {
  width: 28px;
  height: 28px;
  stroke: #0073c5;
}

/* Container */
.steps-box__container {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 1.5rem;
}

/* Einzelne Schritte */
.steps-box__item {
  flex: 1 1 calc(33.333% - 1rem);
  display: flex;
  align-items: flex-start;
  gap: 1rem;
  padding: 1rem;
  background-color: #f9fbfd;
  border-radius: 10px;
  transition: all 0.3s ease;
  border: 1px solid transparent;
}

.steps-box__item:hover {
  border-color: #0073c5;
}

/* Schritt-Inhalt */
.steps-box__content h3 {
  font-size: 1.1rem;
  color: #004c8c;
  margin: 0 0 0.4rem;
}

.steps-box__content b {
	color: #004c8c;
	font-size: 16px;
	margin-bottom: .3333em;
    display: inline-block;
}

/* Responsive */
@media (max-width: 900px) {
  .steps-box__item {
    flex: 1 1 100%;
  }
  .steps-box__container {
    flex-direction: column;
  }
  .steps-box__title {
    font-size: 1.6rem;
  }
}

.note .gsection_description {
	background: #fef6e9;
	padding: 10px;
	
}
.cta {
	background-color: #f9fbfd;
	border: 1px solid #0073c5;
	text-align: center;
}
.cta p {
	font-size: 1.6rem;
	font-weight: 600;
    line-height: 1.125;
}

/* --- Testimonials Slider Styles --- */
.testimonials {
  max-width: 960px;
}

.testimonials p {
	text-align: center;
}

h2.testimonials__heading {
	margin-bottom: 1.4rem;
}

.swiper-horizontal>.swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
	bottom: -5px!important;
}

.testimonials__heading {
  font-size: 1.8rem;
  color: #004c8c;
  text-align: center;
  margin-bottom: 2rem;
}

/* Wrapper für Slider + externe Pfeile */
.testimonials-shell {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* Swiper bleibt mittig, Pfeile sind außerhalb */
.testimonials-shell .swiper {
  width: 88%;
  max-width: 900px;
}

p.testimonial-card__text {
	font-style: italic;
}

p.testimonial-card__author {
	font-weight: bold;
}

/* Karten */
.testimonial-card {
  background-color: #f9fbfd;
  border: 1px solid #e6e9ec;
  border-radius: 12px;
  padding: 1.5rem;
  box-shadow: 0 4px 12px rgba(0,0,0,0.04);
  text-align: left;
  transition: transform .3s, box-shadow .3s;
  min-height: 111.46px;
}
.testimonial-card:hover {
  box-shadow: 0 8px 16px rgba(0,0,0,0.08);
}
.testimonial-card__text { margin: 0 0 .8rem; color: #333; line-height: 1.5; }
.testimonial-card__author { margin: 0; color: #555; text-align: right; font-size: .95rem; }

/* Externe Pfeile */
.nav-arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 40px; height: 40px;
  display: grid; place-items: center;
  border-radius: 50%;
  border: 1px solid #e6e9ec;
  background: #fff;
  box-shadow: 0 2px 8px rgba(0,0,0,.08);
  color: #005ea8;
  cursor: pointer;
  user-select: none;
}

/* 50px außerhalb des Swiper-Containers */
.nav-arrow--prev {
	left: 0px;
	z-index: 10;
}
.nav-arrow--next {
	right: 0px;
	z-index: 10;
}

.nav-arrow:hover { filter: brightness(0.98); }

/* Pagination-Dots in CI-Farbe */
.swiper-pagination-bullet { background: #0073c5; opacity: .35; }
.swiper-pagination-bullet-active {
	opacity: 1;
	background: #005ea8!important;
}

/* Responsiv: auf kleineren Screens Pfeile nach innen holen */
@media (max-width: 1024px) {
  .nav-arrow--prev { left: 8px; }
  .nav-arrow--next { right: 8px; }
}

/* BEGIN - Custom Gravity Forms CSS */
.ginput_container input, .ginput_container select, .ginput_container textarea {
	border-color: #dbdbdb!important;
	box-shadow: unset!important;
}
.gform-field-label {
	font-weight:bold!important;
}
span.gfield_required {
	font-size: 14px;
	color: unset!important;
}
.gform-theme--foundation .gform_fields {
  grid-row-gap: 1rem!important;
}
p.gform_required_legend {
	display: none;
}
.gf_page_steps {
	background: #ccd4db;
	padding: .7rem;
}
.gf_page_steps .gf_step_label {
	color: rgba(0,0,0,.7);
	text-transform: unset;
}
.gf_step_completed .gf_step_number::after {
	background: #666!important;
    color: #fff;
}
.gf_step_active .gf_step_number {
	background: #005ea8!important;
    color: #fff;
}
.gf_step_completed .gf_step_number::after {
	border: 1px solid #666!important;
}
h3.gsection_title {
	display: none;
}
.gsection_description {
	margin-bottom: 12px;
}
.gform-theme-button, .gform_button {
	font-size: 1.6rem!important;
    padding: calc(.5em - 1px) 1em!important;
}
.gform_next_button, .gform_button {
	background: #005ea8!important;
}
.gform_previous_button {
	color: #666!important;
}
.gfield input::placeholder, .gfield textarea::placeholder {
	color: #888;
}
.gform-theme--foundation .gfield textarea.small {
	height: 6rem;
}
.ginput_container_consent label {
	font-weight: normal!important;
}
.gf_page_steps .gf_step span.showMobile {
	display: none;
}
.gform_confirmation_message_1 {
	border-top: 3px solid #ededed;
	border-bottom: 3px solid #ededed;
	padding: 25px 0;
}
@media screen and (max-width:639px) {
	.gf_page_steps .gf_step {
		display: none;
	}
	.gf_page_steps .gf_step_active {
		display: block;
		line-height: 1.4em;
	}
	.gf_page_steps .gf_step span.showMobile {
		display: block;
	}
	.gf_step_number {
		display: none!important;
	}
	.gfield_label, .gform-field-label {
		font-size: 14px!important;
	}
}
/* END - Custom Gravity Forms CSS */
/* END - CUSTOM CSS */