* {
    box-sizing: border-box;
}

:root {
    --page-width: 100em;
}

body {
    margin: 0 auto;
    font-family: Arial;
    -ms-overflow-style: none; /* for Internet Explorer, Edge */
    scrollbar-width: none; /* for Firefox */
    overflow-y: scroll; 
  }
  
/* Hide scrollbar for Chrome, Safari and Opera */
body::-webkit-scrollbar {
    display: none;
  }

[class*="col-"] {
    float: left;
    padding: 10px;
}



.row::after {
    content: "";
    clear: both;
    display: table;
    /*padding: 0px 0px 20px 20px;*/
}


.col-1 {width: 8.33%;}
.col-2 {width: 16.66%;}
.col-3 {width: 25%;}
.col-4 {width: 33.33%;}
.col-5 {width: 41.66%;}
.col-6, .force-col-6 {width: 50%;}
.col-7 {width: 58.33%;}
.col-8 {width: 66.66%;}
.col-9 {width: 75%;}
.col-10 {width: 83.33%;}
.col-11 {width: 91.66%;}
.col-12 {width: 100%;}

.site-title{
    font-size: 3em;
    text-align: center;
    color: #003366;
}

.face-image {
    text-align: center;
}

.container{max-width:var(--page-width); margin: auto; }

.image-grid {
    display: grid;
    grid-template-rows: auto;
    display: grid;
    grid-gap: 1em;
    grid-template-rows: auto;
    grid-template-columns: repeat(auto-fit,
            minmax(calc(var(--page-width) / 5), 1fr));
}

.gallery-image {
    margin-top: 10px;
    margin-bottom: 10px;
}

.nav-bar ul {
    list-style: none;
    padding: 0px 0px 0px 0px;
    text-align: center;
}

.nav-bar li {
    position:relative;
    display: inline-block;
}

.nav-bar li a:hover:after {
    position: absolute;
	content: "";
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	border-radius: 2px;
	box-shadow: 
		inset 0 1px 1px rgba(0,0,0,0.5), 
		0 1px 1px rgba(255,255,255,0.3);
}

