* 
{
	margin:0;
	padding:0;
	box-sizing:border-box;
}

@font-face
{
    font-family: 'chakrapetch';
    src: url('../fonts/ChakraPetch-Light.ttf');
    font-weight: normal;
    font-style: normal;
	font-display: swap;
}

body
{
	font-family: chakrapetch;

	color: rgb(223, 211, 211);
	background-image: url(../img/background/background.gif);
}

h2, h1, span
{
	text-align: center;
}

a
{
	text-decoration: none;
	color:#00ac00;
}

a:hover
{
	color:#007900;
}

.tablinks
{
	width:50%;
	margin-left: auto;
	margin-right: auto;
	display: flex;
	justify-content:flex-end;
}

.tablink
{
	font-size: 14px;
	width: 33%;

	margin:0px 8px;

	border-top-left-radius: 10px;
	border-top-right-radius: 10px;

	padding: 10px;
	background-color: rgb(68, 74, 77);

	margin-top: 15px;
	margin-bottom: -20px;

	border-top: none;
	border-left: none;
	border-right: solid 5px #222;
	border-bottom: solid 1px #333;
	
	transition:all 1s;

	font-family: chakrapetch;
	color: rgb(223, 211, 211);
}

.tablink:hover
{
	transform:translate(5px, 0px);
	box-shadow: 4.5px 0px #00000030;
	border-right: solid 5px #008000;
	overflow: hidden;
	transition:all 0.3s;
}

.activeTab
{
	transform:translate(5px, 0px);
	background-color: rgb(47, 51, 52);
	box-shadow: 4.5px 0px #00000030;
	border-right: solid 5px #008000;
}

.hidden
{
	display: none;
}

.me
{
	text-align: center;
	background-color: #131516;
	padding: 20px;
	
	border-bottom: solid 5px #222222;
}
.me h1
{
	padding-bottom: 20px;
}

.me div
{
	display: inline-block;
}

.me .name
{
	transform: scaleX(1);
	transition: all 0.6s;
}

.me:hover .name
{
	animation:linear;
	transform: scaleX(0);

	transition: all 0.6s;
}

.me .a, .me .i
{
	transition: all 0.5s;
}

.me:hover .a
{
	transform: translateX(70px);
	transition: all 1s;
}

.me:hover .i
{
	transform: translateX(30px);
	transition: all 1s;
}

.me h2
{
	transition: all 0.6s;
}

.me:hover h2
{
	transform: translateY(-15px);
	transition: all 0.6s;
}

.me .medias
{
	position:absolute;
	right:16%;
	top:15px;
	width:25px;
}

.me .medias .media
{
	margin-bottom:5px;
}

/* containers */
.container
{
	font-size: 17px;
	width:70%;
	display:block;
	margin-left: auto;
	margin-right: auto;
	margin-top:20px;
	overflow: auto;

	border-radius: 5px;

	padding: 20px;
	box-shadow: 0 4px 8px 0 rgba(0, 0, 0, 0.5), 0 6px 20px 0 rgba(0, 0, 0, 0.25);
	background-color: rgb(68, 74, 77);

	border-bottom: solid 5px #666666;
	border-right: solid 5px #222222;
}

.presentation h1
{
	text-align: center;
}

.presentation
{
	font-size: 20px;
}

#skills .skills-overview
{
	display:inline-block;
	padding-top : 50px;
	padding-left : 5%;
	width:45%;
	vertical-align:top;
}

#skills h2
{
	padding-bottom: 15px;
}

.skills-logos
{
	display:block;
	text-align: center;
	font-size: 25px;
	margin-top: 25px;
}

.skills-logos .logo
{
	display: inline-block;
	margin-top:50px;
	margin-right: 20px;

	width:150px;
}

.skills-logos .logo div
{
	margin-top: 15px;
}

.skills-logos .logo img
{
	transition: all 0.6s;
}

.skills-logos .logo:hover img
{
	transform: scale(1.2, 1.2);
}

#projects .shipped img
{
	margin:1.5%;
	width: 46.5%;
	display: inline-block;
	overflow: hidden;
	background-color: #000;
	box-shadow: 10px 10px #00000030;

	border-bottom: solid 5px #666666;
	border-right: solid 5px #222222;
	
	border-bottom-left-radius:5px;
	border-top-right-radius:5px;
}

