body { 	
	background-repeat:no-repeat;
	background:#0e232d;
overflow-x: hidden;
	font-family: -apple-system,  BlinkMacSystemFont,  "Segoe UI",  Roboto, Arial,  sans-serif;
	margin: 0; padding: 0;
	height:100%; 
	width:100%; 
	text-transform: none;
}


img,
iframe {
  max-width: 100%;
}

video:not(#bgvid) {
    width: 100%;
    height: auto;
}

h1, h2, h3, h4, h5, h6 {
    line-height: 120%; 
    margin:0; 
    font-weight: 700; 
   font-family: -apple-system,  BlinkMacSystemFont,  "Segoe UI",  Roboto, Arial,  sans-serif;
}

#bg-video-wrapper {
    position: fixed;
    inset: 0;
    z-index: -1;
    overflow: hidden;
    background: #000; /* fallback */
}

#bgvid {
    width: 100%;
    height: 100%;
    object-fit: cover; /* GANZ wichtig */
}

/* optional dunkler Overlay für bessere Lesbarkeit */
#bg-video-wrapper::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.45);
}

#bg-video-wrapper {
    position: fixed;
    inset: 0;
    z-index: 0; /* statt -1 */
}

.wrapper {
    position: relative;
    z-index: 1;
}

#hero-video {
    position: relative;
    width: 100%;
    height: 100vh; /* volle Bildschirmhöhe */
    overflow: hidden;
}

#hero-video video {
    position: absolute;
    top: 50%;
    left: 50%;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transform: translate(-50%, -50%);
    z-index: -10;
    filter: brightness(0.9);
}
#hero-video::after {
    content: "";
    position: absolute;
    inset: 0;
    background: rgba(14, 35, 45, 0.15);
    pointer-events: none;
}

#logo-video { 
    position: absolute; 
    top: 50%; 
    left: 50%;   
    transform: translate(-50%, -50%);
    z-index: 10;
    width: 200px; max-width: 60%;
}

@keyframes blackGlowPulse {
  0%, 100% {
    filter: 
      drop-shadow(0 0 12px rgba(0,0,0,0.5))
      drop-shadow(0 0 25px rgba(0,0,0,0.4));
  }
  50% {
    filter: 
      drop-shadow(0 0 35px rgba(0,0,0,0.9))
      drop-shadow(0 0 70px rgba(0,0,0,0.6));
  }
}

#logo-video img {
  transition: transform 0.4s ease, filter 0.5s ease;
}

#logo-video img:hover {
  transform: scale(1.15);

  filter:
    drop-shadow(0 0 15px rgba(255,255,255,0.8))
    drop-shadow(0 0 35px rgba(255,255,255,0.7))
    drop-shadow(0 0 70px rgba(255,255,255,0.5))
    drop-shadow(0 0 120px rgba(255,255,255,0.3));
}
/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
	Layout Blocks
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */
.wrapper { /* Holds the page items in place */
	XXmin-height:90%; margin: 0px auto;
	box-shadow: 0px 10px 40px -10px rgba(0,0, 0, 0.8);	
}
.wrapper, #topmenubox .m_inner { width: 90%; max-width: 100%; margin: 0 auto;}

.topspacer {padding-top: 0px;  width:100%; }

.topheader { height: 50px; position:relative;  padding-bottom: 5%; width:100%;   background-size: 100% auto;  }
.topheader p {bottom:10%; width:90%; position:absolute; text-align: center; padding: 0 5%; font-size:1.6em; line-height:110%; color:#fff; text-shadow: 0px 2px 30px #000; }

/*frontpage*/
#topparallax {width:100%; position:relative; background-position: center 0; background-size: 100% auto, auto; margin-top: 150px;}



#topparallax .ptext {bottom:0%; width:90%; position:absolute; text-align: center; padding: 3% 5%; background: none;   }
#topparallax .ptext * {text-shadow: 0px 2px 30px #000;  color: #fff ! important;}
#topparallax a.topdown img {width:100px; margin-top: 20px; }

.contentbox { color: #fff; padding: 20px 4%}

.back-to-top {
    width: 48px;
    height: 48px;

    position: fixed;
    bottom: 15px;
    right: 15px;
    z-index: 2000;

    background: rgba(0,0,0,0.55);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 4px;

    transition: all 0.25s ease;
}

/* Pfeil */
.back-to-top::before {
    content: "";
    position: absolute;

    top: 50%;
    left: 50%;

    width: 14px;
    height: 14px;

    border-left: 2px solid #cfcac2;
    border-top: 2px solid #cfcac2;

    transform: translate(-50%, -45%) rotate(45deg);
}

/* Hover */
.back-to-top:hover {
    background: rgba(255,255,255,0.08);
}

.back-to-top:hover::before {
    border-color: #ffffff;
}


.contentbox,
.topheader,
.footerbox {
    background: linear-gradient(
        to bottom,
        #0e232d 0%,
        #0a1d26 50%,
        #051720 100%
    );
}

/*===========================================================
Contentbereich
*/

.container {margin: 0 auto 0 auto; width: 100%; max-width:1500px; padding-top: 30px;}



/*====================================================
Alles rechts neben left
ab hier: 1/3 grid
*/
.mainbox {}

.content { /* main content */
	width: 60%;
	float: left;
	display:inline;
	margin-left: 0;
}

.usegrid3 .content.contentnarrow {width: 62%;}

.mainbox .contentwide  {width:100%; margin: 45px 0 0 0;}

/* Startseite: KEIN Abstand */
.frontpage .mainbox .contentwide {
    margin-top: 0;
}


.social {  top:0px; right: 0px; float: right; }

.fb-page, .fb-page iframe[style], .fb-page span {
    width: 100% !important;
}

.fb-like span, .fb-like iframe { height:35px!important; min-width:150px!important}

.instagram-media {
   width:99.375% !important;
}

#rightbox { width: 37%; float: right; display:inline; border-left:1px #ddd solid; }
.usegrid3 #rightbox {width: 37%; }

#rightbox .inner { margin: 0 3% 3px 3%; font-size: 1.5em; line-height:135%}
#rightbox .inner img { max-width:100%; height:auto ! important;}




.clearcontent {height:10px; clear:both; }

.footerbox {min-height:80px; font-size:13px; color: #999; width: 100%;  color: #fff;}
.footerbox .left {width: 25%; min-height: 10px; margin:0 0 0 0; float:left;}
.footerbox  .center {width: 50%; margin: 10px 0 0 0; float:left; text-align:center;}

#gototopswitch {float:right; margin: 10px 10px 0 0}







/* Top and Menu Box */
#topmenubox {  width: 100%; height:200px; margin:0 0 0 0; position:fixed; z-index:1000; width: 100%; top:0; left:0%;  transition: 0.5s all; }
#topmenubox .m_inner {position:relative; height:100%;   }
#topmenubox a.logo img {max-height:80%; max-width:100%; position: absolute; left: 10px; bottom:1px;}

#topmenubox.reduced .m_inner {
    height: 60px; transition: 0.5s all;    margin: 0px auto 0 auto; } 
#topmenubox.reduced {
    height: 60px; /* gleiche Höhe wie dein reduced Header */
}

#wrapper.reduced { } 
.m_inner.reduced {	} 

#topmenubox.reduced {
    background: rgba(14,35,45,0.85);
    backdrop-filter: blur(10px);
}

/* Search Box in header */
li.search_box_li a {border: none ! important;}

.menuebox {width: 75%; height:100%; float:left; position:relative;} 
.toggleMobileMenu {display:none;}
#openrightboxswitch, #closerightboxswitch{display:none;}

/* nav: see below */




/*~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  */
.breadcrumbs {
	height:30px;
	line-height:100%;
	margin: 0 0 0 0;
	padding: 3px 0 3px 0;
	clear:both;	
}

.innerbc {
	font-size:14px;
	margin:10px 0 0 25%;
	XXwidth: 450px;
}

.breadcrumbs .innerbc span {
	background: transparent url(img/bclink.gif) no-repeat; 
	padding: 6px 2px 0px 12px; font-weight: normal; }
	
.breadcrumbs .innerbc a {
	padding:1px;
	border-bottom: 0px dotted #505567;
	text-decoration: none;
}
.breadcrumbs .innerbc a:hover {border-bottom: 0px solid #505567;}
	
.breadcrumbs .innerbc .menu-current a{
	color: #000000;
}


.frontpage .breadcrumbs {display:none;}

#aprevnext {display:block; width:90px; height:27px; float:right;}
#aprevnext a {display:block; width:40px; height:27px; float:right; opacity:0.5; border:none;}
#aprevnext a.aprev {background: url(img/prev.png) no-repeat center top;  }
#aprevnext a.anext {background: url(img/next.png) no-repeat center top;  }
#aprevnext a:hover {opacity:0.8}

/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ 
	####	Header Menu #####
	#######################

	Horizontal Drop-Down Menu based off :
	http://www.tanfa.co.uk/css/examples/menu/tutorial-h.asp
	
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~  */
/* =========================
   MODERN NAVIGATION
========================= */

#nav {
    position: absolute;
    right: 20px;
    top: 50%;
    transform: translateY(-50%);
    font-family: -apple-system,  BlinkMacSystemFont,  "Segoe UI",  Roboto, Arial,  sans-serif;
    font-size: 1.2em;
}

