*{box-sizing:border-box;margin:0;padding:0}
body,html{
height:100vh;
width:100%;
font-family: 'Serif', sans-serif;
color:black;
font-weight: 300;
font-size:1em;
line-height:1.6;
text-rendering: auto;
scroll-behavior: smooth;
}

h2{font-size: 2e,m;}
h3 {font-size: 1.4em;}
img {
width: 100%;
height: auto;
}
.master-grid{
display:grid;	grid-template-columns:repeat(auto-fit,minmax(100px,1fr));
grid-template-areas:
"header"
"hero"
"intro"



}

/* DESKTOP SCREEN */
@media only screen and (min-width:1281px){
.master-grid{
display:grid;
grid-template-columns:repeat(auto-fit,minmax(100px,1fr));
grid-template-areas:
"header     header      header      header  "
"hero       hero         hero        hero"
" .         intro        intro        .   "


}
}
span {
	font-weight: bold;
}
.hero {
grid-area: hero;
min-height:680px;
background-image:linear-gradient(rgba(7, 7, 7, 0.4) 100%, rgba(7, 7, 7, 0.3) 100%, rgba(7, 7, 8, 0.3) 100%),  url(hero.jpg);
background-repeat: no-repeat;
background-size: cover;
background-position: center center;
background-attachment: fixed;
color: white;
}

.hero h1{
margin-left: 3%;
font-size: 6vw;
margin-top: 80px;
font-weight: 400;
}
.hero h2{
position: absolute;
top: 28%;
margin-left: 35%;
font-size: 1.4vw;
font-weight: normal;
}
.hero p{
	margin-right: 60%;
	padding: 10px;
	margin-left: 50px;
	font-size: 1.2em;
}
.intro{
grid-area: intro;
padding: 20px;
margin-top: 60px;
justify-content: center;
justify-self: center;
}
.intro li{
	padding: 10px;
}
.intro ul{
	padding-left: 15px;
}

.fb {
	max-width: 50px;
	max-height: 50px;
}


/* BUTTONS       */

.btn-cta{
text-align: center;
background-color:#1d5d2c;
color: white; 
cursor: pointer;
border-radius: 12px ;
border: none;
text-decoration:none;
font-size:1em;
width:15em;
padding:10px 35px;
transition: transform .2s;
margin-right:20px;
}
.btn-cta:hover{ text-decoration: underline;}
/* ENDS */






/* TO TOP BUTTON */

.back-to-top {
bottom: 1em;
opacity: 0.9;
position: fixed;
right: 1em;
transition: opacity 200ms ease;
z-index: 1;
color: white;
border: 1px solid white;
border-radius: 50%;
padding: 5px;
z-index: 999;
}

.back-to-top:hover {
opacity: 1;
background-color: #E94823;
}

.at-top .back-to-top,
.at-bottom .back-to-top {
opacity: 0;
pointer-events: none;
}


#scrollToTopBtn {
background-color: black;
border: none;
color: white;
cursor: pointer;
font-size: 18px;
line-height: 48px;
width: 48px;
}
/* ENDS   */






/*NAVIGATION*/
header{
	grid-area: header;
}

.nav {
	height: 70px;
	width: 100%;
background-color: #42591f;
	position: fixed;
	z-index: 555;
}

.nav > .nav-header {
	display: inline;
	margin-right: 20px;
}

.nav > .nav-header > .nav-title {
	display: inline-block;
	font-size: 17px;
	color:white;
	padding: 10px 10px 10px 10px;
}

.nav > .nav-btn {
display: none;
}

.nav > .nav-links {
display: inline;
float: right;
font-size: 17px;
}

.nav > .nav-links > a {
display: inline-block;
padding: 3px 40px 5px 10px;
text-decoration: none;
color:white;
}

.nav > .nav-links > a:hover {
background-color: #1d5d2c;
color: white ;
z-index: 999;
}
.nav > #nav-check {
display: none;
}

@media (max-width:1080px) {
.nav > .nav-btn {
display: inline-block;
position: absolute;
right: 40px;
top: 10px;
z-index: 1;
}
.nav > .nav-btn > label {
display: inline-block;
width: 50px;
height: 50px;
padding: 13px;
}
.nav > .nav-btn > label:hover,.nav  #nav-check:checked ~ .nav-btn > label {
background-color: rgba(0, 0, 0, 0.3);
}
.nav > .nav-btn > label > span {
display: block;
width: 25px;
height: 10px;
border-top: 2px solid #eee;
}
.nav > .nav-links {
position: absolute;
display: block;
width: 100%;
background-color: #9EA791;
height: 0px;
transition: all 0.3s ease-in;
overflow-y: hidden;
top: 50px;
left: 0px;
z-index: 1;
color: white;
}
.nav > .nav-links > a {
display: block;
width: 100%;
}
.nav > #nav-check:not(:checked) ~ .nav-links {
height: 0px;
}
.nav > #nav-check:checked ~ .nav-links {
height: calc(100vh - 50px);
overflow-y: auto;
}
}

/*   NAV ENDS */













/* MEDIA - HAND HELDS */

@media  screen and (max-width: 480px){ 


.hero {
grid-area: hero;
min-height:980px;
background-image: url(mobile-hero.webp);
background-repeat: no-repeat;
background-size: contain;
background-position:top 15%  right 0%;
background-color: #9EA791;
}


}







/* MEDIA SCREEN - TABLETS PORTRIAT --------------------------------------------------*/
@media (min-width: 481px) and (max-width: 810px){

.hero {
grid-area: hero;
height:600px;
background-image: url(happy-person.webp);
background-repeat: no-repeat;
background-size: contain;
background-position:top 20%  right 5%;
background-color: #9ea791;
}


}





@media (min-width: 811px) and (max-width: 930px){


	.hero {
		grid-area: hero;
		min-height:1180px;
		background-image: url(happy-person.webp);
		background-repeat: no-repeat;
		background-size: contain;
		background-position:top 10%  right 5%;
		background-color: #9EA791;
		}
		.fb {
			max-width: 50px;
			max-height: 50px;
		}





	}




@media (min-width: 931px) and (max-width: 1280px){




.hero {
	grid-area: hero;
	min-height:1180px;
	background-image: url(happy-person.webp);
	background-repeat: no-repeat;
	background-size: contain;
	background-position:top 20%  right 5%;
	background-color: #d7d090;
	}

}

.fb{
	max-width: 50px;
	max-height: 50px;
}