@import url('https://fonts.googleapis.com/css?family=Poppins:100,100i,200,200i,300,300i,400,400i,500,500i,600,600i,700,700i,800,800i,900,900i&subset=devanagari,latin-ext');


:root {
	--white: #ffffff;
	--black: #000000;
	--dark-blue: #1f2029;
	--dark-light: #424455;
	--grey: #ecedf3;
	--green: #88B04B;
	--green-light: #bae080;
}

/* #Primary
================================================== */

html{
	scroll-behavior: smooth;
}

body{
	width: 100%;
	height: 100%;
	background: var(--white);
	overflow-x: hidden;
    font-family: 'Poppins', sans-serif;
	font-size: 16px;
	line-height: 30px;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}

header{
	height:85px;
	width:100%;
	background-color: var(--green);
	z-index:9999999;
	position:fixed;
}

#menu{
	width:80%;
	min-width:650px;
	height:100%;
	position:relative;
	top:30%;
	margin:0px;
	padding:0px;
	margin-left:auto;
	margin-right:auto;
	list-style-type : none; 
	font-family: 'Poppins', sans-serif;
	font-size: 22px;
	font-weight: 700;
	color: var(--dark-light);
	text-transform: uppercase;
}

ul#menu li.menu_gauche {
	float : left;
	margin-left: -136px;
}

ul#menu li.menu_droite {
	float : right;
	margin-left: 56px;
}

ul#menu a {
	color : white;
	border-bottom: white solid 4px;
	text-decoration:none;
}
 
ul#menu a:hover { 
	border-bottom:none;
}

p{
    font-family: 'Poppins', sans-serif;
	font-size: 16px;
	margin-left: 6%;
	line-height: 22px;
	color: var(--dark-light);
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
	overflow: hidden;
	text-align: justify;
}

h0{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 100px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}

h0carto{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 95px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}

h0photos{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 87px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}

