*{
margin:0;
padding:0;
box-sizing:border-box;
font-family:Arial;
}


body{
opacity:0;
animation:pageFade .6s ease forwards;
background:#f4f6fb;
font-family:'Open Sans', sans-serif;
}
.skip-link{
position:absolute;
top:-100px;
left:10px;
background:#004F9F;
color:white;
padding:12px 16px;
border-radius:6px;
font-weight:600;
text-decoration:none;
z-index:9999;
transition:top .25s ease;
}

.skip-link:focus{
top:10px;
}


@keyframes pageFade{

0%{
opacity:0;
transform:translateY(10px);
}

100%{
opacity:1;
transform:translateY(0);
}

}


.container{
width:1200px;
max-width:92%;
margin:auto;
}
.text ul{
list-style:none;
margin:25px 0;
padding:0;
}

/* Topbar */

.topbar{
background:#007ac1;
color:#ffffff;
font-size:14px;
padding:8px 0;
}

.phone, .mail{
font-weight:600;
}

.topbar .container{
display:flex;
justify-content:space-between;
}

.topbar a{
color:white;
text-decoration:none;
}

.topbar a:visited{
color:white;
}

.topbar a:hover{
color:white;
}

.topbar a{
color:white;
text-decoration:underline;
font-weight:700;
letter-spacing:.5px;
}
.menu-toggle{
display:none;
}
/* Navigation */


/* Text */


.menu li.dropdown > a::after{
content:"▾";
margin-left:8px;
font-size:14px;
transition:transform .3s ease;
}

.nav-home::before,
.nav-home::after{
content:none;
}

.menu li::before,
.menu li::after{
content:none !important;
}

.dropdown.active > a::after{
transform:rotate(180deg);
}

.navigation{
background:#004F9F;
padding:8px 0;
position:relative;
z-index:1;
display:flex;
align-items:center;
z-index: 10;
}

.menu{
display:flex;

gap:35px;
list-style:none;
}

.menu a{
font-weight:600;
font-size:20px;
letter-spacing:.3px;
color:white;
text-decoration:none;
font-weight:600;
transition:0.3s;
display:block;
width:100%;
padding:10px 0;
display:flex;
align-items:center;
gap:8px;
}


.menu a:hover{
color:#ff8c00;
}

.menu li{
position:relative;
display:inline-block;
}
.menu-icon{
height:15px;
margin-right:0px;
vertical-align:middle;
transition:filter .25s ease;
}

/* Hover */

.nav-home:hover .menu-icon{
filter: brightness(0) saturate(100%) invert(58%) sepia(84%) saturate(1172%) hue-rotate(2deg) brightness(102%) contrast(104%);
}

.nav-home:hover a{
color:#ff8c00;
}

.menu-icon{
height:16px;
display:block;
margin-top:-3px;
}

.dropdown{
padding-bottom:10px;
}

.dropdown::after{
content:"";
position:absolute;
top:100%;
left:0;
width:100%;
height:20px;
}
.submenu{
position:absolute;
top:100%;
left:0;
background:white;
padding:20px 0;
border-radius:10px;
box-shadow:0 20px 40px rgba(0,0,0,.18);
display:none;
min-width:220px;
z-index:1000000;
}

.submenu a{

display:block;
width:100%;
padding:16px 32px;
font-size:18px;
font-weight:500;
color:#2b4c7f;
text-decoration:none;
transition:all .2s ease;

}

.submenu a:hover{

background:#eef2f7;
color:#ff8c00;

}
.submenu li{
width:100%;
}

.dropdown:hover .submenu{
display:block;
}

/* HERO */

.hero{
position:relative;
height:640px;
overflow:visible;
z-index:1;
}

.hero-image{
position:absolute;
width:100%;
height:100%;
object-fit:cover;
}

.hero-overlay{
position:absolute;
width:100%;
height:100%;
background:linear-gradient(rgba(20,40,80,.35),rgba(0,0,0,.15));
}

.hero-container{
position:relative;
display:flex;
align-items:center;
justify-content:space-between;
height:100%;
}

.hero-text{
color:white;
max-width:560px;
margin-left:140px;
}

.hero-text h1{
font-size:58px;
font-weight:700;
line-height:1.15;
letter-spacing:-0.5px;
margin-bottom:18px;

}