/* RESET + FLEX */
#nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    gap: 30px;
    background: transparent;
}

#nav ul li {
    position: relative;
}

/* LINKS */
#nav ul li a {
    position: relative;
    display: inline-block;
    color: #fff;
    text-decoration: none;
    padding: 12px 0;
    letter-spacing: 1px;
    transition: all 0.5s ease;
}

/* falls WBCE span nutzt */
#nav ul li a span {
    display: inline-block;
}

/* =========================
   HOVER ANIMATION
========================= */

#nav ul li a::after {
    content: "";
    position: absolute;
    left: 0;
    bottom: 0;
    width: 0%;
    height: 2px;
    background: #00a0ff;
    transition: width 0.35s ease;
}

#nav ul li a:hover::after {
    width: 100%;
}

/* optional leichter Glow */
#nav ul li a::after {
    box-shadow: 0 0 8px rgba(0,160,255,0.6);
}

/* =========================
   CURRENT PAGE
========================= */

#nav a.menu-current::after {
    width: 100%;
    background: #ffffff;
}

#nav a.menu-current {
    background: none !important;
    color: #fff;
}

/* =========================
   DROPDOWN BASE
========================= */

#nav li ul {
    position: absolute;
    top: 100%;
    left: 0;
    width: 220px;

    background: rgba(20,20,20,0.95);
    backdrop-filter: blur(10px);

    border-radius: 12px;
    padding: 10px 0;

    opacity: 0;
    transform: translateY(10px);
    pointer-events: none;

    transition: all 0.3s ease;
    z-index: 1000;
}

/* SHOW DROPDOWN */
#nav li:hover > ul {
    opacity: 1;
    transform: translateY(0);
    pointer-events: auto;
}

/* DROPDOWN ITEMS */
#nav li ul li {
    width: 100%;
}

#nav li ul li a {
    display: block;
    padding: 10px 20px;
    font-size: 14px;
    color: #ccc;
    transition: all 0.25s ease;
}

/* DROPDOWN HOVER */
#nav li ul li a:hover {
    color: #fff;
    background: rgba(255,255,255,0.05);
}

/* keine underline animation im dropdown */
#nav li ul li a::after {
    display: none;
}

/* =========================
   SUBMENU (3rd level)
========================= */

#nav ul ul ul {
    top: 0;
    left: 100%;
}

/* =========================
   FIXES
========================= */

/* entfernt alte float styles */
#nav ul li {
    float: none !important;
    display: block;
}

/* verhindert alte styles */
#nav ul,
#nav ul li,
#nav ul li a {
    border: none !important;
    background: none !important;
}

/* end menu */
/* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ */

#footer_menu {padding-bottom: 10px;}
#footer_menu a { display: inline-block; padding: 2px 10px; border-right: 1px solid #999; font-size: 1.4em; font-family: -apple-system,  BlinkMacSystemFont,  "Segoe UI",  Roboto, Arial,  sans-serif; color: #ffffff}
#footer_menu a:first-child {border-left: 1px solid #999;}
#footer_menu a.menu-current {font-weight:bold;}

	
	/*Extra cookie_permission */
#cookie_permission {position:fixed; top:50; left:50; z-index:999; width: 200px; padding:10px; background: #555; text-align:center; font-size: 0.9em; line-height:120%; border-radius: 0 0 0 25px; box-shadow: 0 10px 50px 0 rgba(0, 0, 0, 0.2); }
#cookie_permission p , #cookie_permission a {color:#fff;}
#cookie_permission a.cookieaccepted {color:#000; background: #eeb300; display:block; padding:5px; border-radius: 15px; border: 1px solid #fff; font-weight:bold;}



#gototopswitch {float:right; margin:10px 0 0 0;}

/* Login Box */

#showlogin {display:block; float:left; position:relative;  width:30px; text-align:right; margin:10px 6px 0 0; }
#login-box {position:absolute; width:250px; left:10px; top:-10px; padding:5px; font-size:11px; z-index:2000; background: #eee; box-shadow: 0 5px 20px 0 rgba(0, 0, 0, 0.2);}
#login-box td {vertical-align: top; }
#login-box .loginsubmit {border:0;}
#login-box .inputfield {width:100px; border: 1px solid #c9e8f9; padding:1px; line-height: 1em;}

.showonmobiles  {display:none;}

/* ====================================================================================================================
Responsive:
*/
@media screen and (min-width: 1200px) {
	.XXwrapper  {background-position: center -120px;}
}

@media screen and (min-width: 1025px) {
	
}


/*Smaller Screens */
@media screen and (max-width: 1500px) {
	.wrapper,  .mainbox, #topmenubox .m_inner  {width:100%; margin: 0 auto;}
	.XXtopheader {background-size: 100% auto;}
	
}

/*Smaller Screens */
@media screen and (max-width: 1024px) {
	
	XXbody {font-size: 1em;}
	
	body {background-image:none; font-size: 0.8em; } 
#topmenubox a.logo img { max-width: 70%; position: absolute; left: 2%; top: 2%; height: 76px;}
#topmenubox.reduced .m_inner.reduced { height:60px; top: 4px !important; transition: 0.5s all;
background-color: none; } 


	#wrapper { width: 96%;  margin-top: 0px;  }
	.container {padding-top: 2px;}		
	.mainbox .contentwide  {width:100%; margin:10px 0 0 0;}
	#rightbox { width: 33%;}
	#rightbox .inner { margin: 0 5% 0 5%;}
	
	#topmenubox #nav {display:none;}

    
			
/* Ersetze den bestehenden .toggleMobileMenu Block durch diesen: */
.toggleMobileMenu {
    display: block;
    float: right;
    width: 40px;
    height: 40px;
    margin: 10px 4% 0 0;
    position: relative;
    cursor: pointer;
    background: none !important;
    outline: none; /* Entfernt blaue Umrandung beim Klick */
    -webkit-tap-highlight-color: transparent; /* Entfernt blauen Flash auf Mobilgeräten */
}

.toggleMobileMenu::before,
.toggleMobileMenu::after {
    content: "";
    position: absolute;
    left: 8px;
    width: 24px;
    height: 3px;
    background: #ffffff;
    border-radius: 2px;
    transition: all 0.3s ease;
}

.toggleMobileMenu::before { top: 12px; }
.toggleMobileMenu span.menu-bar { top: 19px; } /* Die mittlere Linie */
.toggleMobileMenu::after { top: 26px; }

/* OPTIONAL: Animation zum 'X' wenn offen */
.mobilemenuopen .toggleMobileMenu::before { transform: translateY(7px) rotate(45deg); }
.mobilemenuopen .toggleMobileMenu span.menu-bar { opacity: 0; }
.mobilemenuopen .toggleMobileMenu::after { transform: translateY(-7px) rotate(-45deg); }	
	.topspacer {padding-top: 0px;  }	
	#XXtopparallax {padding-top: 0%; width:100%; position:relative; }


#logo-video { 
    width: 100px; max-width: 60%;
}
	
	/*Nav*/
	
	.breadcrumbs { height:0px; }
	
	#nav2 {
    background: rgba(10, 20, 30, 0.92);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
}


    #nav2 li {width:100%;  padding: 0 0 0 0;  }
	#nav2 li a {
    display: block;
    padding: 16px 20px;
    font-size: 20px;
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,0.08);
	#nav2 li a.menu-current {
    position: relative;
}

#nav2 li a.menu-current::after {
    content: "";
    position: absolute;
    left: 20px;
    bottom: 8px;
    width: 30px;
    height: 2px;
    background: #00a0ff;
}
}

    transition: all 0.25s ease;
}
	#nav2 li li a {padding: 10px 0 10px 30px; font-size:14px;  }
	#nav2 li li li a {padding: 8px 0 8px 40px; font-size:14px; }
	#nav2 li li li li a {padding: 6px 0 6px 50px; font-size:13px; ;}
	
	#nav2 li ul {display:none;}
	#nav2 li.menu-parent > ul, #nav2 li.menu-current > ul {display:block;}
	#nav2 li.is_opened > ul, #nav2 li.is_opened > ul {display:block;}
	
	#nav2 li a.menu-expand {
    background: none;
}
	#nav2 li a.menu-current { color:#fff; border-top: 1px solid #fff;  }
	
	#nav2 ul li a.menu-expand.is_opened, #nav2 ul li a.menu-parent {font-weight:bold; background: #ddd url(img/arr-right.png) no-repeat 2px center ; }
	#nav2close {
    display: none;
    pointer-events: none !important;
}

	#nav2 ul,