#projects .filters
{
	margin-top : 15px;
}

#projects .filters div
{
	display:inline-block;
	padding: 5px;
	border:solid 1px #222222;
	border-radius: 5px;
}

#projects .filters div:hover
{
	background-color:#666666;
	cursor:pointer;
}

#projects .filters .filterSelected
{
	background-color: #131516;
}

#projects .filters .filterSelected:hover
{
	background-color: #222222;
}

#projects .item
{
	margin:1.5%;
	position: relative;
	display: inline-block;
	overflow: hidden;
	width: 30%;
	background-color: #000;
	box-shadow: 10px 10px #00000030;

	border-bottom: solid 5px #666666;
	border-right: solid 5px #222222;
	
	border-bottom-left-radius:5px;
	border-top-right-radius:5px;
	
	transition:all 1s;

	cursor:pointer;
}

#projects .notfiltered
{
	display: none;
}

#projects .item img, #projects .item video
{
	max-width: 100%;
	height:auto;
	margin: 0;
	margin-bottom: -5px;
	transition:all 0.2s;
	position: relative;
	display: inline-block;
}

#projects .item:hover
{
	transform:translate(5px, 5px);
	box-shadow: 4.5px 4.5px #00000030;
	border-bottom: solid 5px #7cfc00;
	border-right: solid 5px #008000;
	transition:all 0.3s;
}

#projects .item .dynamic
{	
	position: absolute;
	width: 100%;
	top: 0;
	left: 0;
	z-index:-1;
}

#projects .item:hover .dynamic
{
	display: inline;
	z-index:1;
}

#projects .item:hover .item-overlay::before
{
	content:'See details';
	display: block;
	font-weight: bold;
	font-size: 20px;
	color:rgb(241, 241, 241);
	padding-top: 35%;
}

#projects .item .item-overlay
{ 
	position: absolute;
	z-index: 2;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: #00000066;
	opacity: 1;
	text-align: center;
	transition: all 0.3s;
}

#projects .item .item-overlay span
{ 
	position: absolute;
	font-size:22px;
	z-index: 3;
	top: 42%;
	right: 0;
	left: 0;
	color: #fff;
}

.project-description
{
	display: none;
	position: fixed;
	z-index: 5;
	left: 0;
	top: 0;
	width:100%;
	height: 100%;
	border-radius: 10px;
	box-shadow: 0 4px 8px 0 #00000080, 0 6px 20px 0 #00000040;
	background-color: #00000080;;
}

.project-description .description-content
{
	position:relative;
	background-color: #222222;
	width:60%;
	height:auto;
	padding:40px;
	padding-bottom: 100px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border-radius: 10px;
	border:solid 5px rgb(90, 90, 90);

	font-size:18px;
	line-height: 19px;
}

.project-description .description-content .links
{
	position:absolute;
	bottom:35px;
	right:75px;
}

.download
{
	display:inline-block;
	width: 150px;
	text-align: center;
	text-decoration: none;
	padding:10px 5px;
	margin-left:20px;
	background-color: rgb(128, 190, 35);
	color:black;
	border-radius: 5px;
	transition:all 0.5s;
	font-size:18px;
	font-weight: bold;
	border-bottom:solid 3px rgb(79, 235, 65);
	border-right:solid 3px rgb(29, 143, 0);
}

.download:hover
{
	background-color: green;
	transform:translate(3px, 3px);
	color:#dfdede;
	border-bottom:solid 3px rgb(53, 156, 43);
	border-right:solid 3px rgb(22, 107, 1);
}

#source-code
{
	background-color: rgb(184, 184, 1);
	border-bottom:solid 3px rgb(232, 235, 65);
	border-right:solid 3px rgb(141, 143, 0);
}

#source-code:hover
{
	background-color: rgb(131, 131, 0);
	border-bottom:solid 3px rgb(166, 168, 48);
	border-right:solid 3px rgb(89, 90, 0);
}

.quit-button
{
	display:block;
	float:right;
	border-bottom:solid 3px rgb(235, 65, 65);
	border-right:solid 3px rgb(143, 0, 0);
    top:4%;
    right:3%;
	width:30px;
	height:30px;
	z-index: 5;
	background-color: red;
	margin-left:25px;
	text-align: center;
	box-shadow: 0 4px 8px 0 #6d0606e3, 0 6px 20px 0 #ff000040;
	border-radius: 3px;
	transition:all 0.5s;

	cursor:pointer;
}