.hero-text p{

font-size:16px;
opacity:.95;
max-width:440px;

}

.hero-light{
position:absolute;
bottom:-120px;
left:-200px;
width:900px;
height:400px;
background:radial-gradient(circle,
rgba(0,160,255,0.45) 0%,
rgba(0,80,200,0.25) 40%,
rgba(0,0,0,0) 70%);
filter:blur(80px);
pointer-events:none;
}

.hero-wave{
position:absolute;
bottom:-1px;
left:0;
width:100%;
height:160px;

background:
radial-gradient(120% 200px at 50% -20px,
rgba(255,255,255,0) 60%,
rgba(255,255,255,0.95) 61%),
linear-gradient(
90deg,
#2c6fb6,
#4c86c7,
#2c6fb6
);

opacity:.9;
}
.cta-button{
display:inline-block;
margin-top:22px;
padding:14px 34px;
border-radius:8px;

background:linear-gradient(
180deg,
#ff9b2f,
#ff7a00
);

color:white;
font-weight:600;
font-size:16px;

text-decoration:none;

box-shadow:
0 10px 25px rgba(255,120,0,0.45),
inset 0 1px 0 rgba(255,255,255,0.4);

transition:all .3s ease;
}
.cta-button:hover{

transform:translateY(-2px);

box-shadow:
0 14px 30px rgba(255,120,0,0.55);

}

/* Logo rechts */

.hero-logo{
position:fixed;
top:60px;
right:20%;
z-index:999999;
}

.hero-logo img{
width:400px;
transform:rotate(-8deg);
filter:drop-shadow(0 25px 40px rgba(0,0,0,.45));
}

.subpage-logo{
position:absolute;
right:16%;
top:10px;
z-index:6000;
pointer-events:none;
}

.subpage-logo img{
width:400px;
transform:rotate(-8deg);
filter:drop-shadow(0 25px 40px rgba(0,0,0,.45));
}

.service-hero-content{
position:relative;
z-index:3;
text-align:center;
padding:0 20px;
margin-top:220px;
}


/* CTA Button Glow */

.cta-button{
animation:ctaGlow 2.5s ease-in-out infinite;
}

@keyframes ctaGlow{

0%{
box-shadow:
0 10px 25px rgba(255,120,0,0.45),
0 0 0 rgba(255,150,0,0.0);
}

50%{
box-shadow:
0 10px 25px rgba(255,120,0,0.6),
0 0 18px rgba(255,150,0,0.6);
}

100%{
box-shadow:
0 10px 25px rgba(255,120,0,0.45),
0 0 0 rgba(255,150,0,0.0);
}

}
/* Hero Text Animation */

.hero-text{
animation:heroFade 1.2s ease forwards;
opacity:0;
}

@keyframes heroFade{

0%{
opacity:0;
transform:translateY(25px);
}

100%{
opacity:1;
transform:translateY(0);
}

}
/* SECTION */

.services{

background:

linear-gradient(
180deg,
#eef3f9 0%,
#e3e9f2 100%
);

padding:110px 0;

}

.service-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:80px;
align-items:center;
}

.text h2{
color:#1d3f70;
font-size:34px;
}

.text h3{
color:#2d66b2;
margin-bottom:20px;
}

.text ul{
margin:25px 0;
}

.text li{
margin-bottom:10px;
font-weight:600;
}