#nav2 li {
    list-style: none;
    margin: 0;
    padding: 0;
}
	.topheader { background: none; background-size: 100% auto; height: 100px;  } 
	
	.breadcrumbs { display:none; }
	.innerbc { margin: 2px 0 5px 2%; width: 96%; }
	.innerbc span  {display: block; float:left; padding: 2px 2px 2px 12px; margin: 0 0 5px 0;}
	.innerbc b  {display: none;}
	
	.mobilemenuopen  #nav2 {left:0;  }

	.mobilemenuopen #nav2close {display:block;} 

	#nav2close {
    position: fixed;
    top: 0;
    left: 0;
    width: 60px;
    height: 60px;
    z-index: 9999;

    /* wichtig */
    margin: 0 !important;
}
.mobilemenuopen #nav2close {
    display: block; 
    pointer-events: none; /* verhindert Blockieren */
}
	 
	h1 { 
		font-size: 1em;
		font-weight: 400;	
	}
	
	h2 { 
		font-size: 1.2em;
		font-weight: 400;
	}
	
	h3 { 
		font-size: 1.1em;	
	}
	
	h4 {	
		font-size: 0.9em;	
	}
	
	h5 {
		font-size: 0.85em;	
	}
	
	h6 {
		font-size: 0.8em	
	}
	
	
}


/* ======================================================================
Smaller Screens SMARTPHONES */
@media screen and (max-width: 1024px) {

  
	.XXfrontpage .wrapper  {background-position: center top;}
	
	.topheader { background: none; background-size: auto 100%; height: 140px; } 
	
	#topparallax {width:100%; position:relative;   }

	#topparallax .ptext { display:none; }
	#topparallax a.topdown {display:none; }
	
	
	#topparallax p {line-height:120%;}

/**** VIDEO STARTSEITE MOBIL ****/

    #hero-video {
        height: auto;
        overflow: hidden;
    }

    #hero-video video {
        position: relative !important;
        top: auto !important;
        left: 50%;
        transform: translateX(-50%) !important;

        width: 120%;
        height: auto !important;
        object-fit: unset !important;

        display: block;
    }
}

/* ======================================================================
Smaller Screens */
@media screen and (max-width: 480px) {
	#topparallax .ptext {bottom:0; width:100%; position:relative; }
	.topheader p { font-size:1.4em; }

    #hero-video {
        height: auto;
        overflow: hidden;
    }

    #hero-video video {
        position: relative !important;
        top: auto !important;
        left: 50%;
        transform: translateX(-50%) !important;

        width: 220%;
        height: auto !important;
        object-fit: unset !important;

        display: block;
    }

    .mainbox .contentwide  {width:100%; margin: 20px 0 0 0;}


}



/***** CSS VON CHAT GPT ****/

/* TITLES */
.cinematic-title {
    text-align: center;
    font-size: 25px;
    font-weight: 400;
    color: #f7f7f7;
    margin: 70px 0 25px 0;
    letter-spacing: 1.5px;
    opacity: 0;
    transform: translateY(18px);
    filter: blur(6px);
    transition: all 0.9s ease;
}
.cinematic-title.show {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}
.cinematic-title::after {
    content: "";
    display: block;
    width: 60px;
    height: 1px;
    background: rgba(232,230,225,0.35);
    margin: 12px auto 0 auto;
}

/* SERVICES */
.services {
    width: 90%;
    max-width: 1100px;
    margin: 20px auto;
    display: grid;
    grid-template-columns: repeat(3,1fr);
    gap: 25px;
}
.service-card {
    position: relative;
    padding: 28px 22px;
    border-radius: 16px;
    background: rgba(236,231,220,0.03);
    border: 1px solid rgba(236,231,220,0.15);
    text-align: center;
    cursor: default;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.6s ease;
    overflow: hidden;
}
.service-card.show {
    opacity: 1;
    transform: translateY(0);
}
.service-icon {
    width: 60px;
    height: 60px;
    object-fit: contain;
    margin: 0 auto 12px auto;
    transition: transform 0.4s ease;
filter: grayscale(100%) brightness(1.15);
}
.service-card:hover .service-icon {
    transform: scale(1.12);
}
.service-card h2 {
    font-size: 20px;
    font-weight: 700;
    margin-bottom: 10px;
    color: #cacbbe;   
}
.service-card p {
    font-size: 14px;
    line-height: 1.6;
    color: #e8e6e1;   
}
.service-card::before {
    content: "";
    position: absolute;
    inset: -40%;
    background: radial-gradient(circle at var(--x,50%) var(--y,50%),
 rgba(0,160,255,0.18),
 transparent 55%);
    opacity: 0;
    filter: blur(18px);
    transition: opacity 0.4s ease;
}
.service-card:hover::before {
    opacity: 1;
}
.service-card:hover {
    transform: translateY(-8px) scale(1.02);
    border-color: rgba(0,160,255,0.35);
    box-shadow: 0 20px 50px rgba(0,0,0,0.55);
}

/* VIDEO */
.containervideo {
    display: flex;
    justify-content: center;
    margin: 45px 0;
    opacity: 0;
    transform: translateY(60px);
    transition: all 0.8s ease;
}
.containervideo.show {
    opacity: 1;
    transform: translateY(0);
}
.video-box {
    position: relative;
    display: inline-block;
    border-radius: 18px;
    padding: 1px;
    background: linear-gradient(120deg,#ece7dc,#d4cdbd,#ece7dc);
    background-size: 200% 200%;
    animation: frameMove 10s ease infinite;
    max-width: 550px;
    width: 92%;
    cursor: pointer;
}
@keyframes frameMove {
    0% { background-position: 0% 50%; }
    50% { background-position: 100% 50%; }
    100% { background-position: 0% 50%; }
}

.video-wrapper {
    position: relative;
    width: 100%;
    border-radius: 16px;
    overflow: hidden;
    background: #000;
}

.video-wrapper video {
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
    border-radius: 16px;
    background: #000;
    transition: transform 0.5s ease, filter 0.5s ease;
    object-fit: cover;
    display: block;
}

.video-box:hover video {
    transform: scale(1.045);
    filter: brightness(1.1) contrast(1.15);
}

/* POPUP */
.popup-video {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    display: none;
    justify-content: center;
    align-items: center;
    padding: 40px;
}
.popup-video video {
    max-width: 75vw;
    max-height: 70vh;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.35);
    box-shadow: 0 10px 30px rgba(0,0,0,0.25),
 0 0 25px rgba(255,255,255,0.12);
}
.popup-video span {
    position: absolute;
    top: 25px;
    right: 35px;
    font-size: 50px;
    color: white;
    cursor: pointer;
}

@media (max-width: 900px) {
    .services {
        grid-template-columns: repeat(2, 1fr);
        gap: 14px;
        width: 92%;
    }

    .service-card {
        padding: 18px 12px;
    }

    .service-icon {
        width: 42px;
        height: 42px;
        margin-bottom: 10px;
    }

    .service-card h2 {
        font-size: 13px;
        margin-bottom: 6px;
    }

    .service-card p {
        font-size: 12px;
        line-height: 1.45;
    }

    .video-box {
        max-width: 92%;
    }
.drone-title {
    font-size: 11px !important;
    line-height: 1.2;
   }
}

/* Linien NUR im echten Button anzeigen */
.toggleMobileMenu::before,
.toggleMobileMenu::after {
    content: "";
}

/* VERHINDERT doppelte Anzeige im geöffneten Zustand */
.mobilemenuopen .toggleMobileMenu::before,
.mobilemenuopen .toggleMobileMenu::after {
    display: block;
}

/* GANZ WICHTIG: keine Linien in anderen Elementen */
#nav2::before,
#nav2::after,
#nav2close::before,
#nav2close::after {
    display: none !important;
    content: none !important;
}

/** LEISTUNGEN ***/


/* =========================
   GRID
   ========================= */
.services-grid {
    width: 90%;
    max-width: 1100px;
    margin: 0 auto 120px auto;
    display: grid;
    grid-template-columns: repeat(2,
 1fr);
    gap: 30px;
}

/* =========================
   SERVICE BOX
   ========================= */
.service-box {
    position: relative;
    border-radius: 16px;
    overflow: hidden;

    background: rgba(236,231,220,0.03);
    border: 1px solid rgba(236,231,220,0.15);

    transform: translateY(30px);
    opacity: 0;
    transition:
        transform 0.7s cubic-bezier(.22,1,.36,1),
        opacity 0.7s ease,
        box-shadow 0.4s ease,
        border-color 0.4s ease;

    cursor: pointer;
}

.service-box.show {
    transform: translateY(0);
    opacity: 1;
}

.service-box img,
.service-box video {
    width: 100%;
    height: 240px;
    object-fit: cover;
    display: block;

    transition: transform 0.7s cubic-bezier(.22,1,.36,1),
                filter 0.7s ease;
}

/* CONTENT */
.service-content {
    padding: 20px;
}

.service-content h2 {
    margin: 0 0 10px 0;
    font-size: 20px;
    color: #ece7dc;
    text-transform: uppercase;
    letter-spacing: 1px;
}

.service-content p {
    font-size: 14px;
    line-height: 1.6;
    color: #cfcac2;
    text-transform: none;
}

/* HOVER + MOUSE EFFECT */
.service-box:hover {
    transform: translateY(-12px) scale(1.02);
    border-color: rgba(147,136,124,0.45);
    box-shadow:
        0 28px 65px rgba(0,0,0,0.65),
        0 0 22px rgba(0,160,255,0.10),
        0 0 55px rgba(0,160,255,0.06);
}

