@font-face {
	font-family: Righteous;
	src: url(righteous.ttf);
}

body{
	background-image: url(background.png);
	font-family: Righteous, cursive;
	text-align: center;
	margin: 0;
	letter-spacing: .1em;
	overflow-x: hidden;
	background-attachment: fixed;
}

h1{
	color: white;
	font-size: 3em;
	background-color: black;
	margin: 0;
	padding: 15px;
	opacity: .9;
}

nav{
	background-color: black;
	display: grid;
	grid-template-columns: repeat(4,25%);
	opacity: .9;
}

nav>a{
	box-sizing: border-box;
	width:100%;
	display: inline-block;
	padding: 15px;
	color: white;
	text-decoration: none;
	transition: background-color .2s;
	font-size: 25px;
}

nav>a:hover{
	background-color: #222;
}

canvas{
	background-color: #222;
}

@media (max-aspect-ratio: 1/1) {
	main{
		display: block !important;
		grid-template-columns: 32% 33% 33%;
		grid-column-gap: 1%;
		grid-row-gap: 1%;
	}
	main>*{
		display: block !important;
		background-color: red;
		margin-bottom: 10px;
	}
}

main{
	display: grid;
	grid-template-columns: 32% 33% 33%;
	grid-column-gap: 1%;
	grid-row-gap: 1%;
}

#maze{
	grid-column-end: span 2;
	display: grid;
	grid-template-columns: 50% 50%;
}
#maze>canvas{
	max-width: 100%;
	max-height: 900px;
}

#battleship{
	display: block;
	background-image: url(projects/battleship.png);
	background-size: cover;
	padding: 0;
}
#battleship>h3,#blockus>h3,#ef>h3,#banana>h3,#chess>h3,#circuit>h3,#pacman>h3{
    background-color: rgba(0, 0, 0, .7);
    height: 100%;
    margin: 0;
    padding: 20px;
    box-sizing: border-box;
}
#ninny{
	grid-area: 3 / 2 / span 1 / span 2;
	display: grid;
	grid-template-columns: 50% 50%;
}
#ninny>h3{
	margin: 5px;
}
#ninny>canvas{
	max-width: 100%;
	max-height: 600px;
	margin-top: 5%;
}

#blockus{
	display: block;
	background-image: url(projects/blockus.png);
	background-size: cover;
	padding: 0;
}

#ef{
	display: block;
	background-image: url(projects/ef.png);
	background-size: cover;
	padding: 0;
}

#blockus>h3{
	padding-top: 15%;
}

#connect4{
	grid-column-end: span 2;
	display: flex;
}
#connect4>canvas{
	height: 500px;
/*	margin-top: 5%;*/
}
#connect4>h3{
/*	margin-top: 15%;*/
}

#hilbert{
	grid-row-end: span 2;
}
#hilbert>canvas{
	width: 100%;
}

#minesweeper>canvas{
	width: 100%;
}

#banana{
	display: block;
	background-image: url(projects/bananagrams.jpg);
	background-size: cover;
	padding: 0;
}

#chess{
	display: block;
	background-image: url(projects/chess.png);
	background-size: cover;
	padding: 0;
}

#circuit{
	display: block;
	background-image: url(projects/circuits.png);
	background-size: cover;
	padding: 0;
}

#pacman{
	display: block;
	background-image: url(projects/pacman.png);
	background-size: cover;
	padding: 0;
}



main>*{
/*	display: grid;*/
/*	grid-template-columns: 75% 25%;*/
	background-color: black;
	opacity: .9;
	color: white;
}

main>div>img,main>div>canvas{
/*	width: 100%;*/
}

main h3{
	font-size: 25px;
}

main>div>h3>p{
	display: block;
	margin: auto;
	width: 50%;
	padding: 20px;
	font-size: 18px;
}

#minesweeper{
	grid-template-columns: calc(100% - 422px) 422px;
}

button{
	background-color: transparent;
	border: 2px solid white;
	color: white;
	border-radius: 15px;
	padding: 10px;
	font-size: 20px;
	transition: background-color .2s, color .2s;
	outline: 0;
}

button:hover{
	background-color: white;
	color: black;
}

p>img{
	display: inline-block;
	transform: translateY(5px);
}

p>a{
	color: white !important;
}
