/*
 Theme Name:   OceanWP Child
 Description:  Child Theme des high-performance WP-Theme OceanWP
 Author:       Philipp Limbeck
 Author URI:   https://insyde.at/
 Template:     oceanwp
 Version:      1.0
 Text Domain:  oceanwp-child
*/

/* overwrite general settings of oceanwp for focus of links (black border) */
#main a:focus,
#site-header a:focus,
#footer a:focus{
	outline: 0px !important;
}


:root {
    --farbe-weiss: #FFFFFF;
	--farbe-opacity-weiss: #FFFFFFB0;
    --farbe-schwarz: #1D1D1B;
	--farbe-blau: #0B2943;
	--farbe-dunkelblau: #011A36;
	--farbe-koenigsblau: #0E4B87;
	--farbe-beige: #F2EDE9;	
	--farbe-dunkelbeige: #CFC5BC;
}

#main h2{
    color: var(--farbe-dunkelblau);
}

#main h3{
    margin: 0 0 10px;
    color: var(--farbe-dunkelblau);
}


footer#footer{
	background-color: var(--farbe-dunkelblau);
}

footer#footer a:not(.insyde-simple-btn),
footer#footer p:not(.insyde-button-text) {
	color: var(--farbe-weiss);
	font-size: 16px;
}

#footer h4{
    color: var(--farbe-weiss);
	font-size: 24px;
}

#footer .wpb_wrapper .footer-menue-ueberschrift p{
	font-size: 24px;
	font-weight: 500;
}

#footer .footer-menue-ueberschrift{
	margin-bottom: 0;
}

#footer div.footer-kontakt-button-anfragen a.insyde-simple-btn{
	min-height: unset;
	padding: 10px 20px;
}

#footer ul.menu{
	margin-left: 0;
}
#footer ul.menu li{
	list-style: none;
	border: 0;
}

#footer .footer-linke-spalte .vc_column-inner{
	max-width: 60%;
}


#footer .vc_row.wolf-cta-row {
    position: relative !important;
    overflow: hidden !important;
    isolation: isolate;
	  background-image: url('/wp-content/uploads/2026/06/Wolf-Footer.svg');
    background-repeat: no-repeat;
    background-position: right center;
	background-size: contain;
	padding-top: 50px;
	padding-bottom: 25px;
}

/* Inhalt über dem Wolf */
#footer .vc_row.wolf-cta-row > .wpb_column {
    position: relative !important;
    z-index: 2 !important;
}

/* Wolf als Pseudo-Element 
#footer .vc_row.wolf-cta-row::before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    right: -35px;
    width: 300px;
    height: 300px;
    transform: translateY(-50%);
    background-image: url('/wp-content/uploads/2026/06/Wolf-Footer.svg');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    opacity: 1;
    z-index: 1;
    pointer-events: none;
}
*/


/* Zeile mit Erfahrungswerten mit 4 Spalten BEGINN */
.erfahrungswerte-zeile {
    background: var(--farbe-blau);
    color: var(--farbe-weiss);
    padding: 26px 0;
    margin-top: 0;
    margin-bottom: 0;
}

.erfahrungswerte-zeile.vc_row,
.erfahrungswerte-zeile .vc_row {
    display: flex;
    align-items: center;
}

.erfahrungswerte-zeile > .wpb_column {
    display: flex;
    align-items: center;
}

.erfahrungswerte-zeile > .wpb_column > .vc_column-inner {
    padding-top: 0 !important;
    padding-bottom: 0 !important;
}

.erfahrungswerte-zeile .wpb_wrapper {
    width: 100%;
}

.erfahrungswerte-zeile .wpb_content_element,
.erfahrungswerte-zeile .wpb_raw_code {
    margin-bottom: 0 !important;
}

.erfahrungswerte-container {
    position: relative;
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 14px;
    min-height: 54px;
}

.erfahrungswerte-zeile > .wpb_column:not(:last-child) .ww-stat-item::after {
    content: "";
    position: absolute;
    right: 0;
    top: 50%;
    width: 1px;
    height: 50px;
    transform: translateY(-50%);
    background: rgba(255, 255, 255, 0.28);
}

.erfahrungswerte-icon {
    flex: 0 0 38px;
    width: 38px;
    height: 38px;
}

.erfahrungswerte-icon img {
    display: block;
    width: 38px;
    height: 38px;
    object-fit: contain;
}

.erfahrungswerte-content {
    display: flex;
    flex-direction: column;
    justify-content: center;
    line-height: 1.1;
}