.service-box:hover img,
.service-box:hover video {
    transform: scale(1.07);
    filter: brightness(1.12) contrast(1.05);
}

.service-box::after {
    content: "";
    position: absolute;
    inset: 0;
    background: radial-gradient(
        circle at var(--x,50%) var(--y,50%),
        rgba(0,160,255,0.22),
        transparent 60%
    );
    opacity: 0;
    transition: opacity 0.35s ease;
    pointer-events: none;
}

.service-box:hover::after {
    opacity: 1;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 30px;
}

@media (max-width: 800px) {
    .services-grid {
        grid-template-columns: 1fr !important;
    }
}
/* =========================
   POPUP (SMALLER + SOFTER)
   ========================= */
.popup {
    position: fixed;
    inset: 0;
    display: none;
    justify-content: center;
    align-items: center;
    background: rgba(0,0,0,0.65);
    backdrop-filter: blur(14px);
    z-index: 9999;
}

/* softer glow */
.popup::before {
    content: "";
    position: absolute;
    inset: -25%;
    pointer-events: none;

    background: radial-gradient(
        circle at 50% 50%,
        rgba(0,160,255,0.18),
        transparent 65%
    );

    filter: blur(70px);
    opacity: 0.8;
}

/* ???? SMALLER POPUP */
.popup-content {
    position: relative;
    width: 85%;
    max-width: 620px;
    background: #111;
    border-radius: 16px;
    overflow: hidden;
    animation: popIn 0.35s ease;

    box-shadow:
        0 25px 70px rgba(0,0,0,0.75),
        0 0 25px rgba(0,160,255,0.12),
        0 0 60px rgba(0,160,255,0.06);
}

@keyframes popIn {
    from { opacity: 0; transform: scale(0.95); }
    to { opacity: 1; transform: scale(1); }
}

.popup-content {
    max-height: 80vh;
    overflow-y: auto;
}

.popup-media img,
.popup-media video {
    width: 100%;
    display: block;
}

/* TEXT POPUP */
.popup-text {
    padding: 20px;
    text-align: center;
}

.popup-text h2 {
    margin-top: 0;
    margin-bottom: 15px;
    text-transform: none;
}

.popup-text p {
    line-height: 1.7;
    color: #cfcac2;
    white-space: pre-line;
    text-transform: none;
}

/* CLOSE */
.close-btn {
    position: absolute;
    top: 12px;
    right: 18px;
    font-size: 38px;
    color: white;
    cursor: pointer;
    z-index: 10000;
}

/* RESPONSIVE */
@media (max-width: 800px) {
    .services-grid {
        grid-template-columns: 1fr;
    }
}
/* Korrektur für Cinematic Titles auf mobilen Geräten */
@media screen and (max-width: 1024px) {
    .cinematic-title {
        font-size: 18px !important; /* Deutlich kleiner als die Standard 25px */
        margin: 40px 0 15px 0 !important; /* Weniger Abstand oben/unten auf dem Handy */
        letter-spacing: 1px !important;
    }

    .cinematic-title::after {
        width: 40px !important; /* Auch die Linie unter dem Titel wird kürzer */
    }
}

/* =========================
   PROJEKTE SEITE
========================= */

.projects {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 60px;
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}

.project {
    width: 100%;
    text-align: center;
    opacity: 0;
    transform: translateY(60px);
    transition: all 0.8s ease;
}

.project.show {
    opacity: 1;
    transform: translateY(0);
}

.caption {
    margin-top: 18px;
    color: #d6d2ca;
    font-size: 17px;
    text-transform: none;
}

/* Popup bleibt erhalten */
.popup-video {
    position: fixed;
    inset: 0;
    z-index: 9999;
    background: rgba(255,255,255,0.08);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    display: none;
    justify-content: center;
    align-items: center;
    padding: 40px;
    box-sizing: border-box;
}

.popup-video video {
    max-width: 75vw;
    max-height: 70vh;
    object-fit: contain;
    border-radius: 14px;
    border: 1px solid rgba(255,255,255,0.35);
    box-shadow:
        0 0 0 1px rgba(255,255,255,0.15),
        0 10px 30px rgba(0,0,0,0.25),
        0 0 25px rgba(255,255,255,0.12);
    background: #000;
}

.popup-video span {
    position: absolute;
    top: 25px;
    right: 35px;
    font-size: 50px;
    color: white;
    cursor: pointer;
}

@media (max-width: 768px) {
    .projects {
        grid-template-columns: 1fr;
        gap: 30px;
    }

    .caption {
        font-size: 14px;
        margin-top: 12px;
        line-height: 1.4;
    }
}

/* =========================
   KONTAKTSEITE
========================= */

.contact-subtitle {
    text-align: center;
    font-size: 15px;
    color: #cfcac2;
    max-width: 700px;
    margin: 0 auto 50px auto;
    line-height: 1.6;
    text-transform: none;
    opacity: 0;
    transform: translateY(20px);
    transition: all 0.8s ease;
}

.contact-subtitle.show {
    opacity: 1;
    transform: translateY(0);
}

.contact-links {
    width: 90%;
    max-width: 900px;
    margin: 0 auto 40px auto;
    display: flex;
    flex-direction: column;
    gap: 12px;
    opacity: 0;
    transform: translateY(30px);
    transition: all 0.8s ease;
}

.contact-links.show {
    opacity: 1;
    transform: translateY(0);
}

.contact-card {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 14px 18px;
    border-radius: 12px;
    background: rgba(0,160,255,0.06);
    border: 1px solid rgba(0,160,255,0.22);
    text-decoration: none;
    color: #f5f3ee;
    transition: all 0.35s ease;
    text-transform: none;
}
.contact-card span {
    color: #ece7dc !important;
}

.contact-card:hover span {
    color: #ffffff !important;
}

.contact-card:hover {
    transform: translateY(-6px);
    background: rgba(0,160,255,0.12);
    border-color: rgba(0,160,255,0.45);
    box-shadow: 0 0 25px rgba(0,160,255,0.25);
}

.contact-card img {
    width: 20px;
    height: 20px;
}

.contact-wrapper {
    width: 90%;
    max-width: 1000px;
    margin: 0 auto 120px auto;

    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 25px;
    align-items: start;

    opacity: 0;
    transform: translateY(40px);
    transition: all 0.8s ease;
}
.contact-wrapper.show {
    opacity: 1;
    transform: translateY(0);
}

.contact-wrapper form {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 22px;
    background: rgba(0,160,255,0.06);
    border: 1px solid rgba(0,160,255,0.22);
    border-radius: 14px;
    box-shadow: 0 0 18px rgba(0,160,255,0.10);
    text-transform: none;
}

.contact-wrapper input,
.contact-wrapper textarea {
    background: rgba(255,255,255,0.04);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 10px;
    padding: 12px;
    color: #e8e6e1;
    font-size: 14px;
    outline: none;
    text-transform: none;
}

.contact-wrapper textarea {
    min-height: 140px;
    resize: vertical;
}

.contact-wrapper input:focus,
.contact-wrapper textarea:focus {
    border-color: rgba(0,160,255,0.5);
}

.contact-wrapper button {
    padding: 12px;
    border-radius: 10px;
    border: none;
    background: rgba(0,160,255,0.18);
    color: #7ecbff;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    text-transform: none;
}

.contact-wrapper button:hover {
    background: rgba(0,160,255,0.28);
    transform: translateY(-3px);
}

.info-box {
    padding: 22px;
    border-radius: 14px;
    background: rgba(0,160,255,0.04);
    border: 1px solid rgba(0,160,255,0.15);
    color: #cfcac2;
    line-height: 1.6;
    text-transform: none;
}
.info-box{
    opacity:0;
    transform:translateY(30px);
    transition:all .8s ease;
}

.info-box.show{
    opacity:1;
    transform:translateY(0);
}
.info-box strong {
    color: #e3dccf;
}

@media (max-width: 800px) {
    .contact-wrapper {
        grid-template-columns: 1fr;
    }
}

/* =========================
   PERFECT CUSTOMER LOGO LOOP
========================= */

.logo-marquee {
    position: relative;
    left: 50%;
    right: 50%;
    margin-left: -50vw;
    margin-right: -50vw;

    width: 100vw;
    max-width: 100vw;

    overflow: hidden;
    display: flex;

    padding: 6px 0 18px 0;
    margin-top: -30px;

    box-sizing: border-box;
}

.logo-track {
    display: flex;
    align-items: center;
    flex-shrink: 0;
    width: max-content;

    animation: logoLoop 24s linear infinite;
}

/* Jede Logo-Position gleich breit */
.logo-track img {
    width: 180px;
    height: 100px;
    object-fit: contain;
    flex: 0 0 160px;

    margin-right: 30px;

    opacity: 0.9;
    filter: grayscale(100%) brightness(1.2);
    transition: all 0.3s ease;
}

.logo-track img[src*="Sigiltra_Soegel"] {
    width: 135px;
    height: 60px;
    flex: 0 0 135px;
}

