@import 'https://fonts.googleapis.com/css?family=Montserrat:300, 500, 700&display=swap';

html {
	font-size: 10px;
	font-family: 'Montserrat', sans-serif;
	scroll-behavior: smooth;
}

body {
  margin: 0;
  font-family: Arial, Helvetica, sans-serif;
}

.container{
  background-color: black;
  position: fixed;
  top: -90px;
  width: 100%;
  height: 68px;
  transition: top 0.4s;
  z-index: 2;
}


/*------------------------- Topnav --------------------------------*/
.topnav {
  overflow: hidden;
  /*background-color: rgb(26, 29, 33);*/
  /*background: linear-gradient(143deg, rgba(16,24,40,1) 0%, rgba(26,29,33,1) 100%);*/
  position: fixed;
  width: 100%;
  top: 0px;
  z-index: 20;
}

@media screen and (min-width: 2000px) {
  .topnav{
    display: flex;
    justify-content: center;}
  .brand{
    margin: 0 10vw 0 0;
  }

}


.topnav a {
  float: right;
  display: block;
  color: #f2f2f2;
  text-align: center;
  text-transform: uppercase;
  padding: 26px 16px;
  text-decoration: none;
  letter-spacing: 1px;
  font-size: 17px;
  font-weight: 500;
	font-family: 'Montserrat', sans-serif;
}

.brand a{
  padding: 0;
}

.topnav a:hover {
    color: #fca311;
}
.topnav .icon img{
  width: 25px;
  padding: 0;
}
.topnav .icon {
  display: none;
}

@media screen and (max-width: 960px) {
  .topnav a:not(:first-child) {display: none; padding: 20px 16px 16px 16px;}
  .topnav a.icon {
    float: right;
    display: block;
  }
}

@media screen and (max-width: 960px) {
  .topnav.responsive {position: relative;}
  .topnav.responsive .icon {
    position: absolute;
    right: 0;
    top: 0;
  }
  .topnav.responsive a {
    float: none;
    display: block;
    text-align: left;
  }
}

/*------------------------- Sidenav --------------------------------*/

.sidenav {
  height: 100%;
  width: 0;
  position: fixed;
  z-index: 1;
  top: 0;
  left: 0;
  background-color: #111;
  overflow-x: hidden;
  transition: 0.5s;
  padding-top: 60px;
  text-align:center;
  z-index: 30;
}

.sidenav a {
  padding: 15px 8px 15px 32px;
  text-decoration: none;
  font-size: 25px;
  text-transform: uppercase;
  color: #ffffff;
  display: block;
  transition: 0.3s;

}

.sidenav a:hover{
  color: #fca311;
}

.sidenav .closebtn {
  position: absolute;
  top: 0;
  right: 25px;
  font-size: 36px;
  margin-left: 50px;
}

@media screen and (max-height: 450px) {
  .sidenav {padding-top: 15px;}
  .sidenav a {font-size: 18px;}
}

/*------------------------- Nav Media 300 --------------------------------*/

@media screen and (max-width: 300px) {
    .topnav{
      display: flex;
      flex-direction: column;
    }
    .brand{
      margin: auto;
      margin-top: 18px;
    }
    .brand:not(a) {
      padding: 0 0 0 0;
    }
    .sidenav a {
      font-size: 7vw;
      padding: 7vw;
    }

    .container{
      height: 90px ;
      top: -90px;
    }
}

/*------------------------- Logo --------------------------------*/

.brand {
	max-width: 278px;
  width: 60vw;
  float: left;
  padding: 18px 0 0 10px;
}
.brand img{
	max-width: 90%;
}
.center{
  margin-top: 35%;
}

/*------------------------- Üdvözöljük --------------------------------*/
.header{
  background-image: url(./images/header.jpg);
  height: 100vmin;
  background-size: cover;
	background-position: top center;
  position: relative;
  z-index: -1;
}
@media screen and (max-width: 920px) {
  .header{height: 100vmax;}
}


.udv_container{
  margin: 0 auto;
  max-width: 1200px;
}
.udv{
  display: flex;
  position: absolute;
  flex-direction: column;
  top: 32rem;
}
.udv h1{
  font-size: 5.3rem;
  font-weight: 500;
  color: #ffffff;
  margin: 0;
  letter-spacing: 1px;
  margin: 0 0 0 5rem;
}
@media screen and (max-width: 800px) {
.udv h1{
  margin: 0 0 0 1rem;
  font-size: 4.6rem;
}
}


