@import url('https://fonts.googleapis.com/css2?family=Merriweather:ital,opsz,wght@0,18..144,300..900;1,18..144,300..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Alan+Sans:wght@300..900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

header {
	padding-left: 48px;
	padding-right: 48px;

	padding-top: 32px;
	padding-bottom: 32px;

	background-color: #f5f5f5;

	max-width: 1000px;
	margin: auto;
}

ul:not(.toplist) {
	list-style-type: disc;
	padding-left: 13pt;

	display: flex;
    flex-direction: column;
    gap: 0px;

	margin-bottom: 6pt;
	margin-top: 6pt;
}

.toplist {
  list-style-type: none;

  margin: 0;
  padding: 0;
  padding-top: 0;

  overflow: hidden;
}

.hl {
  float: left;
  padding-right: 32px;
  padding-top: 16px;
}

.content {
	margin: 0 auto;
	max-width: 1000px;
	display: block;
	padding-left: 48px;
	padding-right: 48px;
	padding-top: 48px;
	padding-bottom: 48px;

	background-color: #ffffff;
}

.wrapper {
	width: 100%;
}

.homeheader {
	max-width: 550px;
	display: flex;
	justify-content: center;
	align-items: center;
}

.home {
	display: flex;
	justify-content: center;
	align-items: center;
	width: 100%;
	height: 100%;
}

.homebox {
	max-width: 550px;
	padding-bottom: 48px;
}

.homelist {
	display: flex;
	justify-content: space-between;
}

body {
	margin-top: 0px;
	margin-left: 0;
	margin-right: 0;
	margin-bottom: 0;

	width: 100%;

	font-family: "Inter";
	color: #333333;
	font-size: 13pt;

	background-color: #f0f0f0;
}

p {
	color: #333333;
	font-size: 13pt;

	margin-top: 0px;
	margin-bottom: 0px;

	line-height: 1.5;
	text-align: justify;
}


strong {
	color: #353535;
}

.header-title {
	color: #000000;

	font-size: 40px;

	margin: 0;

	font-family: "Inter";

	display: flex;
	align-items: center;
	justify-content: flex-start;
	
	white-space: normal;
}

h1 {
	color: #000000;
	margin: 0;
}

h2 {
	color: #000000;
	font-size: 22pt;
	margin-top: 0px;
	margin-bottom: 6px;
	font-family: "Inter";
}

h2:not(:first-child) {
	margin-top: 12px;
}

h3 {
	color: #000000;
	font-size: 16pt;
	margin-top: 0px;
	margin-bottom: 12px;
	font-family: "Inter";
}

.padtop {
	padding-top: 20px;
}

a {
	text-decoration: underline;
	color: #555555;
}

a:hover {
  color: #3498db;
}

.invis {
	text-decoration: none;
}

embed {
	width: 100%;

	margin: 0;
	padding: 0;
}

.logo {
	height: 48px;
	padding-right: 16px;
}

li a {
	text-decoration: underline;
	color: #555555;
	font-size: 13pt;
}

.fullwidthimg {
	width: 75%;
	margin: auto;
	display: block;
	padding-top: 12pt;
	padding-bottom: 12pt;
}



.gallery {
	display: flex;
	flex-direction: row;

	flex-wrap: wrap;
	justify-content: space-evenly;
	align-content: flex-start;
}

.project {
	/* max-width: 300px; */
	display: flex;
	flex-direction: column;
	flex-wrap: nowrap;

	justify-content: center;

	flex: 0 1 450px;

	padding: 24px;

	text-align: center;
	border-radius: 10px;

	text-decoration: none;
}

.project h3 {
	text-decoration: underline;
}

.projectimg {
	height: 100%;
	width: 100%;
	border-radius: 10px;
	object-fit: cover;

	aspect-ratio: 3/2;
	
	margin-bottom: 16px;
}

.project:hover {
	background-color: #f0f0f0;
}

.cdiv {
	display: flex;

	flex-direction: row;
	justify-content: center;
	flex-wrap: wrap;
	gap: 32px;

	padding-top: 32px;
	padding-bottom: 32px;
}

.cimg{
	border-radius: 10px;
	text-align: center;
	max-width: 500px;
	width: 100%;
	object-fit: cover;
	flex: 1 1 350px;

	aspect-ratio: 4/3;
}

.fit {
	object-fit:scale-down;
}

figure {
	margin: 0;
}

figcaption {
	font-size: 12pt;
	padding-top: 16px;
	text-align: center;
}

.tstack {
	display: flex;

	flex-direction: column;
	flex-wrap: nowrap;

	justify-content: space-between;

	gap: 16px;
}

.cvid {
	aspect-ratio: 16/9;
	flex: 0 1 47%;
}

pre {
	margin-bottom: 0;
}

code {
	border-radius: 10px;
}

@media (max-width: 767px) {
    p {
        font-size: 11pt; 
    }
    a {
        font-size: 11pt;
    }
    li a {
        font-size: 11pt;
    }
	body {
        font-size: 11pt;
    }
	figcaption {
		font-size: 10pt;
	}

	.header-title {
		font-size: 16pt;
	}
}