.logo-track img[src*="Waldbuehne_Ahmsen"] {
    width: 180px;
    height: 90px;
    flex: 0 0 180px;
}

.logo-track img {
    transition: all 0.35s ease;
}

.logo-track img:hover {
    opacity: 1;
    filter: grayscale(0%) brightness(1.15);
    transform: translateY(-4px) scale(1.12);
}

@keyframes logoLoop {
    from {
        transform: translateX(0);
    }
    to {
        transform: translateX(calc(-100%));
    }
}

/* Mobile */
@media (max-width: 768px) {
    .logo-track img {
        width: 160px;
        height: 80px;
        flex: 0 0 110px;
        margin-right: 18px;
    }

    .logo-track {
        animation-duration: 18s;
    }
.logo-marquee {
        padding: 0px 0 18px 0;
        margin-top: 0;
    }
}
body.body10 .logo-marquee {
    margin-top: 40px;
}
/* =========================
   DANKESEITE FIX
========================= */

.thankyou-wrapper{
    margin-bottom:120px;
}

.thankyou-actions{
    display:flex;
    flex-direction:column;
    gap:12px;
}

.thankyou-actions .contact-card{
    justify-content:center;
}
/* =========================
   IMPRESSUM / LEGAL
========================= */

.legal-box{
    width:90%;
    max-width:900px;
    margin:0 auto 120px auto;
    padding:32px;

    border-radius:16px;
    background: rgba(0,160,255,0.04);
    border:1px solid rgba(0,160,255,0.16);

    box-shadow:
        0 18px 55px rgba(0,0,0,0.35),
        0 0 24px rgba(0,160,255,0.06);

    opacity:0;
    transform:translateY(35px);
    transition:all .9s ease;
}

.legal-box.show{
    opacity:1;
    transform:translateY(0);
}

.legal-section{
    padding:0 0 24px 0;
    margin:0 0 24px 0;
    border-bottom:1px solid rgba(255,255,255,0.06);
}

.legal-section:last-child{
    margin-bottom:0;
    padding-bottom:0;
    border-bottom:none;
}

.legal-section h2{
    font-size:18px;
    color:#ffffff;
    margin:0 0 12px 0;
    text-transform:none;
}

.legal-section p{
    margin:0;
    font-size:15px;
    line-height:1.8;
    color:#cfcac2;
    text-transform:none;
}

.legal-section a{
    color:#7ecbff;
    text-decoration:none;
    transition:all .25s ease;
}

.legal-section a:hover{
    color:#ffffff;
    text-shadow:0 0 12px rgba(0,160,255,0.35);
}

@media (max-width:768px){

    .legal-box{
        padding:22px 18px;
        margin:0 auto 70px auto;
    }

    .legal-section h2{
        font-size:16px;
    }

    .legal-section p{
        font-size:14px;
        line-height:1.7;
    }
}
/* =========================
   DATENSCHUTZ / PRIVACY
========================= */

.privacy-box{
    width:90%;
    max-width:900px;
    margin:0 auto 120px auto;
    padding:32px;

    border-radius:16px;
    background: rgba(0,160,255,0.04);
    border:1px solid rgba(0,160,255,0.16);

    box-shadow:
        0 18px 55px rgba(0,0,0,0.35),
        0 0 24px rgba(0,160,255,0.06);

    opacity:0;
    transform:translateY(35px);
    transition:all .9s ease;
}

.privacy-box.show{
    opacity:1;
    transform:translateY(0);
}

.privacy-section{
    padding:0 0 24px 0;
    margin:0 0 24px 0;
    border-bottom:1px solid rgba(255,255,255,0.06);
}

.privacy-section:last-child{
    margin-bottom:0;
    padding-bottom:0;
    border-bottom:none;
}

.privacy-section h2{
    font-size:18px;
    color:#ffffff;
    margin:0 0 12px 0;
    text-transform:none;
}

.privacy-section p{
    margin:0;
    font-size:15px;
    line-height:1.8;
    color:#cfcac2;
    text-transform:none;
}

.privacy-section a{
    color:#7ecbff;
    text-decoration:none;
    transition:all .25s ease;
}

.privacy-section a:hover{
    color:#ffffff;
    text-shadow:0 0 12px rgba(0,160,255,0.35);
}

@media (max-width:768px){

    .privacy-box{
        padding:22px 18px;
        margin:0 auto 70px auto;
    }

    .privacy-section h2{
        font-size:16px;
    }

    .privacy-section p{
        font-size:14px;
        line-height:1.7;
    }
}
/* =========================
   COUNTER PREMIUM FINISH
========================= */

.stat-box.done{
    animation: statFinish 1s cubic-bezier(.22,1,.36,1);
    position: relative;
    overflow: hidden;
}

@keyframes statFinish{
    0%{
        transform: scale(1);
        box-shadow: 0 0 0 rgba(0,160,255,0);
    }

    35%{
        transform: translateY(-8px) scale(1.06);
        box-shadow:
            0 0 25px rgba(0,160,255,0.28),
            0 0 55px rgba(0,160,255,0.12);
    }

    100%{
        transform: translateY(0) scale(1);
    }
}
/* =========================
   COUNTER PREMIUM FINISH
========================= */

.stat-box.done{
    animation: statFinish 1s cubic-bezier(.22,1,.36,1);
    position: relative;
    overflow: hidden;
}

@keyframes statFinish{
    0%{
        transform: scale(1);
        box-shadow: 0 0 0 rgba(0,160,255,0);
    }

    35%{
        transform: translateY(-8px) scale(1.06);
        box-shadow:
            0 0 25px rgba(0,160,255,0.28),
            0 0 55px rgba(0,160,255,0.12);
    }

    100%{
        transform: translateY(0) scale(1);
    }
}

/* Shine Sweep */
.stat-box.done::after{
    content:"";
    position:absolute;
    top:0;
    left:-120%;
    width:60%;
    height:100%;

    background: linear-gradient(
        110deg,
        transparent,
        rgba(255,255,255,0.28),
        transparent
    );

    transform: skewX(-20deg);
    animation: shineMove 1.1s ease;
}

@keyframes shineMove{
    to{
        left:160%;
    }
}
/* ==================================================
   NEW MOBILE MENU CLEAN VERSION
================================================== */
@media screen and (max-width:1024px){

  /* Menüpanel */
	
  #nav2{
    position: fixed !important;
    top: 50% !important;
	transform: translateX(-115%) translateY(-50%) scale(0.92);
    left: 0;
    width: 100%;
    max-height: 90vh;
	overflow-y: auto;
    background: rgba(8,18,28,0.58);
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	box-shadow:   	0 10px 35px rgba(0,0,0,0.45),   	0 0 35px rgba(0,160,255,0.18), 	0 0 70px rgba(0,160,255,0.12);
  	margin-top: 0 !important;
    box-sizing: border-box;
    overflow-y: auto;
    z-index: 9998;
	opacity: 0;
	filter: blur(8px);
	transition: transform .65s cubic-bezier(.19,1,.22,1),    opacity .55s ease,   filter .65s ease;
  }

  /* geöffnet */
  .mobilemenuopen #nav2{
   transform: translateX(0) translateY(-50%) scale(1);
   opacity: 1;
   filter: blur(0);
   pointer-events: auto;
}


  /* Listen reset */
	#nav2 ul { 
    list-style: none;
    margin:  0;
    padding: 10px;
  }

	#nav2 li { margin-top: 10px;  }
  #nav2 ul{
    display: block;
  }

 
  /* Hauptlinks */
  #nav2 li a{
    display: block;
    width: 100%;
    padding: 16px 18px;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 1px;
    text-transform: uppercase;

    color: #ffffff;
    text-decoration: none;

    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 14px;

    transition: all .25s ease;
    box-sizing: border-box;
  }

  /* Hover / Klick */
  #nav2 li a:hover,
  #nav2 li a:active{
    background: rgba(0,160,255,0.12);
    border-color: rgba(0,160,255,0.35);
    transform: translateX(4px);
  }

  /* aktive Seite */
  #nav2 li a.menu-current{
    border-color: rgba(255,255,255,0.35);
    background: rgba(255,255,255,0.06);
  }

  /* Untermenüs */
  #nav2 li ul{
    margin-top: 8px;
  }

  #nav2 li li a{
    padding-left: 30px;
    font-size: 16px;
  }

  #nav2 li li li a{
    padding-left: 42px;
    font-size: 15px;
  }

  /* Seite scrollt nicht wenn Menü offen */
  body.mobilemenuopen{
    overflow: hidden;
  }

}
/* =========================
   ABOUT PAGE
========================= */

.about-container{
    width:90%;
    max-width:1100px;
    margin:0 auto 120px auto;
    display:grid;
    grid-template-columns:0.9fr 1.1fr;
    gap:50px;
    align-items:start;
    opacity:0;
    transform:translateY(40px);
    transition:all .8s ease;
}

.about-container.show{
    opacity:1;
    transform:translateY(0);
}

.about-image{
    display:flex;
    justify-content:center;
}