.btn-blue{
display:inline-block;
background:linear-gradient(180deg,#2e61a6,#1e4f8f);
padding:14px 28px;
border-radius:8px;
color:white;
text-decoration:none;
font-weight:600;
letter-spacing:.3px;

box-shadow:0 8px 20px rgba(0,0,0,.18);
transition:all .3s ease;
}

/* Hover Effekt */
.kontaktemail{
color:#2e61a6;
text-decoration:none;
font-weight:600;
position:relative;
transition:color .3s ease;
}

.kontaktemail::after{
content:"";
position:absolute;
left:0;
bottom:-3px;
width:0;
height:2px;
background:#ff8c00;
transition:width .3s ease;
}

.kontaktemail:hover{
color:#1d3f70;
}

.kontaktemail:hover::after{
width:100%;
}
.btn-blue:hover{
transform:translateY(-3px);

background:linear-gradient(180deg,#3a73c5,#245fa9);

box-shadow:
0 14px 28px rgba(0,0,0,.25),
0 0 12px rgba(46,97,166,.5);
}

.image img{
width:100%;
border-radius:12px;
}

/* Footer */

/* FOOTER */

.footer-bar{
background:#00509f;
padding:18px 0;
}

.footer-links{
display:flex;
justify-content:center;
gap:40px;
}

.footer-links a{
color:white;
text-decoration:none;
font-size:16px;
font-weight:500;
position:relative;
transition:all .3s ease;
}

/* Hover Effekt */

.footer-links a::after{
content:"";
position:absolute;
left:0;
bottom:-4px;
width:0%;
height:2px;
background:#ff8c00;
transition:width .3s ease;
}

.footer-links a:hover{
color:#ffffff;
}

.footer-links a:hover::after{
width:100%;
}
.footer-phone a{
color:white;
text-decoration:none;
}

.scrolltop{
position:fixed;
right:40px;
bottom:40px;
background:white;
width:60px;
height:60px;
border-radius:40px;
display:flex;
align-items:center;
justify-content:center;
font-size:24px;
box-shadow:0 4px 12px rgba(0,0,0,0.2);
cursor:pointer;
}
/* LEISTUNGSSEITEN */

.service-hero{
position:relative;
height:420px;
display:flex;
align-items:center;
justify-content:center;
color:white;
overflow:hidden;
width:100%;
}

.service-hero img{
position:absolute;
width:100%;
height:100%;
object-fit:cover;
object-position:center;
z-index:1;
object-position:20% center;
}

.service-hero-overlay{
position:absolute;
width:100%;
height:100%;
background:linear-gradient(rgba(0,60,120,.25),rgba(0,0,0,.15));
z-index:2;
}

.service-hero-content{
position:relative;
z-index:3;
text-align:center;
padding:0 20px;
}

.service-hero h1{
font-size:46px;
margin-bottom:10px;
}

.service-hero p{
font-size:18px;
opacity:.9;
}

.service-section{
padding:90px 0;
background:#f4f6fb;
}

.service-container{
max-width:1100px;
margin:auto;
padding:0 20px;
}

.service-grid{
display:grid;
grid-template-columns:1fr 1fr;
gap:60px;
align-items:start;
}

.service-grid img{
width:100%;
border-radius:10px;
}

.service-text h2{
font-size:32px;
color:#1d3f70;
margin-bottom:15px;
}

.service-text p{
margin-bottom:15px;
line-height:1.6;
}

.service-list{
margin-top:20px;
}

.service-list li{
margin-bottom:10px;
list-style:none;
font-weight:600;
}

.service-cta{
margin-top:30px;
}

.service-button{
display:inline-block;
padding:14px 30px;
background:linear-gradient(#ff9b2f,#ff7a00);
color:white;
border-radius:8px;
text-decoration:none;
font-weight:600;
box-shadow:0 8px 20px rgba(255,120,0,.4);
text-decoration:none;
}

.service-button:hover{
transform:translateY(-2px);
}

.service-benefits{
margin-top:40px;
display:grid;
grid-template-columns:repeat(3,1fr);
gap:30px;
}

.benefit-box{
background:white;
padding:25px;
border-radius:10px;
box-shadow:0 10px 25px rgba(0,0,0,.08);
}

.benefit-box h3{
color:#2e61a6;
margin-bottom:10px;
}



@media(max-width:900px){

.service-grid{
grid-template-columns:1fr;
gap:40px;
}

.service-benefits{
grid-template-columns:1fr;
}

.service-hero{
height:340px;
}

.service-hero h1{
font-size:32px;
}

}
/* RESPONSIVE */

@media (max-width:900px){

.subpage-logo{
position:absolute;
top:90px;
left:50%;
transform:translateX(-50%);
z-index:6000;
}

.subpage-logo img{
width:180px;
transform:none;
}
.container{
width:92%;
}

/* Topbar */

.topbar .container{
font-size:13px;
}

/* Navigation */

.nav-container{
display:flex;
align-items:center;
justify-content:space-between;
height:60px;
}

.menu-toggle{
display:flex;
flex-direction:column;
justify-content:center;
align-items:center;
width:40px;
height:40px;
background:none;
border:none;
cursor:pointer;
}

.menu-toggle span{
display:block;
width:26px;
height:3px;
background:white;
margin:3px 0;
border-radius:2px;
}

.menu{
position:absolute;
top:60px;
left:0;
width:100%;
background:#004F9F;
flex-direction:column;
align-items:flex-start;
padding:20px;
display:none;
gap:20px;
z-index:7000;
}

.menu.active{
display:flex;
}

.menu li{
width:100%;
}

.menu a{
font-size:20px;
}

/* Dropdown Mobile */

.dropdown:hover .submenu{
display:none;
}

.submenu{
position:relative;
top:0;
left:0;
width:100%;
background:white;
border-radius:8px;
box-shadow:none;
padding:10px 0;
display:none;
margin-top:10px;
}

.dropdown.active .submenu{
display:block;
}

.submenu a{
padding:14px 20px;
}

/* HERO */
/* HERO MOBILE OPTIMIERT */

.hero{
height:620px;
padding:0;
overflow:hidden;
}

.hero-container{
position:relative;
height:100%;
display:block;
}

/* Hintergrundbild */

.hero-image{
object-fit:cover;
object-position:35% center;
}

/* Logo */

.hero-logo{
position:fixed;
top:90px;
right:10px;
z-index:999999;

}

.hero-logo img{
width:140px;
transform:none;
filter:drop-shadow(0 10px 20px rgba(0,0,0,.35));
}
.kontaktemail{
color:#2e61a6;
text-decoration:none;
font-weight:500;
position:relative;
transition:color .3s ease;
}

/* Hover Unterstrich Animation */

.hero-text{
position:absolute;
bottom:60px;
left:-5%;
transform:translateX(-50%);
width:85%;
max-width:420px;
text-align:left;
margin:0;
}

.hero-text h1{
font-size:12px;
line-height:1.2;
margin-bottom:10px;
font-weight:700;
}

.hero-text p{
font-size:15px;
line-height:1.4;
opacity:.95;
}

/* Button */

.cta-button{
margin-top:16px;
padding:12px 24px;
font-size:15px;
border-radius:8px;
display:inline-block;
}

/* Wave Abstand */

.hero-wave{
height:140px;
}
/* Hintergrundbild */

.hero-image{
object-fit:cover;
object-position:20% center;
}

/* Services */

.service-grid{
grid-template-columns:1fr;
gap:40px;
}

.services{
padding:80px 0;
}

.topbar a{
color:white;
text-decoration:underline;
font-weight:700;
letter-spacing:.5px;
}

}
.service-text a:not(.kontaktemail){
color:#2e61a6;
text-decoration:underline;
}
.cta-button{
display:inline-block;
margin-top:22px;
padding:14px 34px;
border-radius:8px;

background:linear-gradient(180deg,#ff9b2f,#ff7a00);
color:white;
font-weight:600;
font-size:16px;

text-decoration:none !important;

box-shadow:
0 10px 25px rgba(255,120,0,0.45),
inset 0 1px 0 rgba(255,255,255,0.4);

transition:all .3s ease;
}

.service-text a:not(.kontaktemail):hover{
color:white;
}
/* FOOTER */

.site-footer{
background:#00509f;
color:white;
margin-top:0px;
}

.footer-container{
max-width:1200px;
margin:auto;
padding:60px 20px;
display:grid;
grid-template-columns:repeat(4,1fr);
gap:50px;
}

.footer-column h3{
margin-bottom:18px;
font-size:20px;
}

.footer-column p{
line-height:1.6;
opacity:.9;
}

.footer-phone{
margin-top:15px;
font-weight:600;
}

.footer-column ul{
list-style:none;
padding:0;
}

.footer-column li{
margin-bottom:10px;
}

.footer-column a{
color:white;
text-decoration:none;
position:relative;
transition:all .3s ease;
}

/* Hover Effekt */

.footer-column a::after{
content:"";
position:absolute;
left:0;
bottom:-3px;
width:0%;
height:2px;
background:#ff8c00;
transition:width .3s ease;
}

.footer-column a:hover::after{
width:100%;
}

/* Footer bottom */

.footer-bottom{
text-align:center;
padding:20px;
background:#003e7d;
font-size:14px;
opacity:.9;
}
.form-hint{
font-size:14px;
color:#5f6b7a;
margin-bottom:25px;
display:flex;
align-items:center;
gap:6px;
}

.required{
color:#ff7a00;
font-weight:700;
}

/* Mobile */

@media(max-width:900px){

.footer-container{
grid-template-columns:1fr 1fr;
gap:35px;
text-align:left;
}

.footer-column:first-child{
grid-column:1 / -1;
text-align:center;
}

.footer-column ul{
padding:0;
}

}
/* KONTAKTSEITE */

.contact-section{
padding:100px 0;
background:#f4f6fb;
}

.contact-container{
max-width:1100px;
margin:auto;
padding:0 20px;
}

.contact-grid{
display:grid;
grid-template-columns:2fr 1fr;
gap:40px;
}

.contact-card{
background:white;
padding:40px;
border-radius:12px;
box-shadow:0 15px 40px rgba(0,0,0,.08);
}
.contact-card label[for="notiz"]{
display:block;
margin-bottom:8px;
font-weight:600;
color:#1d3f70;
}

.contact-card h2{
margin-bottom:25px;
color:#1d3f70;
}

.form-grid{
display:grid;
grid-template-columns:220px 1fr;
gap:16px 20px;
align-items:center;
margin-bottom:20px;
}
.form-grid label{
font-weight:600;
color:#2c4a74;
}

.form-grid input,
.form-grid select{
width:100%;
padding:12px 14px;
border-radius:6px;
border:1px solid #d6dbe3;
font-size:15px;
background:#fff;
transition:border .2s ease, box-shadow .2s ease;
}
.form-grid select{
width:100%;
padding:12px 40px 12px 14px;
border-radius:6px;
border:1px solid #d6dbe3;
font-size:15px;
background:#fff;
appearance:none;
background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath fill='%23607080' d='M1 1l5 5 5-5'/%3E%3C/svg%3E");
background-repeat:no-repeat;
background-position:right 14px center;
background-size:12px;
}
.form-grid input:focus,
.form-grid select:focus,
textarea:focus{
outline:none;
border-color:#2e61a6;
box-shadow:0 0 0 2px rgba(46,97,166,0.15);
}

textarea{
grid-column:2;
width:100%;
min-height:160px;
padding:14px;
border-radius:6px;
border:1px solid #ddd;
margin-bottom:20px;
font-size:15px;
}

.form-check{
margin-bottom:20px;
font-size:14px;
}

.form-check a{
color:#2e61a6;
text-decoration:underline;
}

.captcha{
margin-bottom:20px;
}
input:focus,
textarea:focus,
select:focus,
button:focus{
outline:3px solid #ff7a00;
outline-offset:2px;
}
a:focus-visible,
button:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
outline:3px solid #ff7a00;
outline-offset:2px;
}
.contact-button{
padding:14px 30px;
border:none;
background:linear-gradient(#ff9b2f,#ff7a00);
color:white;
font-weight:600;
border-radius:8px;
cursor:pointer;
box-shadow:0 8px 20px rgba(255,120,0,.4);
}

.contact-button:hover{
transform:translateY(-2px);
}

/* INFO */

.contact-info p{
margin-bottom:20px;
line-height:1.6;
}

.contact-info a{
color:#2e61a6;
text-decoration:underline;
}

/* MOBILE */

@media(max-width:900px){

.contact-grid{
grid-template-columns:1fr;
}

.form-grid{
grid-template-columns:1fr;
}

}
.service-text h3{
margin-top:35px;
margin-bottom:10px;
color:#1d3f70;
}

.service-text p{
line-height:1.7;
margin-bottom:14px;
}
.service-text h3{
margin-top:35px;
margin-bottom:10px;
color:#1d3f70;
}

.service-text p{
line-height:1.7;
margin-bottom:14px;
}


/* GLOBAL SUBPAGE LOGO */
/* iPad / Tablet Fix */

@media (max-width:1200px){

.subpage-logo{
position:absolute;
top:30px;
right:3%;
}

.subpage-logo img{
width:260px;
transform:rotate(-8deg);
}

}

/* iPad hochkant */

@media (max-width:1050px){

.subpage-logo{
top:20px;
right:30%;
}

.subpage-logo img{
width:220px;
}

.hero-text{
margin-left:60px;
max-width:500px;
}

.hero-text h1{
font-size:42px;
line-height:1.2;
}

.hero-text p{
font-size:18px;
}
}