.cta{
  text-decoration: none;
  color: white;
  border: 2px solid #fca311;
	border-radius: 50px;
	font-size: 2rem;
  padding:18px 55px;
  font-weight: 300;
}
@media screen and (max-width: 360px) {
  .cta{
    padding: 1.2vw 2.4vw ;
  }
  .cta{
    font-size: 17px;
  }
}
.udv a:hover {
  background-color: #fca311;
  transition: 0.3s;
}


/*------------------ Body -----------------------------*/


.bodey_container{
  display: flex;
  max-width: 1200px;
  flex-direction: column;
  margin: 2rem auto 0 auto;
  align-items: center;
}

.bodey_container h1{
  font-family: 'Montserrat', sans-serif;
  font-size: 5rem;
  font-weight: 300;
  text-transform: uppercase;
  margin: -6rem 0 2rem 0;
  text-align: center;
}
.bodey_container span{
  color: #fca311;
}
.szlogen{
  font-family: 'Montserrat', sans-serif;
  font-size: 1.7rem;
  text-align: center;
  max-width: 600px;
  margin: -1rem 0 2rem 0 ;
}
@media screen and (max-width: 500px) {
  .bodey_container h1{
    font-size: 9vw;
  }
}

/*------------------------- Szolgáltatások --------------------------------*/

.servicies_container{
  display: flex;
  flex-direction: row;
  justify-content: center;
  flex-wrap: wrap;
  width: 100%;
  max-width: 1200px;
  margin-bottom: 3rem;
}

.service{
  color: #ffffff;
  display: flex;
  flex-direction: column;
  background-image: url(./images/service_cover.jpg);
  background-size: cover;
	background-position: top center;
  border-radius: 10px;
  padding:  2rem 0;
  align-items: center;
  margin: 2rem 2.5rem 0 2.5rem;
  width: 30rem;
}
.service img{
  width: 10rem;
}
.service h1{
  font-size: 2rem;
  font-weight: 500;
  text-transform: none;
  margin: 2rem 0 1rem 0;
}
.service p{
  font-size: 1.5rem;
  text-align: center;
  padding: 0 2rem;
}
.button{
  text-decoration: none;
  color: white;
  border: 2px solid #fca311;
	border-radius: 50px;
	font-size: 2rem;
  padding:18px 55px;
  font-weight: 300;
  margin: 1rem 0 0 0;
}
.button:hover{
  background-color: #fca311;
  transition: 0.3s;
}

/*------------------------- Projektek --------------------------------*/

.project_1{
  display: flex;
  flex-direction: row;
  align-items: center;
  max-width: 1000px;
  color: #ffffff;
}
.project_2{
  display: flex;
  flex-direction: row;
  align-items: center;
  max-width: 1000px;
  color: #ffffff;
}

.p1{
  height: 20rem;
  width: 50%;
  background: linear-gradient(210deg, rgba(17,18,18,1) 0%, rgba(40,49,59,1) 100%);
  padding: 3rem 0rem;
}
.p1 h1{
  font-size: 3rem;
  text-align: left;
  margin: 1rem 0rem 2rem 3rem;
}
.p1 p{
  font-family: 'Montserrat', sans-serif;
  font-size: 1.6rem;
  margin: 5% 3rem 0 3rem;
}

.p2{
  display: flex;
  width: 50%;
  height: 26rem;
  background-size: cover;
	background-position: center center;
}
/*kis korrekció*/
@media screen and (max-width: 750px) {
  .p1 h1{
    font-size: 4vw;
  }
  .p1 p{
    font-size: 2vw;
  }
}
/*mobile*/
@media screen and (max-width: 550px) {
  .project_1{
    flex-direction: column;
    margin: 2rem 0;
  }
  .project_2{
    flex-direction: column-reverse;
    margin: 2rem 0;
  }
  .p1{
    padding: 0;
    width: 70%;
  }
  .p1 h1{
    font-size: 5vw;
    margin: 2rem 0;
    text-align: center;
  }
  .p1 p{
    font-size: 3vw;
    text-align: center;
    margin: 1rem 1.3rem 0 1.3rem;
  }
  .p2{
    width: 70%;
  }
}


/*------------------------- Rólunk --------------------------------*/

.rolunk_container{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin: 0rem 6rem;
}
.rolunk{
  display: flex;
  flex-direction: row;
  align-items: center;
  margin-bottom: 10rem;
}
.rolunk img{
  width: 30rem;
  object-fit: cover;
  margin: 7rem 6rem 0 0;
}
.rolunk_content{
  display: flex;
  flex-direction: column;
  font-family: 'Montserrat', sans-serif;
  font-size: 1.9rem;
  max-width: 65rem;
}
.rolunk_content h1{
  text-align: left;
}