.about-image img{
    width:85%;
    max-width:360px;
    border-radius:16px;
    object-fit:cover;
    border:1px solid rgba(236,231,220,0.15);

    box-shadow:
      0 0 18px rgba(0,160,255,0.25),
      0 0 40px rgba(0,160,255,0.12),
      0 25px 70px rgba(0,0,0,0.6);

    transition:all .5s ease;
}

.about-image img:hover{
    transform:scale(1.04) translateY(-6px);
}

.about-text p{
    font-size:15px;
    line-height:1.55;
    color:#cfcac2;
    margin-bottom:10px;
    text-transform:none;
}

.stats{
    margin-top:18px;
    display:flex;
    gap:12px;
    flex-wrap:wrap;
}

.stat-box{
    flex:1;
    min-width:140px;
    text-align:center;
    padding:14px 12px;
    border-radius:12px;
    background:rgba(0,160,255,0.08);
    border:1px solid rgba(0,160,255,0.25);
    box-shadow:0 0 18px rgba(0,160,255,0.12);
    transition:all .35s ease;
}

.stat-box:hover{
    transform:translateY(-6px) scale(1.03);
    background:rgba(0,160,255,0.14);
}

.stat-number{
    font-size:22px;
    font-weight:700;
    color:#7ecbff;
}

.stat-label{
    font-size:12px;
    color:#a9cfe8;
    margin-top:4px;
    text-transform:none;
}

.stat-box.done{
    animation:pop .5s ease;
}

@keyframes pop{
    0%{transform:scale(1);}
    50%{transform:scale(1.08);}
    100%{transform:scale(1);}
}

@media (max-width:900px){

    .about-container{
        grid-template-columns:1fr;
        text-align:center;
    }

    .stats{
        justify-content:center;
    }

}
/* =========================
FAQ PAGE
========================= */

.faq-page{
width:90%;
max-width:1100px;
margin:0 auto 120px auto;
}

.faq-hero{
    text-align:center;
    padding-top:0px;
    margin-bottom:45px;
}

.faq-kicker{
color:#00a0ff;
font-size:14px;
letter-spacing:2px;
margin-bottom:18px;
}

.faq-hero h1{
    font-size:40px;
    line-height:1.08;
    color:#ffffff;
    margin:18px 0 20px 0;
    text-transform:none;
    font-weight:700;
}

.faq-intro{
    max-width:700px;
    margin:0 auto;
    color:#cfcac2;
    font-size:16px;
    line-height:1.7;
    text-transform:none;
}

.faq-list{
display:flex;
flex-direction:column;
gap:14px;
}

.faq-item{
    border:1px solid rgba(0,160,255,0.14);
    border-radius:14px;
    background:rgba(0,160,255,0.03);
    overflow:hidden;
    transition:.35s ease;
position: relative;
isolation: isolate;

    box-shadow:
      0 0 16px rgba(0,160,255,0.05),
      0 10px 28px rgba(0,0,0,0.22);
}
.faq-item::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:14px;
    pointer-events:none;
    opacity:0;
    transition:opacity .45s ease, transform .45s ease;

    background:
      radial-gradient(circle at 20% 30%,
      rgba(255,255,255,0.08),
      transparent 35%),

      radial-gradient(circle at 80% 70%,
      rgba(0,160,255,0.12),
      transparent 40%);
}

.faq-item:hover{
    transform: translateY(-4px) scale(1.01);

    border-color: rgba(0,160,255,0.42);

    background: rgba(0,160,255,0.05);

    box-shadow:
        0 0 14px rgba(255,255,255,0.04),
        0 0 26px rgba(0,160,255,0.16),
        0 0 52px rgba(0,160,255,0.10),
        0 18px 40px rgba(0,0,0,0.28);
}
.faq-item:hover::before{
    opacity:1;
    transform:scale(1.04);
}
.faq-item:hover .faq-question{
    color:#ffffff;
    text-shadow:0 0 10px rgba(0,160,255,0.18);
    transform:translateX(4px);
}

.faq-question{
    width:100%;
    background:none;
    border:none;
    color:#ffffff;
    padding:18px;
    display:flex;
    align-items:center;
    gap:18px;
    cursor:pointer;
    font-size:17px;
    text-align:left;
    font-weight:600;
transition: transform .35s ease, color .35s ease, text-shadow .35s ease;
position: relative;
z-index: 2;
}

.faq-number{
color:#00a0ff;
font-size:18px;
min-width:35px;
}

.faq-icon{
margin-left:auto;
font-size:30px;
color:#d7e9ff;
}

.faq-answer{
    height:0;
    overflow:hidden;

    padding:0 22px 0 75px;

    opacity:0;
    transform:translateY(-6px);

    color:#cfcac2;
    font-size:15px;
    line-height:1.8;
    text-transform:none;

    transition:
        height .38s cubic-bezier(.4,0,.2,1),
        padding .28s ease,
        opacity .20s ease,
        transform .20s ease;
}

.faq-item.active .faq-answer{
    padding:0 22px 22px 75px;
    opacity:1;
    transform:translateY(0);
}

.faq-cta{
    margin-top:40px;
    padding:35px;
    border-radius:18px;
    border:1px solid rgba(0,160,255,0.14);
    background:rgba(0,160,255,0.03);

    box-shadow:
      0 0 22px rgba(0,160,255,0.06),
      0 20px 40px rgba(0,0,0,0.25);
}

.faq-cta h2{
font-size:38px;
color:#fff;
margin-bottom:12px;
text-transform:none;
}

.faq-cta p{
color:#c2ccd6;
font-size:18px;
margin-bottom:25px;
text-transform:none;
}

.faq-btn{
    display:inline-block;
    padding:14px 28px;

    border:1px solid rgba(0,160,255,0.35);
    border-radius:12px;

    color:#ece7dc !important;
    font-weight:700;
    letter-spacing:0.2px;
    text-decoration:none !important;

    background:rgba(255,255,255,0.02);

    text-shadow:0 0 10px rgba(255,255,255,0.10);

    transition:.3s ease;
}

.faq-btn:hover{
    color:#ffffff;
    background:rgba(0,160,255,0.12);
    box-shadow:0 0 20px rgba(0,160,255,0.2);
}

@media(max-width:768px){

.faq-hero h1{
font-size:38px;
}

.faq-question{
font-size:16px;
padding:18px;
}

.faq-answer{
font-size:14px;
}

.faq-item.active .faq-answer{
padding:0 18px 18px 18px;
}

.faq-cta h2{
font-size:28px;
}

.faq-cta p{
font-size:15px;
}
}
/* FAQ Scroll Animation Start */
.faq-hero,
.faq-item,
.faq-cta{
    opacity:0;
    transform:translateY(35px);
    transition:
        opacity .8s ease,
        transform .8s ease;
}

/* sichtbar */
.faq-hero.show,
.faq-item.show,
.faq-cta.show{
    opacity:1;
    transform:translateY(0);
}
.faq-item:nth-child(1){transition-delay:.05s;}
.faq-item:nth-child(2){transition-delay:.10s;}
.faq-item:nth-child(3){transition-delay:.15s;}
.faq-item:nth-child(4){transition-delay:.20s;}
.faq-item:nth-child(5){transition-delay:.25s;}

@media (max-width:768px){
  .faq-answer{
      padding:0 18px 0 18px;
  }

  .faq-item.active .faq-answer{
      padding:0 18px 18px 18px;
  }
}

}
/* ==================================================
   TRUST SECTION SMALLER
================================================== */

.trust-section{
    width:90%;
    max-width:1080px;
    margin:0 auto 180px auto;
}

/* HERO */

.trust-hero{
    text-align:center;
    max-width:680px;
    margin:0 auto 42px auto;
    opacity:0;
    transform:translateY(30px);
    transition:all .8s ease;
}

.trust-hero.show{
    opacity:1;
    transform:translateY(0);
}

.trust-topline{
    display:none;
}

.trust-hero h2{
    font-size:42px;
    line-height:1.08;
    color:#ffffff;
    margin-bottom:14px;
    text-transform:none;
}

.trust-hero h2 span{
    color:#63bfff;
text-shadow:0 0 12px rgba(99,191,255,0.18);
}

.trust-hero p{
    font-size:16px;
    color:#cfcac2;
    line-height:1.65;
    margin-bottom:18px;
    text-transform:none;
}