.erfahrungswerte-zahl {
    display: flex;
    align-items: baseline;
    gap: 2px;
    font-size: 28px;
    line-height: 1;
    font-weight: 400;
    color: var(--farbe-opacity-weiss);
}

.ww-stat-label {
    margin-top: 4px;
    font-size: 13px;
    line-height: 1.2;
    color: var(--farbe-weiss);
}
/* Zeile mit Erfahrungswerten mit 4 Spalten ENDE */




/* Zeile Vortragsformate BEGINN */
.vortragsformate-zeile {
    margin-top: 0;
    margin-bottom: 0;
}

.vortragsformate-zeile .vc_column-inner {
    padding-top: 0 !important;
}

.vortragsformate-zeile .wpb_content_element,
.vortragsformate-zeile .wpb_raw_code {
    margin-bottom: 0 !important;
}

.vortragsformat-card {
    display: flex;
    align-items: flex-start;
    gap: 18px;
    height: 100%;
    min-height: 164px;
    padding: 24px 26px;
    background: var(--farbe-beige);
    border-radius: 10px;
    box-sizing: border-box;
}

.vortragsformat-icon {
    flex: 0 0 48px;
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--farbe-dunkelblau);
    display: flex;
    align-items: center;
    justify-content: center;
}

.vortragsformat-icon img {
    display: block;
    width: 24px;
    height: 24px;
    object-fit: contain;
}

.vortragsformat-content {
    flex: 1;
    min-width: 0;
}

div.vortragsformate-ueberschrift{
	margin-bottom: 0;
}

.vortragsformat-content p {
    margin: 0 0 12px;
    font-size: 20px;
    line-height: 1.35;
    color: #657282;
}

.vortragsformat-link {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    font-size: 18px;
    line-height: 1.2;
    font-weight: 700;
    color: var(--farbe-dunkelblau);
    text-decoration: none !important;
}

.vortragsformat-link span {
    transition: transform 0.2s ease;
}

.vortragsformat-link:hover span {
    transform: translateX(3px);
}

@media (max-width: 767px) {
    .vortragsformat-card {
        min-height: 0;
        padding: 22px;
        gap: 16px;
    }

    .vortragsformat-icon {
        flex-basis: 44px;
        width: 44px;
        height: 44px;
    }

    .vortragsformat-icon img {
        width: 22px;
        height: 22px;
    }
}
/* Zeile Vortragsformate ENDE */

/* Header Zeile BEGINN */
.header-zeile .header-linke-spalte .wpb_wrapper{
	max-width: 620px;
}
.header-zeile .header-linke-spalte h1{
	padding-top: 20px;
	padding-bottom: 20px;
}

.header-zeile .header-innerezeile-buttons .wpb_wrapper{
	padding-top: 50px;
}

/* Hero: rechte Spalte bis zum Browserrand, linke Spalte bleibt im Container */
.header-zeile {
    display: flex;
    align-items: center;
    margin-left: 0 !important;
    margin-right: 0 !important;
}

/* Beide Spalten sauber auf 50% */
.header-zeile > .wpb_column {
    width: 50%;
}

/* Linke Spalte wieder auf 1800px-Container-Abstand bringen */
.header-zeile > .wpb_column:first-child > .vc_column-inner {
    padding-left: max(68px, calc((100vw - 1800px) / 2));
    padding-right: 60px;
}

/* Rechte Spalte wirklich bis zum Rand */
.header-zeile > .wpb_column:last-child > .vc_column-inner {
    padding-left: 0 !important;
    padding-right: 0 !important;
}

/* Bild ohne WPBakery-Abstände */
.header-zeile .wpb_single_image,
.header-zeile .wpb_single_image figure,
.header-zeile .vc_single_image-wrapper {
    margin: 0;
    width: 100%;
    max-width: none;
}

/* Bild füllt die rechte Spalte */
.header-zeile .vc_single_image-img {
    width: 100%;
    height: auto;
    display: block;
}

.header-zeile strong{
	font-size: 26px;
	line-height: 1.4;
	font-weight: 500;
	color: #0000009e;
}


@media (max-width: 1200px) {
    .header-zeile > .wpb_column:first-child > .vc_column-inner {
        padding-left: 52px;
        padding-right: 40px;
    }
}

@media (max-width: 767px) {
    .header-zeile {
        display: block;
    }

    .header-zeile > .wpb_column {
        width: 100%;
    }

    .header-zeile > .wpb_column:first-child > .vc_column-inner {
        padding: 40px 24px;
    }

    .header-zeile > .wpb_column:last-child > .vc_column-inner {
        padding: 0 !important;
    }
}
/* Header Zeile ENDE */