.nav-bar li a:after { background: #003366; }

.nav-bar li a {
    color: #003366;
    text-decoration: none;
    text-align: center;
    padding: 0px 10px 0px 10px;
    font-size: 1em;
}

.no-list-style {
    list-style: none;
    text-align: center;
    padding: 0;
    margin: 0;
}

.footer {
    font-size: 1em;
    color: black;
    padding: 10px 0px 10px 0px;
    text-align: center;
}

.footer a {
    text-decoration: underline;
    color: #003366;
}

.footer a:hover {
    text-decoration: none;
}

.footer a:visited {
    color: #003366;
    text-decoration: underline;
}

.recent-post {
    padding: 0px 10px 10px 10px;
} 

.post-photo {
    min-height: 670px;
}

.cv-content-style h1:after,
.cv-content-style h2:after,
.cv-content-style h3:after {
	position: absolute;
	content: "";
	left: 0;
	top: 0;
	bottom: 0;
	width: 5px;
	border-radius: 2px;
	box-shadow: 
		inset 0 1px 1px rgba(0,0,0,0.5), 
		0 1px 1px rgba(255,255,255,0.3);
}

.cv-content-style h1:after { background: #003366; }
.cv-content-style h2:after { background: #003366; }
.cv-content-style h3:after { background: #003366; }

.cv-content-style h1 {
    /*margin: 1em 0 .6em 0;*/
	padding: 0 0 0 20px;
	font-weight: normal;
	color: #003366;
	/*font-family: 'Hammersmith One', sans-serif;
	text-shadow: 0 -1px 0 rgba(0,0,0,0.4);*/
	position: relative;
	font-size: 2.1875em;
	line-height: 37px;
	/*font-family: 'Questrial', sans-serif;*/
}

.cv-content-style h2 {
    margin: 1em 0 .6em 0;
	padding: 0 0 0 20px;
    font-weight: normal;
    color: #003366;
    position: relative;
    font-size: 1.875em;
    line-height: 37px;
}

.cv-content-style h3 {
    margin: 1em 0 .6em 0;
	padding: 0 0 0 20px;
    font-weight: normal;
    color: #003366;
    position: relative;
    font-size: 1.17em;
    line-height: 37px;
}

.cv-content-style .job-duration {
    font-size: 0.5em;
}

.cv-content-style .publish-date {
    font-size: 0.75em;
    padding: 0px;
    margin: 0 auto;
}

/*.cv-content-style h2 {
    display: block;
    font-size: 1.5em;
    margin-block-start: 0.83em;
    margin-block-end: 0.83em;
    margin-inline-start: 0px;
    margin-inline-end: 0px;
    font-weight: bold;
} */

a {
    color: #003366;
    text-decoration: none;
    padding: 0px 0px 0px 0px;
}

a:hover {
    text-decoration: underline;
}

a:visited {
    color: #003366;
}

.table-of-contents.box {
    padding: 10px 0px 0px 0px;
}

.table-of-contents.header {
background-color: #003366;
color: white;
}

.table-of-contents.title {
    color: white;
}

.table-of-contents.list nav ol {
    padding: 0px 0px 0px 15px;
    margin: 5px 0px 10px 0px;
}

.table-of-contents.list nav ol li {
    padding: 5px 0px 5px 0px;
}

pre {
    background: #f4f4f4;
    border: 1px solid #ddd;
    border-left: 3px solid #003366;
    color: #666;
    page-break-inside: avoid;
    font-family: monospace;
    font-size: 1em;
    line-height: 1.6;
    margin-bottom: 1.6em;
    max-width: 100%;
    overflow: auto;
    padding: 1em 1.5em;
    display: block;
    word-wrap: break-word;
}

.article-link {
    font-size: 1em;
}

.article-metadata {
    font-size: 0.8em;}

* {
    box-sizing: border-box;
}

@media only screen and (max-width: 600px) {
    /* On smallest devices, each column on top of each other */
    [class*="col-"] {
        width: 100%;
        height: 100%;
    }
    .force-col-6 {width: 50%;}
    a {text-decoration: underline;}
    a:hover {text-decoration: none;}
    .meta-info {
        padding: 15px 0px 0px 0px;
    font-size:1em;}
    .face-image {
        height: 200px;
        text-align: center;
        min-height: 15vh;
        height: auto;
    }
    .full-photo {
        width: 100%;
    }
    .image-grid {
        display: grid;
        grid-template-rows: auto;
        display: grid;
        grid-gap: 1em;
        grid-template-rows: auto;
        grid-template-columns: repeat(auto-fit,
                minmax(calc(var(--page-width) / 5), 1fr));
    }

}

.git-info{
    font-size: 0.75em;
}



/*@media only screen and (min-width: 600px) {} */

@media only screen and (min-width: 768px) {

    .force-col-6 {width: 50%;}
    .site-title{
        font-size: 5em;
    }

    

    .footer {
        font-size: 1.25em;
    }
    .cv-content-style h1 {
        font-size: 3em;
	    line-height: 1em;
    }
    .cv-content-style h2 {
        font-size: 2.25em;
        line-height: 1em;
    }
    .cv-content-style h3 {
        font-size: 1.7em;
        line-height: 1em;
    }
    .cv-content-style .job-duration {
        font-size: 0.5em;
    }
    .cv-content-style .publish-date {
        font-size: 0.75em;
    }
    pre {
        font-size: 1.5em;
        line-height: 1.6;
    }
    .article-metadata {
        font-size: 1.2em;}
    .nav-bar li a {
        font-size: 1.5em;
    }
    .meta-info{
        font-size:1.5em;
        padding: 90px 0px 0px 0px;
    }
    p {
        font-size:1.2em;
    }
    .article-link {
    font-size: 1.8em;
    img {
        width: 100%;
    }
}

} 

@media only screen and (min-width: 992px) {
}

@media only screen and (min-width: 1200px) {}



.text-center {
    text-align: center;
}