.trust-line{
    width:150px;
    height:2px;
    margin:0 auto;
    background:linear-gradient(90deg,transparent,#00a0ff,#ffffff,#00a0ff,transparent);
    box-shadow:0 0 10px rgba(0,160,255,0.22);
}

/* GRID */

.trust-grid{
    display:grid;
    grid-template-columns:repeat(3, minmax(0, 300px));
    justify-content:center;
    gap:14px;
}
.trust-card{
    padding:18px;
    min-height:195px;
    border-radius:14px;
position:relative;
overflow:hidden;

    background:rgba(0,160,255,0.02);
    border:1px solid rgba(0,160,255,0.12);

    box-shadow:inset 0 0 0 1px rgba(255,255,255,0.012);

    opacity:0;
    transform:translateY(28px);

    transition:
      transform .4s ease,
      box-shadow .4s ease,
      border-color .4s ease,
      opacity .7s ease;
}
.trust-card::before{
    content:"";
    position:absolute;
    inset:0;
    border-radius:inherit;
    pointer-events:none;

    opacity:0;
    transition:opacity .45s ease, transform .45s ease;

    background:
      radial-gradient(circle at 20% 25%,
      rgba(255,255,255,0.07),
      transparent 35%),

      radial-gradient(circle at 80% 75%,
      rgba(0,160,255,0.12),
      transparent 42%);

    transform:scale(1);
}

.trust-card.show{
    opacity:1;
    transform:translateY(0);
}

.trust-card:hover{
    transform:translateY(-4px);

    border-color:rgba(0,160,255,0.32);

    background:rgba(0,160,255,0.035);

    box-shadow:
      0 0 16px rgba(0,160,255,0.14),
      0 0 32px rgba(0,160,255,0.08),
      inset 0 0 0 1px rgba(255,255,255,0.03);
}
.trust-card:hover::before{
    opacity:1;
    transform:scale(1.03);
}
.trust-card:hover h3{
    color:#ffffff;
}

.trust-card:hover p{
    color:#e1dfdb;
}

/* ICON */

.trust-icon{
    width:42px;
    height:42px;
    margin-bottom:14px;
    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:18px;
    color:#00a0ff;

    border:1px solid rgba(0,160,255,0.24);
    background:rgba(0,160,255,0.03);
}

.trust-card h3{
    color:#ece7dc;
    font-size:18px;
    margin-bottom:10px;
    line-height:1.3;
    text-transform:none;
}

.trust-card p{
    color:#cfcac2;
    font-size:14px;
    line-height:1.65;
    text-transform:none;
}

/* FEATURED */

.trust-card.featured{
    border-color:rgba(0,160,255,0.22);
}

.trust-badge{
    display:inline-block;
    padding:6px 10px;
    margin-bottom:12px;
    border-radius:9px;
    background:rgba(0,160,255,0.14);
    color:#eaf6ff;
    font-size:11px;
    font-weight:700;
}

/* CTA */

.trust-cta{
    text-align:center;
    margin-top:42px;
    opacity:0;
    transform:translateY(28px);
    transition:all .8s ease;
}

.trust-cta.show{
    opacity:1;
    transform:translateY(0);
}

.trust-cta h3{
    color:#ffffff;
    font-size:24px;
    margin-bottom:10px;
    text-transform:none;
}

.trust-cta p{
    color:#cfcac2;
    font-size:15px;
    margin-bottom:18px;
    text-transform:none;
}

.trust-btn{
    display:inline-block;
    padding:13px 26px;
    border-radius:12px;
    border:1px solid rgba(0,160,255,0.28);
    color: #ece7dc !important;
    text-decoration:none;
    font-weight:700;
    font-size:14px;
    letter-spacing:.25px;
    transition:.3s ease;
}

.trust-btn:hover{
    background:rgba(0,160,255,0.08);
    box-shadow:0 0 18px rgba(0,160,255,0.14);
}

/* MOBILE */

@media(max-width:1100px){

    .trust-grid{
        grid-template-columns:1fr;
    }

    .trust-hero h2{
        font-size:34px;
    }

    .trust-card{
        min-height:auto;
    }

    .trust-card h3{
        font-size:18px;
    }

    .trust-card p,
    .trust-hero p,
    .trust-cta p{
        font-size:15px;
    }

    .trust-cta h3{
        font-size:24px;
    }
}
/* Videos nebeneinander */
.video-section-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 40px;
    align-items: start;
    width: 100%;
}

.video-column .cinematic-title {
    margin-bottom: 20px;
}

/* Mobile Ansicht */
@media (max-width: 900px) {
    .video-section-grid {
        grid-template-columns: 1fr;
        gap: 30px;
    }
}
/* MOBILE TEXT FIX */
@media (max-width: 900px) {

    .process-text {
        text-align: left !important;
        align-items: flex-start !important;
    }

    .process-step {
        text-align: left;
    }

}
/* =========================
   PROCESS FINAL V3
========================= */

.process-section {
    width: 90%;
    max-width: 1150px;
    margin: 60px auto 60px auto;
    position: relative;
}

/* ===== LINE ===== */

.process-line-wrapper {
    position: absolute;
    top: 45px;
    left: 9%;
    width: 82%;
    height: 2px;
    z-index: 1;
}

.process-line {
    height: 2px;
    width: 0%;
    background: linear-gradient(
        90deg,
        rgba(0,160,255,0.2),
        rgba(0,160,255,1),
        rgba(0,160,255,0.2)
    );

    box-shadow:
        0 0 12px rgba(0,160,255,0.8),
        0 0 30px rgba(0,160,255,0.35);

    transition: width 2.6s cubic-bezier(.22,1,.36,1);
}

/* ===== STEPS ===== */

.process-steps {
    display: flex;
    justify-content: center;
    gap: 20px;
    position: relative;
    z-index: 2;
margin-bottom: 10px;
}

.process-step {
    width: 18%;
    text-align: center;

    opacity: 0;
    transform: translateY(40px);

    transition: all 0.6s ease;
}

.process-step.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ===== ICON ===== */

.process-dot {
    width: 90px;
    height: 90px;
    border-radius: 50%;

    background: #0e232d;
    border: 1px solid rgba(255,255,255,0.15);

    display: flex;
    align-items: center;
    justify-content: center;

    margin: 0 auto 20px auto;

    position: relative;
    z-index: 5;

    transition: all 0.4s ease;
}

/* ICON FIX (Videodreh etc.) */
.process-dot img {
    width: 52px;
    height: 52px;
    object-fit: contain;
    display: block;

    filter: grayscale(100%) brightness(1.3);
    transition: all 0.5s ease;
}

/* ===== AKTIV (Glow erst später) ===== */

.process-step.active .process-dot {
    border-color: rgba(0,160,255,0.8);
    box-shadow:
        0 0 20px rgba(0,160,255,0.9),
        0 0 50px rgba(0,160,255,0.4);
}

.process-step.active .process-dot img {
    filter: brightness(1.3) saturate(1.3);
}

/* ===== HOVER ===== */

.process-step:hover .process-dot {
    transform: translateY(-6px) scale(1.08);
}

/* ===== TEXT ===== */

.process-step h3 {
    font-size: 14px;
    color: #ffffff;
    margin-bottom: 10px;
}

.process-step p {
    font-size: 13px;
    line-height: 1.6;
    color: #cfcac2;

    max-width: 170px; /* WICHTIG → gleiche Breite */
    margin: 0 auto;

    text-align: center;
    text-wrap: balance;

    text-transform: none;
}

/* =========================
   MOBILE TIMELINE FIX
========================= */

@media (max-width: 900px) {

    .process-section {
        margin: 60px auto 60px auto;
    }

    .process-steps {
        display: flex;
        flex-direction: column;
        gap: 50px;
        position: relative;
    }

    /* LINIE LINKS */
    .process-line-wrapper {
        display: block;
        position: absolute;
        top: 0;
        left: 30px;
        width: 2px;
        height: 100%;
    }

    .process-line {
        width: 2px !important;
        height: 0%;
    }

    /* STEP */
    .process-step {
        width: 100%;
        display: flex;
        align-items: flex-start;
        gap: 18px;
        text-align: left;
    }

    /* ICON */
    .process-dot {
        width: 70px;
        height: 70px;
        flex-shrink: 0;
        margin: 0;
    }

    .process-dot img {
        width: 40px;
        height: 40px;
    }

    /* TEXT (WICHTIG) */
    .process-text {
        display: flex;
        flex-direction: column;
        align-items: flex-start;
        text-align: left;
        flex: 1;
    }

    .process-text h3 {
        margin: 0 0 6px 0;
        text-align: left;
    }

    .process-text p {
        margin: 0;
        text-align: left;
    }

}
/* DESKTOP DEFAULT */
.process-text {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
}

.process-text h3 {
    margin: 0 0 6px 0;
}

.process-text p {
    margin: 0;
}
/* =========================
   VIDEO SIDE BY SIDE (DESKTOP)
========================= */

.video-section {
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}

.video-item {
    width: 100%;
}

/* Desktop */
@media (min-width: 900px) {

    .video-section {
        display: flex;
        gap: 40px;
        align-items: flex-start;
    }

    .video-item {
        flex: 1;
    }

    /* Titel etwas kompakter nebeneinander */
    .video-item .cinematic-title {
        margin-top: 60px;
    }

}
/* =========================
   PROCESS CTA BUTTON
========================= */

.process-cta {
    width: 100%;
    text-align: center;
    margin-top: -30px;
 margin-bottom: 100px;

    opacity: 0;
    transform: translateY(40px);
    transition: all 0.6s ease;
}

.process-cta.show {
    opacity: 1;
    transform: translateY(0);
}

.process-btn {
    display: inline-block;
    padding: 14px 28px;

    border-radius: 30px;

    background: rgba(0,160,255,0.12);
    border: 1px solid rgba(0,160,255,0.35);

    color: #7ecbff;
    text-decoration: none;
    font-size: 14px;
    letter-spacing: 1px;

    transition: all 0.35s ease;
}

