.raleway {
  font-family: "Raleway", sans-serif;
  font-optical-sizing: auto; 
}

html {
   
    height: auto; 
    font-family: 'Raleway', sans-serif;
}

body {
    overflow-x: hidden;
    position: relative;
    width: 100%;
    padding: 0;
    margin: 0;
}

.toparea
{background: #FFFFFF;
width: 90%;
height: 80px;
margin: auto;}

.logo
{background: #FFFFFF;
padding: 5px;
border-radius: 10px;}

.logo img
{width:55%;}

nav 
{display: block;
text-align: center;}

nav li {
	position: static;
	display: inline-block;
	margin: 15px 15px;
	outline: none;	
	text-decoration: none;	
	letter-spacing: 1px;
	font-weight: 400;	
	font-size: 14px;
	
}

nav li:hover,
nav li:focus {
	outline: none;
}

nav a
{color: #000;
text-decoration:none;}



nav ul li ul {
    opacity: 0;
    position: absolute;     
    width: 100vw;   
    left: 50%;
    transform: translateX(-50%);     
    background: rgb(255, 255, 255);
    border-top: 3px solid #030;
    max-height: 0px;
    overflow: hidden;
    transition: max-height 0.4s linear, opacity 0.4s;
    z-index: 9999;
    margin-top: 30px;    
}
			

nav ul li:hover > ul {
display: block;
opacity: 1;
max-height:400px;
height:200px;
}

nav ul li:nth-child(2):hover ul {
display: flex;
flex-wrap: wrap; 
align-items:center !important;
justify-content: center;
max-height:400px;
height:200px; 
}

nav ul li:nth-child(2) ul li 
{width: 25%;
margin-left: 0;
margin-right: 0;
padding-left: 0;
padding-right: 0;}

nav ul li:nth-child(3):hover ul {
display: flex;
flex-wrap: wrap; 
align-items:center !important;
max-height:400px;
height:200px;   
}

/* Элементы списка (ссылки) */
nav ul li:nth-child(3) ul li {
    display: block !important;
    flex: 0 0 33.33%; 
    box-sizing: border-box; 
    margin: 0;
    padding: 10px; 
    list-style: none;
}



nav ul li:nth-child(3) ul li ul {
    display: none; 
    opacity: 0;
    position: absolute;
    top: 0;      
    left: 100%; 
    width:1200px !important; 
    transform: none;          
    max-height: 0;
    margin-top: 0;            
    overflow: visible;    
    background: #ffffff;
    border: 1px solid #eee;
    display: flex !important; 
    flex-wrap: wrap; 
    padding:1px;
}


nav ul li:nth-child(3) ul li:hover > ul {
    opacity: 1;    
    transition: opacity 0.3s ease;
    height:100px;
}


	





.lang 
{margin-top: 25px;}

.lang li
{display: block;
float: left;
margin: 5px 5px;}

.lang li a
{color:#2E3032;
text-decoration: none;}

.phone
{margin-top: 27px;}

.phone img 
{margin-bottom: -7px;}