@media screen and (max-width: 900px) {
  .rolunk{
    flex-wrap: wrap;
    justify-content: center;
    text-align: center;
  }
  .rolunk_content h1{
    text-align: center;
    margin: 0;
  }
  .rolunk img{
    margin: 0 auto;
  }
}
@media screen and (max-width: 400px) {
  .rolunk img{
    width: 90vw;
  }
}

/*------------------------- Csapatunk --------------------------------*/
.csapat{
  background: linear-gradient(60deg, #29323c 0%, #111111 100%);
  color: #ffffff;
  border-radius: 20px;
  padding: 1rem 2rem;
  margin-top: 1rem;
}
.csapatunk_container{
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  margin: 0 0 4rem 0;
  justify-content: center;
}
.tag{
  display: flex;
  flex-direction: column;
  align-items: center;
  background: linear-gradient(60deg, #29323c 0%, #111111 100%);
  border-radius: 20px;
  color: #ffffff;
  margin: 0 2rem 2rem 2rem;
}
.tag img{
  width: 18rem;
  margin: 0.3rem 2rem ;
}
.tag h2{
  font-family: 'Montserrat', sans-serif;
  font-size: 2.2rem;
  margin: 2rem 0 1rem 0 ;
}
.tag p{
  font-family: 'Montserrat', sans-serif;
  font-size: 1.3rem;
  margin: 0 0 3rem 0;
}


/*------------------------- Kapcsolat --------------------------------*/
.contact_container{
  display: flex;
  flex-direction: row;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 auto;
}
.contact{
  background-color: rgb(26 29 33 / 6%);
  border-radius: 10px;
  display: flex;
  flex-direction: row;
  padding: 3rem 3rem;
  box-shadow: rgba(17, 17, 26, 0.1) 0px 8px 24px, rgba(17, 17, 26, 0.1) 0px 16px 56px, rgba(17, 17, 26, 0.1) 0px 24px 80px;
  margin: 2rem 3rem;
}
.picture{
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.contact a{
  text-decoration: none;
  color: black;
}
.content{
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.contact img{
  width: 5rem;
  margin: 0 2rem 0 0;
}
.contact h1{
  font-family: 'Montserrat', sans-serif;
  font-size: 2.8rem;
  font-weight: 500;
  padding: 0;
  text-transform: none;
  margin: 0 0 0.3rem 0;
}
.contact p{
  font-family: 'Montserrat', sans-serif;
  font-size: 1.6rem;
  margin: 0;
  text-align: center;
  width: 19rem;
}
@media screen and (max-width: 400px) {
  .contact{
    padding: 5vw 5vw;
    margin: 5vw 0rem;
    max-width: 80vw;
  }
  .contact h1{
    font-size: 5vw;
  }
  .contact p{
    font-size: 4vw;
  }
}
/*------------------------- Footer --------------------------------*/
.footer{
  width: 100%;
  background: linear-gradient(60deg, #29323c 0%, #111111 100%);
  display: flex;
  flex-direction: column;
  align-items: center;
  color: #ffffff;
	font-family: 'Montserrat', sans-serif;
  margin-top: 8rem;
}
.footer h1{
  font-size: 3.2rem;
  font-weight: 700;
  margin: 25px 0 10px 0;
}
.footer h2{
  font-size: 2rem;
  font-weight: 100;
  margin: 0 0 15px 0;
  text-align: center;
}
.footer p{
  font-size: 1.3rem;
  font-weight: 100;
  margin: 25px 0 8px 0;
  text-align: center;
}


.social{
  display: flex;
  flex-direction: row;
}
.social img{
  width: 4rem;
  margin: 0 1.3rem;
}

@media screen and (max-width: 300px) {
  .social img{
    width: 3rem;
    margin: 0 0.9rem;
  }
  .footer h1{
    font-size: 1.9rem;
  }
  .footer h2{
    font-size: 1.8rem;
  }
  .footer p{
    font-size: 1.1rem;
  }
}
@media screen and (max-width: 200px) {
  .social img{
    width:15vw;
    margin: 0 2.9vw;
  }
}







.section-title::before { 
  display: block; 
  content: " "; 
  height: 13rem; 
  visibility: hidden; 
  pointer-events: none;
}

@media screen and (max-width: 900px) {
  .rolunk_container::before { 
    display: block; 
    content: " "; 
    height: 80px; 
    visibility: hidden; 
    pointer-events: none;
  }
  .section-title::before { 
    display: block; 
    content: " "; 
    height: 8rem; 
    visibility: hidden; 
    pointer-events: none;
  }
}

/*.project_2:hover {
  transform: scale(1.02);
  transition: all 0.7s;
}
.project_1:hover{
  transform: scale(1.02);
  transition: all 0.7s;
}*/