/* Hover */
.process-btn:hover {
    background: rgba(0,160,255,0.22);
    border-color: rgba(0,160,255,0.6);
    color: #ffffff;

    transform: translateY(-3px);
    box-shadow: 0 0 25px rgba(0,160,255,0.25);
}
/* =========================
   PROCESS DETAIL PAGE (NEU)
========================= */

.process-detail-wrapper {
    width: 90%;
    max-width: 1100px;
    margin: 0 auto 120px auto;

    display: flex;
    flex-direction: column;
    gap: 70px;
}

/* =========================
   SINGLE STEP
========================= */

.process-detail {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 45px;
    align-items: center;

    opacity: 0;
    transform: translateY(50px);
    transition: all 0.8s cubic-bezier(.22,1,.36,1);
}

.process-detail.show {
    opacity: 1;
    transform: translateY(0);
}

/* Wechsel Layout */
.process-detail.reverse {
    direction: rtl;
}

.process-detail.reverse .process-content {
    direction: ltr;
}

/* =========================
   MEDIA
========================= */

.process-media img,
.process-media video {
    width: 100%;
    height: 100%;
    max-height: 320px;

    object-fit: cover;

    border-radius: 18px;
    border: 1px solid rgba(236,231,220,0.15);

    box-shadow:
        0 25px 60px rgba(0,0,0,0.65),
        0 0 30px rgba(0,160,255,0.12);

    transition: all 0.5s ease;
}

.process-media img:hover,
.process-media video:hover {
    transform: scale(1.04) translateY(-4px);
    box-shadow:
        0 35px 80px rgba(0,0,0,0.8),
        0 0 45px rgba(0,160,255,0.18);
}

/* =========================
   TEXT
========================= */

.process-content h2 {
    font-size: 22px;
    margin-bottom: 12px;
    color: #ece7dc;
    letter-spacing: 1px;
}

.process-content p {
    font-size: 15px;
    line-height: 1.6;
    color: #cfcac2;
    text-transform: none;
}

/* =========================
   BACK BUTTON
========================= */

.process-back {
    text-align: center;
    margin-bottom: 120px;
margin-top: -60px;
}

/* =========================
   RESPONSIVE
========================= */

@media (max-width: 900px) {

    .process-detail {
        grid-template-columns: 1fr;
        gap: 20px;
    }

    .process-detail.reverse {
        direction: ltr;
    }

    .process-media img,
    .process-media video {
        max-height: 260px;
    }

}
.process-detail-wrapper {
    position: relative;
}

/* SVG */
.process-path {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;

    pointer-events: none;
    z-index: 0;
}
/* =========================================
   COLOR GRADING
========================================= */

.grading-intro{
    width: 90%;
    max-width: 720px;

    margin: -5px auto 35px auto;

    text-align: center;

    color: #cfcac2;

    font-size: 15px;
    line-height: 1.7;

    text-transform: none;

    opacity: 0.92;
}

.grading-compare{
    width: 90%;
    max-width: 820px;

    margin: 0 auto 100px auto;
}

.grading-wrapper{
    position: relative;

    width: 100%;
    aspect-ratio: 16 / 9;

    overflow: hidden;

    border-radius: 18px;

    background: #000;

    cursor: ew-resize;

    border: 1px solid rgba(255,255,255,0.08);

    box-shadow:
        0 20px 60px rgba(0,0,0,0.55),
        0 0 25px rgba(0,160,255,0.08);
overflow: hidden;

}

/* Beide Layer */

.grading-before,
.grading-reveal{
    position: absolute;
    inset: 0;

    width: 100%;
    height: 100%;
}

/* Bilder */

.grading-before img,
.grading-reveal img{
    width: 100%;
    height: 100%;

    object-fit: cover;

    display: block;

    user-select: none;
    pointer-events: none;
}

/* Vorher unten */

.grading-before{
    z-index: 1;
}

/* Nachher oben */

.grading-reveal{
    z-index: 2;

    clip-path: inset(0 100% 0 0);

    will-change: clip-path;
}

/* Slider */

.grading-slider{
    position: absolute;

    top: 0;
    left: 0%;

    width: 3px;
    height: 100%;

    z-index: 10;
}

/* Linie */

.grading-line{
    width: 100%;
    height: 100%;

    background: rgba(255,255,255,0.95);

    box-shadow:
        0 0 18px rgba(255,255,255,0.7),
        0 0 40px rgba(0,160,255,0.35);
}

/* Handle */

.grading-handle{
    position: absolute;

    top: 50%;
    left: 50%;

    width: 60px;
    height: 60px;

    transform: translate(-50%, -50%);

    border-radius: 50%;

    background: rgba(255,255,255,0.08);

    backdrop-filter: blur(10px);

    border: 1px solid rgba(255,255,255,0.3);

    box-shadow:
        0 0 25px rgba(255,255,255,0.18),
        0 0 45px rgba(0,160,255,0.14);

    transition:
        transform .25s ease,
        box-shadow .25s ease;
}

/* Pfeile */

.grading-handle::before,
.grading-handle::after{
    content: "";

    position: absolute;
    top: 50%;

    width: 12px;
    height: 12px;

    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
}

.grading-handle::before{
    left: 18px;
    transform: translateY(-50%) rotate(-135deg);
}

.grading-handle::after{
    right: 18px;
    transform: translateY(-50%) rotate(45deg);
}
/* Hover */

.grading-wrapper:hover .grading-handle{
    transform: translate(-50%, -50%) scale(1.06);

    box-shadow:
        0 0 30px rgba(255,255,255,0.25),
        0 0 60px rgba(0,160,255,0.2);
}

/* Mobile */

@media(max-width:768px){

    .grading-intro{
        font-size: 13px;
        line-height: 1.6;

        margin-bottom: 25px;
    }

    .grading-compare{
        max-width: 95%;
    }

    .grading-handle{
        width: 52px;
        height: 52px;
    }

}
/* =========================================
   COLOR GRADING SCROLL ANIMATION
========================================= */

.grading-compare,
.grading-intro{
    opacity: 0;
    transform: translateY(40px);
    filter: blur(8px);

    transition:
        opacity 0.9s ease,
        transform 0.9s ease,
        filter 0.9s ease;
}

.grading-compare.show,
.grading-intro.show{
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}
/* =========================
   COLOR GRADING NAVIGATION
========================= */

.grading-compare {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 22px;
}

.grading-nav {
    width: 54px;
    height: 54px;

    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.18);

    background: rgba(255,255,255,0.04);
    color: #ffffff;

    font-size: 28px;
    cursor: pointer;

    transition: all 0.3s ease;

    backdrop-filter: blur(10px);
}

.grading-nav:hover {
    transform: scale(1.08);
    background: rgba(0,160,255,0.15);

    border-color: rgba(0,160,255,0.4);

    box-shadow:
        0 0 20px rgba(0,160,255,0.25);
}
/* MOBILE BUTTONS STANDARDMÄSSIG AUS */
.grading-nav-mobile {
    display: none !important;
}

@media (max-width: 768px) {

   /* Desktop Buttons ausblenden */
.grading-prev,
.grading-next {
    display: none !important;
}

    /* Wrapper normal */
    .grading-compare {
        width: 100%;
        max-width: 100%;
    }

    /* Bild größer */
    .grading-wrapper {
        width: 94vw;
        max-width: none;
        margin: 0 auto;
    }

    .grading-wrapper img {
        width: 100%;
        display: block;
    }

   /* MOBILE BUTTONS */
.grading-nav-mobile {

    display: flex !important;

    justify-content: center;
    align-items: center;

    gap: 12px;

    margin-top: -50px;

    width: 100%;
}

/* Buttons selbst */
.grading-prev-mobile,
.grading-next-mobile {

    display: flex;
    justify-content: center;
    align-items: center;

    width: 44px;
    height: 44px;

    border-radius: 12px;

    background: rgba(255,255,255,0.06);

    border: 1px solid rgba(255,255,255,0.10);

    backdrop-filter: blur(10px);

    color: #ffffff;

    font-size: 20px;

    transition: all 0.25s ease;

    box-shadow:
        0 4px 18px rgba(0,0,0,0.35);
}

/* Hover */
.grading-prev-mobile:hover,
.grading-next-mobile:hover {

    transform: translateY(-2px);

    background: rgba(255,255,255,0.10);

    border-color: rgba(255,255,255,0.22);
}

}/* =========================
   GRADING SLIDE ANIMATION
========================= */

.grading-wrapper {
    position: relative;
overflow: hidden;
}

.grading-inner {
    overflow: hidden;
    border-radius: 18px;
}

.grading-slide {
    animation-duration: 0.45s;
    animation-timing-function: ease;
}

.grading-slide-left {
    animation-name: gradingImageLeft;
}

.grading-slide-right {
    animation-name: gradingImageRight;
}

@keyframes gradingImageLeft {

    0% {
        opacity: 0.4;
        transform: translateX(40px);
    }

    100% {
        opacity: 1;
        transform: translateX(0);
    }
}

@keyframes gradingImageRight {

    0% {
        opacity: 0.4;
        transform: translateX(-40px);
    }

    100% {
        opacity: 1;
        transform: translateX(0);
    }
}