.quit-button:hover
{
	border-bottom:solid 3px rgb(48, 156, 26);
	border-right:solid 3px rgb(8, 105, 5);
	background-color: green;
	box-shadow: 0 4px 8px 0 #066d0fe3, 0 6px 20px 0 #15ff0040;
	transform:translate(2px, 2px);
}

.specs
{
	padding-top: 25px;
	padding-left: 25px;
	font-size: 13px;
}
.specs li
{
	margin-bottom:5px;
}

.title
{
	text-align: center;
	font-weight: bold;
}

ul #impair
{
	background-color: #202324;
}

footer
{
	text-align: right;
	background-color: #131516;
	padding: 20px;
	margin-top: 20px;
}

.foot
{
	width:70%;
	display:block;
	margin-left: auto;
	margin-right: auto;
}

footer a
{
	margin-left:20px;
}

@media (max-width: 1600px)
{

	#projects .item
	{
		width:45%;
	}

	.skills-logos .logo
	{
		width:80px;
	}

	.skills-logos img
	{
		height: 70px;
		width: 70px;
	}
	
	.tablinks
	{
		width:70%;
	}
}

@media (max-width: 1300px)
{
	.item .links
	{
		position:relative;
		float:left;
	}
}

@media (max-width: 1200px) 
{
	.description-content
	{
		width:90% !important;
	}

	#skills .skills-overview
	{
		float:none;
		width:100%;
	}
}

@media (max-width: 800px)
{	
	.container
	{
		width:90%;
	}
	
	.me .medias
	{
		position:absolute;
		right:6%;
		top:15px;
		width:25px;
	}

	.tablinks
	{
		width:90%;
	}

	.tablink
	{
		font-size: 10px;
		padding: 10px 0px;
		transform:none;
		transition:none;
		margin-right:2px;
		margin-left:0px;
	}

	.tablink:hover
	{
		box-shadow: none;
		transform:none;
		transition:none;
	}

	.skills-logos .logo
	{
		font-size: 18px;
		width:60px;
	}

	.skills-logos img
	{
		height: 50px;
		width: 50px;
	}

	#projects .shipped img
	{
		margin:1.5%;
		width: 97%;
	}

	#projects .item
	{
		width:95%;
		height:auto;
	}

	.links
	{
		display:inline-block !important;
		right:25px !important;
	}

	.download
	{
		margin:0;
	}
}

@media (max-width: 600px)
{	
	.description-content
	{
		font-size: 15px !important;
	}

	.experience-title
	{
		font-size: 14px !important;
	}
	
	.experience-description
	{
		font-size: 12px !important;
	}
}


@media (max-width: 500px)
{	
	.download
	{
		width:110px !important;
		font-size: 13px !important;
	}
	.description-content
	{
		font-size: 13px !important;
		line-height: 14px !important;
	}

	.experience-title
	{
		font-size: 11px !important;
	}
	
	.experience-description
	{
		font-size: 9px !important;
	}
}

@media (max-height: 600px)
{
	.description-content
	{
		font-size:15px !important;
	}
}

.column-section
{
	display: flex;
	justify-content: center;
	align-items: flex-start;
	margin-top: 50px;
	margin-bottom: 50px;
}
  
/* Define the styles for each column */
.column
{
	width: 50%;
}
  
/* Define the styles for the title of each experience */
.experience-title
{
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 5px;
}
  
/* Define the styles for the description of each experience */
.experience-description
{
	font-size: 16px;
	line-height: 1.5;
	margin-bottom: 0;
}

.job
{
	border-left: solid 12px #333;
}

.study
{
	border-right: solid 12px #999;
	text-align: right;
}

.experience
{
	padding: 5px 15px;
    border-top: 3px solid transparent;
    border-bottom: 3px solid transparent;
}

.experienceDate
{
	font-size: 14px;
	width: 40px;
	position: relative;
	border-bottom: solid 1px #999;
	border-left: solid 1px #999;
	border-right: solid 1px #333;
    border-bottom: 2px solid transparent;
    border-image: linear-gradient(0.25turn, #999, #FFF, #333);
    border-image-slice: 1;
}
  
.experienceDateContent
{
	position: absolute;
	bottom: 0;
	text-align: center;
	width: 100%;
}