.phone a 
{font-family: Arial, Helvetica, sans-serif;
text-decoration: none;
color: #000;}

.hero-video {
  position: relative;
  height: 100vh;
  overflow: hidden;
 
}

.title h2 
{font-size: 35px;
text-transform: uppercase;
display: block;
text-align: center;}

.title h2::after 
{display: block;
content: "";
margin:7px auto;
border-bottom:2px solid #99CE7C;
width: 180px;}

.about-parallax-section {
    position: relative;
    /* Высота всей прокрутки: чем больше vh, тем дольше длится эффект */
    height: 250vh; 
    background: #fff;
}

.sticky-container {
    position: sticky;
    top: 0;
    height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: center;
    overflow: hidden;
}

/* Начальное состояние картинки */
.company_img img {
    transform: scale(0);
    opacity: 0;
    transition: transform 0.8s cubic-bezier(0.175, 0.885, 0.32, 1.275), opacity 0.6s ease;
}

/* Состояние при появлении картинки */
.company_img.is-visible img {
    transform: scale(1);
    opacity: 1;
}

/* Начальное состояние блоков текста */
.text-step {
    opacity: 0;
    transform: translateY(100px); /* Появление снизу */
    transition: transform 0.8s ease-out, opacity 0.8s ease-out;
    margin-bottom: 30px;
}

/* Финальное состояние блоков текста */
.text-step.active {
    opacity: 1;
    transform: translateY(0);
}

/* Для мобильных отключаем фиксацию, чтобы не ломать верстку */
@media (max-width: 800px) {
    .about-parallax-section { height: auto; }
    .sticky-container { position: relative; height: auto; padding: 50px 0; }
    .text-step { opacity: 1; transform: none; }
    .company_img img { transform: scale(1); opacity: 1; }
}

.company_img img 
{width: 100% !important;}

.prod_categories 
{margin-bottom:50px;}

.adv_wrapper {
    width:90%;
    height:550px;
    display: flex;
    flex-direction: row;
    align-items: center;
    margin: auto;
    position: relative; 
}

.line {
    width: 100%;
    border: 1px solid #B5B5B5;
    position: absolute; 
    top: 50%;
    left: 0;
    z-index: 1;
}

.advblock {
    width: 20%;
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    z-index: 5;
    position: relative; 
}


.text_top {
    margin-bottom: 10px;
    position: absolute;
    bottom: 100%; 
    font-size: 20px;
}

.text_bottom {
    margin-top: 10px;
    position: absolute;
    top: 100%;
    font-size: 20px;
}

.advblock img {    
    display: block;
    width: 100px;
}

.i1 
{margin-top: -95px;}

.i2 
{margin-bottom: -95px;}


.adv_wrapper_second 
{width: 100%;
margin-top:150px;}



.adv_select_outer {
    background-color: #e7ede38d;    
    padding-top: 40px;
    position: relative;
    z-index:7;
    overflow: visible;
    width: 70%;
    height:200px;    
    border-top-left-radius:20px;
    border-top-right-radius:20px;
    margin-left:15%;
    margin-bottom: -60px;
    transform: translateY(-60px);
}

.adv_select 
{width:90%;
height:300px;
margin-left:5%;
border-radius: 20px;
position: relative;
z-index:55 !important;
background: #FFFFFF;
border: 3px solid #93C477;
border-bottom: 20px;}

.green_bottom 
{background:#99CE7C;
width: 100%;
height: 215px;
display: flex;
position: relative;
z-index:4;
justify-content: center;}



.footer
{width:100%;
height: 500px;

}

.footer_inner
{width: 95%;
margin: auto;}

.footer_block
{padding-top: 10px;}

.bl_lightgreen
{background:#d3efc5;
padding-top:50px;
width: 100%;
height: 500px;}

.footer_brand p 
{font-size: 25px;
font-weight:600;
display: block;
text-align: center;
color:#211F6B;}

.bl_green 
{background:#62A73F;
padding-top:50px;
width: 100%;
height: 500px;}

.bl_darkgreen
{background:#2D722A;
padding-top:50px;
width: 100%;
height: 500px;}

.bl_blue
{background:#2A3A8E;
width: 100%;
height: 500px;}

.footer_contacts {
    display: flex; 
    align-items: flex-start; 
    gap: 12px;
    margin: 20px 0px; 
}

.icon {
    flex-shrink: 0; 
    width: 24px; 
}

.icon img {
    width: 100%;
    height: auto;
    display: block;
}

.footer_contacts_text p {
    margin:0; 
    line-height: 1.8; 
}

.footer_contacts_text a {
   color: #FFFFFF;
   text-decoration: none;
}

.pa-underline-color-swipe li
{list-style-type: none;
margin: 20px 10px;}

.pa-underline-color-swipe li a {
   position: relative;
   background-clip: text;
   -webkit-text-fill-color: transparent;
   background-image: linear-gradient(to right, #2A3A8E, #2A3A8E 50%, #FFFFFF 50%);
   background-size: 200% 100%;
   background-position: 100%;
   transition: all 0.35s ease;  
	padding: 5px 10px;
    text-decoration: none;
	
}

.pa-underline-color-swipe li a::before {
   position: absolute;
   bottom: 0;
   display: block;
   height: 2px;
   width: 0%;
   content: "";
   background-color:#2A3A8E;  
   transition: all 0.35s ease;
}

.pa-underline-color-swipe li a:hover::before {
   opacity: 1;
   width: 100%;
}

.pa-underline-color-swipe li a:hover {
   transition: all 0.3s cubic-bezier(0, 0, 0.23, 1);
   background-position: 0%;
}

.footer_contacts
{margin-bottom: 20px;
margin-top: 20px;}


.footer_contacts_text p
{color: #FFFFFF;
font-size: 18px;}

.footer_social li
{list-style-type: none;
float: left;
margin: 10px 20px;}

.footer_map 
{width: 100%;
height: auto;
overflow: hidden;}

@media screen and (max-width:4000px) {
	
#main-nav 
{display:none;}	
	
}


@media screen and (max-width:1566px) {

#main-nav 
{display:none;}

.footer_brand img 
{width: 100% !important;}


.toparea
{background: #FFFFFF;
width:95%;
height: 80px;
margin: auto;}

.logo img
{width:60%;}

nav li {
	position: static;
	display: inline-block;
	margin: 15px 6px;
	outline: none;	
	text-decoration: none;	
	letter-spacing: 1px;
	font-weight: 400;	
	font-size: 14px;
	
}
	
	
}


@media screen and (max-width:1288px) {

#main-nav 
{display:none;}
	
.toparea
{background: #FFFFFF;
width: 98%;
height: 80px;
margin: auto;}
	
.footer_brand img 
{width: 100% !important;}
	
.footer_social ul li
{margin: 10px 7px !important;}

	
	
}

@media screen and (max-width:768px) {

#main-nav 
{display: block;}

.toparea
{background: #FFFFFF;
width:100%;
height:auto;
margin: auto;}  

.logo 
{display: block;
text-align: center;}

.lang 
{margin-left: 10px;
}

.mymenu 
{display: none;}

.adv_wrapper {
        display: flex;
        flex-direction: column;
        height: auto;
        padding: 20px 0 20px 20px; /* Отступ слева для линии */
        gap: 30px;
        position: relative;
    }

    
    .line {
        width: 2px; 
        height: 90%;
        top:0;
        left: 51px; 
        border: none;
        background-color: #B5B5B5;
        position: absolute;
        z-index: 1;
        margin-top: -13px;
        margin-bottom: -13px;
    }

    .advblock {
        display: flex !important;
        flex-direction: row !important; 
        align-items: center;
        width: 100%;
        margin: 0 !important;
        position: relative;
        z-index: 2;
    }

    
    .advblock.i1 {
        flex-direction: row-reverse !important;
        justify-content: flex-end;
        margin-left: -36px !important;
    }

    .advblock.i2 {       
        margin-left: -36px !important;
    }

   
    .advblock img {
        width: 60px;
        height: auto;
        flex-shrink: 0;
        background: #fff; 
        padding:0px 0px;
        margin-right: 20px;       
        margin-left: 20px; 
    }

    
    .text_top, .text_bottom {
        position: static !important;
        text-align: left;
        font-size: 15px;
        line-height: 1.4;
        margin: 0;
        padding: 0 15px 0 0;
        color: #333;
        flex: 1;
    }
    
   
    .text_top p, .text_bottom p {
        margin: 0;
    }


.adv_select_outer {
    background-color: #e7ede38d;    
    padding-top:0px;
    position: relative;
    z-index:7;
    overflow: visible;
    width:100%;
    height:auto;    
    border-top-left-radius:20px;
    border-top-right-radius:20px;
    margin-left:0;
    margin-bottom: -60px;
    transform: translateY(-60px);
}

.adv_select 
{width:98%;
 height:auto; 
margin-left:0;
border-radius: 20px;
position: relative;
z-index:55 !important;
background: #FFFFFF;
border: 3px solid #93C477;
border-bottom:40px !important;}    

.green_bottom 
{background:#99CE7C;
width: 100%;
height:auto;
display: flex;
position: relative;
z-index:4;
justify-content: center;}

.grren_logo
{display: none;}

.footer_contacts
{margin-left: 10px;}

	
	
}