h1{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 50px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
h2{
    font-family: 'Poppins', sans-serif;
	font-size: 34px;
	font-weight: 900;
	margin-left: 6%;
	line-height: 30px;
	color: var(--green);
	text-transform: uppercase;
}

h3{
    font-family: 'Poppins', sans-serif;
	font-size: 22px;
	font-weight: 700;
	margin-left: 6%;
	line-height: 0px;
	color: var(--dark-light);
	text-transform: uppercase;
	padding-bottom: 10px;
	padding-top: 20px;
}

.paragraphe{
	float: left;
	width: 40%;
	margin-left: 2.5%;
	margin-right: 10%;
	overflow: hidden;
}

.paragraphe-droite{
	float: left;
	width: 40%;
	margin-right: 2.5%;
	position: relative;
}

.gauche-propos {
	float: left;
	width: 25%;
	margin-left: 2.5%;
	margin-right: 2%;
	padding-top: 130px;
	padding-bottom: 90px;
	position: relative;
}

.autres-propos {
	float: left;
	width: 18%;
	padding-top: 69%;
	margin-right: 2.5%;
	position: relative;
}


.liste{
	float: left;
	margin-left: 3%;
	line-height: 22px;
    font-family: 'Poppins', sans-serif;
	font-size: 16px;
	text-align: justify;
	color: var(--dark-light);
}

.img-portfolio{
	position: fixed;
	top: 25%;
	left: 50%;
	padding : 5px;
	-moz-border-radius : 4px;
	-webkit-border-radius : 4px;
}

.legende{
	position: fixed;
	top: 72.5%;
	left: 50%;
	text-align: center;
  font-family: 'Poppins', sans-serif;
	font-size: 12px;
	color: var(--dark-light);
	margin-left: 0%;
	background-color: var(--white);
	width: 786px;
}

.moi-vert{
	position: relative;
	width: 50%;
	height: 50%;
	margin: -20px 400px 20px 30px;
}

.ajustement{
	margin-top: 38.4px;
}

.skill-bordure-gimp{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -281px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes gimp{
	from{width: 0px;}
	to{width: 100px;}
}

.skill-gimp{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -278px;
	border-radius: 2px;	
 		animation-name: gimp;
 		animation-duration: 4s;
 		animation-delay: 2s;
 		animation-fill-mode: forwards;
}

.skill-bordure-inkscape{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -259px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes inkscape{
	from{width: 0px;}
	to{width: 120px;}
}

.skill-inkscape{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -256px;
	border-radius: 2px;	
 		animation-name: inkscape;
 		animation-duration: 4s;
 		animation-delay: 2.2s;
 		animation-fill-mode: forwards;
}

.skill-bordure-scribus{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -237px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes scribus{
	from{width: 0px;}
	to{width: 110px;}
}

.skill-scribus{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -235px;
	border-radius: 2px;	
 		animation-name: scribus;
 		animation-duration: 4s;
 		animation-delay: 2.4s;
 		animation-fill-mode: forwards;
}

.skill-bordure-illustrator{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -215px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes illustrator{
	from{width: 0px;}
	to{width: 170px;}
}

.skill-illustrator{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -212px;
	border-radius: 2px;	
 		animation-name: illustrator;
 		animation-duration: 4s;
 		animation-delay: 2.6s;
 		animation-fill-mode: forwards;
}

.skill-bordure-indesign{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -193px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes indesign{
	from{width: 0px;}
	to{width: 155px;}
}

.skill-indesign{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -190px;
	border-radius: 2px;	
 		animation-name: indesign;
 		animation-duration: 4s;
 		animation-delay: 2.8s;
 		animation-fill-mode: forwards;
}

.skill-bordure-photoshop{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -171px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes photoshop{
	from{width: 0px;}
	to{width: 150px;}
}

.skill-photoshop{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -168px;
	border-radius: 2px;	
 		animation-name: photoshop;
 		animation-duration: 4s;
 		animation-delay: 3s;
 		animation-fill-mode: forwards;
}

.skill-bordure-aftereffects{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -149px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes aftereffects{
	from{width: 0px;}
	to{width: 115px;}
}

.skill-aftereffects{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -146px;
	border-radius: 2px;	
 		animation-name: aftereffects;
 		animation-duration: 4s;
 		animation-delay: 3.2s;
 		animation-fill-mode: forwards;
}

.skill-bordure-premierpro{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -127px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes premierpro{
	from{width: 0px;}
	to{width: 80px;}
}

.skill-premierpro{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -124px;
	border-radius: 2px;	
 		animation-name: premierpro;
 		animation-duration: 4s;
 		animation-delay: 3.4s;
 		animation-fill-mode: forwards;
}

.skill-bordure-sketchup{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -105px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes sketchup{
	from{width: 0px;}
	to{width: 30px;}
}

.skill-sketchup{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -102px;
	border-radius: 2px;	
 		animation-name: sketchup;
 		animation-duration: 4s;
 		animation-delay: 3.6s;
 		animation-fill-mode: forwards;
}

.skill-bordure-rhino{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -105px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes rhino{
	from{width: 0px;}
	to{width: 40px;}
}

.skill-rhino{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -102px;
	border-radius: 2px;	
 		animation-name: sketchup;
 		animation-duration: 4s;
 		animation-delay: 3.6s;
 		animation-fill-mode: forwards;
}

.skill-bordure-htmlcss{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -83px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes htmlcss{
	from{width: 0px;}
	to{width: 90px;}
}

.skill-htmlcss{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -80px;
	border-radius: 2px;	
 		animation-name: htmlcss;
 		animation-duration: 4s;
 		animation-delay: 3.8s;
 		animation-fill-mode: forwards;
}

.skill-bordure-p5js{
	position: absolute;
	height: 20px;
	width: 200px;
	left: 200px;
	margin-top: -61px;
	border-radius: 4px;
	border-width: 3px;
	border-color: var(--green);
	border-style: solid;
}

@keyframes p5js{
	from{width: 0px;}
	to{width: 100px;}
}

.skill-p5js{
	position: absolute;
 	background-color: var(--green);
  	width: 0px;
 	height: 16px;
 	left: 200px;
	margin-top: -58px;
	border-radius: 2px;	
 		animation-name: p5js;
 		animation-duration: 4s;
 		animation-delay: 4s;
 		animation-fill-mode: forwards;
}

a:link {
    color: var(--green);
}

a:visited {
    color: var(--green);
}

a:hover {
    color: var(--green);
}

a:active {
    color: var(--green);
}

::selection {
	color: var(--green);
	background-color: var(--black);
}
::-moz-selection {
	color: var(--green);
	background-color: var(--black);
}
mark{
	color: var(--green);
	background-color: var(--black);
}

.logo-index {
	position: fixed;
	right: 1%; 
	bottom: 2%;  
    color: rgba(200,200,200,.1);
    background: linear-gradient(-90deg, rgba(200,200,200,0), rgba(200,200,200,0.1));
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
	line-height: 1;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
	z-index: 30 !important;
}

.p5Canvas {
	position: fixed;
	left: 50%;
	z-index: -2 !important;  
}

.size-18{
    font-size: 18px;
}
.opacity-40{
	opacity: 0.4;
}
.opacity-60{
	opacity: 0.6;
}
.section {
    position: absolute;
    overflow: hidden;
	width: 100%;
	/*display: block;*/
}
.over-hide {
    overflow: hidden;
}
.padding-top-bottom {
	padding-top: 130px;
	padding-bottom: 90px;
}
.padding-bottom {
	padding-bottom: 90px;
}
.padding-bottom2 {
	padding-bottom: 30px;
}


.hero-center-section{
	position: fixed;
	top: 50%;
	left: 22.5%;
	width: 100%;
	z-index: 10;
	transform: translateY(-50%);
	opacity: 0;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
	z-index: -1 !important;  
}
.hero-center-section.show{
	opacity: 1;
}

.hero-center-section .left-text{
	position: absolute;
	top: -50%;
	left: -20px;
	height: 300%;
	z-index: 1;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	text-align: left;    
	-webkit-writing-mode: vertical-lr;
    writing-mode: vertical-lr;
    font-size: 5vw;
    line-height: 1;
    color: var(--green);
	line-height: 1;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.hero-center-section.show .left-text{
	left: 0;
}

.z-bigger {
	z-index: 30 !important;
}

.img-wrap {
	position: relative;
	width: 100%;
	overflow: hidden;
	border-radius: 4px;
	box-shadow: 0 3px 5px rgba(0, 0, 0, 0.02);
	display: block;
	transform: scale(1.03);
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.hero-center-section.show .img-wrap{
	transform: scale(1);
}
.img-wrap img {
	width: 100%;
	height: auto;
	display: block;
}

/* #Cursor
================================================== */
.cursor2,
.cursor3{
	position: fixed;
	border-radius: 50%;	
	transform: translateX(-50%) translateY(-50%);
	pointer-events: none;
	left: -100px;
	top: 50%;
	mix-blend-mode: difference;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
	z-index: 9999999;
}
.cursor2,.cursor3{
	height: 36px;
	width: 36px;
	z-index:99998;
	-webkit-transition:all 0.3s ease-out;
	transition:all 0.3s ease-out
}
.cursor2.hover,
.cursor3.hover{
	-webkit-transform:scale(2) translateX(-25%) translateY(-25%);
	transform:scale(2) translateX(-25%) translateY(-25%);
	border:none
}
.cursor2{
	border: 2px solid var(--green);
	box-shadow: 0 0 12px rgba(255, 255, 255, 0.2);
}


.link-to-page {
	position: fixed;
    top: 30px;
    right: 30px;
    z-index: 20000;
    cursor: pointer;
    width: 30px;
}
.link-to-page img{
	width: 100%;
	height: auto;
	display: block;
}
.slide-buttons{
	position: relative;
	padding: 0px;
	margin: auto;
	text-align: left;
  	width: 40%;
  	max-width: 100%;
  	margin-left: 44.4%;
	list-style: none;
}
.slide-buttons li{
	position: relative;
	text-align: left;
	left: -105%;
	display: block;
	list-style: none;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.titrage li{
	margin-bottom: 40px;
}
.slide-buttons li a{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 100px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	opacity: 0.3;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.slide-buttons li b{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 100px;
	line-height: 1;	
	margin-top: 40px;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--dark-light);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.slide-buttons li b1{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 100px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.slide-buttons li c{
	position: relative;
	display: inline-block;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 50px;
	line-height: 1;
	text-transform: uppercase;
    -webkit-text-fill-color: var(--green);
    text-fill-color: transparent;
    color: transparent;
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
}
.slide-buttons li paragraphe{
	font-family: 'Poppins', sans-serif;
	font-size: 16px;
	margin-left: 6%;
	line-height: 22px;
	color: var(--dark-light);
	-webkit-transition: all 300ms linear;
	transition: all 300ms linear; 
	overflow: hidden;
	text-align: justify; 
}
.slide-buttons li.active a{
	opacity: 1;
}
.slide-buttons li a:hover{
	text-decoration: none;
}
.slide-buttons li a:focus,
.slide-buttons li a:active{
	border: none;
	outline: none;
	box-shadow: none;
}
.slide-buttons li a::before {
	position: absolute;
	top: 0;
	left: 0;
    font-family: 'Poppins', sans-serif;
	font-weight: 900;
	font-size: 100px;
	line-height: 1;
	overflow: hidden;
	text-transform: uppercase;
	padding: 0;
	max-height: 0;
	-webkit-text-stroke: transparent;
    text-stroke: transparent;
    -webkit-text-fill-color: var(--green);
    text-fill-color: var(--green);
	color: var(--green);
	content: attr(data-hover);
	-webkit-transition: max-height 0.4s;
	-moz-transition: max-height 0.4s;
	transition: max-height 0.4s;
}
.slide-buttons li.active a::before,
.slide-buttons li a:active::before,
.slide-buttons li a:focus::before {
	max-height: 100%;
}

.bottom-right{
	position: fixed;
	bottom: 50px;
	right: 30px;
	z-index: 1000;
}

body.light{
	background: var(--green);
}
body.light p{
	color: var(--dark-blue);
}
body.light h3{
	color: var(--dark);
}
body.light .cursor,
body.light .cursor2,
body.light .cursor3{
	mix-blend-mode: difference;
	z-index: 9999999 !important;
}
body.light .cursor.hover,
body.light .cursor2.hover,
body.light .cursor3.hover{
}
body.light .cursor{
	background-color: var(--dark-blue);
}

body.light .cursor.hover,
body.light .cursor2.hover,
body.light .cursor3.hover{
	opacity: 0;
}
body.light .cursor2.hover{
	opacity: 0;
}
body.light .slide-buttons li a{
	-webkit-text-stroke: 2px var(--dark-blue);
    text-stroke: 2px var(--dark-blue);
    -webkit-text-fill-color: transparent;
    text-fill-color: transparent;
    color: transparent;
	opacity: 1;
}
body.light .slide-buttons li a::before {
	-webkit-text-stroke: transparent;
    text-stroke: transparent;
    -webkit-text-fill-color: var(--dark-blue);
    text-fill-color: var(--dark-blue);
	color: var(--dark-blue);
}
body.light .hero-center-section.show{
	margit-top: 0;
	opacity: 0.9;
}
body.light .hero-center-section .left-text{
    color: var(--green);
    background: var(--green); 
}

/* #Media
================================================== */


@media (max-width: 1199px) { 
	.hero-center-section .left-text{
		font-size: 13vw;
	}
	.slide-buttons li{
		margin: 50px 0;
	}
	.slide-buttons li a{
		font-size: 80px;
	}
	.slide-buttons li a::before {
		font-size: 80px;
	}	
}

@media (max-width: 991px) { 
	.hero-center-section .left-text{
		font-size: 16vw;
	}
}

@media (max-width: 767px) {
	.cursor,
	.cursor2,
	.cursor3{
		display: none;
	}
	.hero-center-section .left-text{
		display: none;
	}
	.slide-buttons li{
		margin: 40px 0;
	}
	.slide-buttons li a{
		font-size: 60px;
		font-weight: 700;
	}
	.slide-buttons li a::before {
		font-size: 60px;
		font-weight: 700;
	}	
}

@media (max-width: 575px) {
	.slide-buttons li a{
		font-size: 50px;
		font-weight: 700;
	}
	.slide-buttons li a::before {
		font-size: 50px;
		font-weight: 700;
	}	
}