html {
	opacity: 1;
	overflow-y: scroll;
}

.mobile-only {
	display: none;
}

#home_content_boxes {
	display: none !important;
}

nav a {
	float: left;
	display: block;
	padding: 0 9px;
	margin: 0 auto;
	border-bottom: none !important;
	color: #333 !important;
}

nav.top_nav a {
	color: #eee !Important;
}

nav a:first-of-type {
	padding-left: 16px;
}

nav a:hover {
	opacity: 0.8;
}

@media (prefers-color-scheme: dark) {
	body {
		color: #ddd !important;
		background: #111 !important;
	}

	nav.top_nav {
		background: #111 !important;
	}

	nav a {
		color: #ddd !important;
	}

	hr {
		background: #444 !important;
	}

	#newsletter_post {
		border-top: 1px solid #444 !important;
	}

	#home_posts_list .blog_entry_excerpt {
		color: #bbb !important;
	}

	.green-button {
		background: #ddd !important;
	}

	#side_menu a, #other_posts_list a {
		color: #ddd !important;
	}

	/*article,*/ .post_content_container_ext {
		border-top: 1px solid #444 !important;
	}

	#side_menu ul li, #other_posts_list ul li {
		border-top: 1px solid #444 !important;
	}

	#home_sidebar {
		background: #333 !important;
	}
	
	#home_about_bio {
		border: 1px solid #444 !important;
		background: #333 !important;
	}

	#header h2 {
		color: #eee !important;
	}

	.home_content_box_button {
		background: #222 !important;
	}
	
	.home_content_box_button:hover, .home-button:hover {
		background: #009688 !important;
		color: #ddd !important;
		/*border: 1px solid #009688 !important;*/
	}
	
	.home-button, .green-button, .home_content_box_button {
		color: #ddd !important;
	}
	
	.green-button {
		color: #ddd !important;
		background: #555 !important;
	}
	
	.home_content_box a, #prev_next a, #home_posts_list a {
		color: #ddd !important;
	}
	
	.meta a {
		color: #ddd !important;
	}

	.post tr:nth-child(even) {
		background: #444 !important;
	}

	.post tr:nth-child(odd) {
		background: #333 !important;
	}

	.post tr:first-of-type {
		background: #009688 !important;
	}
	
	.highlight, #cta {
		background: #333 !important;
		color: #ddd !important;
	}
	
	.light {
		display: none !important;
	}
	
	.dark {
		display: inline !important;
	}
	
	#fourohfour, nav {
		border-bottom: 1px solid #444 !important;
	}
	
	#footer, nav {
		border-top: 1px solid #444 !important;
	}
	
	.home_content_box {
		border-right: 1px solid #444 !important;
	}

	.home_about_box:last-of-type, .home_content_box:last-of-type {
		border-right: none !important;
	}
	
	.home-link {
		color: #999 !important;
		font-style: italic;
	}

	.blog_entry{
		border-bottom: 1px solid #444 !important;
	}
	
	a.home-index {
		color: #ddd !important;
	}
	
	.blog-index .home_content_box_title {
		border-top: 1px solid #444 !important;
	}
	
	#blog-index-cols h2 {
		background: none !important;
		border: 1px solid #666 !important;
		color: #ddd !important;
	}
	
	#blog-index-cols h2.green-title {
		background: #555 !important;
		border: 1px solid #666 !important;
		color: #ddd !important;
	}	
}

.dark {
	display: none;
}

.non_flex {
	display: none;
}

.flex {
	display: flex;
}

body {
	background: #ddd;
	color: #333;
	font-family: Roboto, Arial, sans-serif;
	font-size: 12pt;
	line-height: 1.4em;
}

#site-container {
	max-width: 845px;
	margin: 0 auto;
	padding: 0px;
}

#header {
	float: left;
	width: 765px;
	padding: 15px 40px 10px;
	background: #fff;
	border-top-left-radius: 5px;
	border-top-right-radius: 5px;
}

#header_left h2 {
	float: left;
}

#header_left {
	float: left;
}

#header_left a {
	float: left;
	border-bottom: none !important;
}

#header_right {
	float: right;
	padding-top: 9px;
}

#search_cont {
	float: right;
	padding-right: 5px;
}

#search {
	background: #eee;
	border: 1px solid #ddd;
	color: #333;
	border-radius: 5px;
	padding: 5px;
	font-family: 'Roboto', Arial;
	font-size: 11pt;
	height: 15px;
	margin-top: 9px;
	width: 175px;
}

#search:focus, #search:focus-visible {
	border-color: #333;
	outline: none;
	box-shadow: none;
}

.link_icon_twitter {
	float: right;
	padding-left: 12px;
	width: 18px;
	margin-top: 5px;
}

.link_icon_email {
	float: right;
	padding-left: 12px;
	width: 24px;
	margin-top: 2px;
}

.link_icon_about {
	float: right;
	padding-left: 12px;
	width: 18px;
	margin-top: 5px;
}

.link_icon_feed {
	float: right;
	padding-left: 12px;
	width: 18px;
	margin-top: 5px;
}

.link_icon_bluesky {
	float: right;
	padding-left: 10px;
	width: 21px;
	margin-top: 5px;
}

.link_icon_twitter:hover, .link_icon_email:hover, .link_icon_about:hover, .link_icon_feed:hover, .link_icon_bluesky:hover {
	opacity: 0.8;
}

.site_logo {
	width: 35px;
	height: 35px;
	float: left;
	padding-top: 3.5px;
	padding-right: 10px;
	padding-left:;
}

#home_about {
	float: left;
	padding-bottom: 20px;
}

#home_about_bio {
	float: left;
	width: 733px;
	padding: 15px;
	font-family: "Roboto", Arial, sans-serif;
	line-height: 1.5em;
	background: #eee;
	border: 1px solid #ddd;
	border-radius: 10px 10px 0 0;
	margin-top: 20px;
}

a.home_about_bio {
	color: #333 !important;
}

#home_about_newsletter {
	float: left;
	width: 733px;
	padding: 10px 15px;
	font-family: "Roboto", Arial, sans-serif;
	line-height: 1.4em;
	background: linear-gradient(to bottom right, #ede1c7, #e6dac0);
	border: 1px solid #ddd;
	border-top: none;
	border-radius: 0 0 10px 10px;
	margin-bottom: 5px;
	color: #333;
	font-size: 10pt;
}

#home_about_boxes, #home_content_boxes {
	float: left;
}

#home_content_boxes {
	border-top: none;
	border-bottom: none;
}

.home_about_box {
	float: left;
	width: 145px;
	padding: 0 5px 0px 0;
	margin: 0px 0 30px 0;
}

.home_content_box {
	float: left;
	width: 349px;
	padding: 0 15px 0 0;
	margin: 10px 20px 15px 0;
	border-right: 1px solid #ddd;
}

.home_about_box:last-of-type, .home_content_box:last-of-type {
	margin-right: 0;
	border-right: none;
}

#home_sidebar {
	float: right;
	width: 145px;
	margin-top: 20px;
	margin-left: 25px;
	margin-bottom: 40px;
	background: #eee;
	border-radius: 10px;
	padding: 15px;
}

.box_cols {
	width: 510px;
	float: left;
	column-count: 2;
	column-gap: 40px;
	margin: 30px 0 10px 0;
	padding: 20px;
	background: #eee;
}

.box_cols p {
	font-family: "Roboto", Arial, sans-serif !important;
	font-size: 11pt !important;
	/*text-align: justify !important;*/
}

.box_cols h3 {
	margin-top: 0 !important;
	padding-top: 0 !important;
	line-height: 1.15em !important;
	border-bottom: 1px solid #777;
	padding-bottom: 10px !important;
	margin-bottom: 8px !important;
	font-style: italic;
}

@media screen and (max-width: 859px) {

    .home_box {
		float: left !important;
        width: 100% !important;
		border-right: 0 !important;
		padding-right: 0 !important;
		border-bottom: 1px solid #ddd !important;
		padding-bottom: 15px !important;
		margin-bottom: 0px !important;
    }

    nav.top_nav a {
    	padding: 2px 10px !important;
    }

    nav.top_nav a:first-of-type {
		display:none !Important;
	}

    #home_sidebar, #newsletter_sidebar, .newsletter_disclaimer {
    	display: none;
    }

    #header, article, #footer, #prev_next, #home_container, #home_about_bio, #home_about_newsletter {
    	width: 90% !important;
    	padding-left: 5% !important;
    	padding-right: 5% !important;
    }

    #home_posts_list article {
    	width: 100% !important;
    }

    #header_left {
    	width: 240px !important;
    }

    #header_left h2 {
    	width: auto !important;
    }

    #header_right {
    	width: 160px !important;
    }

    img.half {
    	width: 100% !important;
    }
	
	.home_box:last-of-type {
		border-bottom: none !important;
	}
	
	.content_image_caption {
		width: 100% !important;
		margin: 0 !important;
	}
		
	blockquote, #newsletter_mid {
		margin-left: 0 !important;
		width: 90% !important;
		padding-left: 4% !important;
		padding-right: 5% !important;
	}
	
	#home_posts_list {
		width: 100% !important;
		padding-bottom: 5px !important;
	}
	
	#home_posts_list .blog_entry_date {
		width: 30% !important;
	}

	#home_posts_list .blog_entry_title {
		width: 100% !important;
	}
	
	.home_about_box .home_content_box_title_left {
		display: none !important;
	}

	.post_content_container_int {
		width: 100% !important;
	}
	
	.flex {
		display: none;
	}
	
	.non_flex {
		display: block;
	}

	nav.pagination {
		display: block !important;
		padding-bottom: 15px !important;
	}
	
	.blog-index-col {
		width: 100% !important;
	}
	
	#blog-index-cols h2,.blog-index-pinned-post {
		width: 91.5% !important;
	}
	
	.home_content_box_title_left.reading-list {
		width: 30% !important;
	}
	
	.home_content_box_title_right.reading-list {
		width: 70% !important;
	}

	.big_quote {
		padding-left: 5% !important;
		padding-right: 5% !important;
		margin-left: 0 !important;
		width: 90% !important;
	}

	.box_cols {
		columns: 1 !important;
		width: 90% !important;
		padding-left: 5% !Important;
		padding-right: 5% !important;
	}

	.box_cols h3 {
		margin-bottom: 0px !important;
	}

    .blog_entry {
        grid-template-columns: 1fr !important;
        grid-template-rows: auto auto auto !important;
    }

    .blog_entry_thumbnail {
        grid-column: 1 !important;
        grid-row: 1 !important;
        width: 100% !important;
        height: 160px !important;
        overflow: hidden !important;
    }

	.blog_entry_thumbnail img {
	    width: 100% !important;
	    height: 100% !important;
	    object-fit: cover !important;
	    display: block !important;
	}

    .blog_entry_title {
    	padding-top: 15px !important;
        grid-column: 1 !important;
        grid-row: 2 !important;
        width: auto !important;
        height: auto !important;
    }

    .blog_entry_excerpt {
        grid-column: 1 !important;
        grid-row: 3 !important;
        width: auto !important;
        height: auto !important;
    }

    .home-link {
    	padding-top: 5px !important;
    	line-height: 1.3em !important;
    }

    .desktop-only {
    	display: none !important;
    }

    .mobile-only {
    	display: inline !important;
    }
}

@media screen and (max-width: 859px) and (prefers-color-scheme: dark) {
	.home_box {
		border-bottom: 1px solid #555 !important;
    }
	
	.home_box:last-of-type {
		border-bottom: none !important;
	}
}

.home_content_box_title {
	width: 100%;
	float: left;
	display: none;
}

.home_content_box_title_left {
	float: left;
	width: 50%;
}

.home_content_box_button {
	float: right;
	padding: 5px 10px;
	margin-right: 10px;
	margin-top: 5px;
	color: #009688;
	background: #fff;
	border: 1px solid #009688;
	border-radius: 5px;
}

.home_content_box_title_left .home_content_box_button {
	float: left;
}

.home_content_box_button:hover, .home-button:hover {
	background: #009688;
	color: #fff;
}

.home_content_box_title_right {
	float: right;
	width: 50%;
	padding-bottom: 10px;
}

.home_about_box h2, .home_content_box h2, #home_posts_list h2 {
	float: left !important;
	font-size: 10pt !important;
	line-height: 1.2em !important;
	text-transform: uppercase !important;
	width: 100% !important;
	padding-bottom: 10px !important;
	margin-top: 10px !important;
	margin-bottom: 0 !important;
}

.home_about_box h2 {
	margin-top: 0 !important;
	padding-left: 5px !important;
}

.home_about_box p, .home_content_box p, #home_posts_list p {
	float: left !important;
	font-size: 11pt !important;
	padding: 0 0 10px 0 !important;
	line-height: 1.4em !important;
	font-family: "Roboto", Arial, sans-serif !important;
}

.home_about_box ul, .home_content_box ul {
	float: left !important;
	font-size: 11pt !important;
	line-height: 1.4em !important;
	margin: 0 !important;
	padding: 0 0 0 20px !important;
}

.home_about_box ul li, .home_content_box ul li {
	float: left !important;
	width: 100% !important;
	margin: 0 0 5px !important;
	padding: 0 0 0 5px !important;
}

.home_about_box p:last-of-type {
	padding-bottom: 5px;
}

.home_content_box a, #home_posts_list a {
	text-decoration: none;
	color: #333;
	border-bottom: none !important;
}

.year_label, #home_posts_list .blog_entry_date {
	font-weight: bold;
	font-family: "Roboto", Arial;
	padding-right: 5px;
	color: #009688;
}

#home_posts_list .blog_entry_date {
	float: left;
}

#home_posts_list .blog_entry_title {
	float: left;
	width: 550px;
	padding-top: 3px;
}

#home_posts_list .blog_entry_excerpt {
	float: left;
	width: 550px;
	color: #555;
	height: 75px;
	overflow: hidden;
	/*mask-image: linear-gradient(180deg, black 70%, transparent 100%);*/
}

.blog_entry, .blog_entry_date, .blog_entry_title {
	float: left;
}

.blog_entry {
	width: 100%;
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid #ddd;
}

.blog_entry_thumbnail {
	float: left;
	background: #333;
	width: 200px;
	height: 112.5px;
	margin-right: 15px;
}

.blog_entry:hover {
	opacity: 0.8;
}

#home_posts_list {
	width: 765px;
	float: left;
	padding: 25px 0px 20px;
}

.post_content_container_ext {
	float: left;
	width: 100%;
	border-top: 1px solid #ddd;
}

.post_content_container_int {
	float:left;
	width: 550px;
	padding-top: 5px;
	padding-bottom: 30px;
}

#prev_next {
	float: left;
	width: 765px;
	font-weight: normal;
	font-style: italic;
	font-size: 11pt;
	background: #fff;
	padding: 25px 40px 20px;
}

.prev {
	float: left;
	width: 45%;
	padding-right: 5%;
}

.next {
	text-align: right;
	float: right;
	width: 45%;
	padding-left: 5%;
}

#footer {
	float: left;
	width: 765px;
	border-top: 1px solid #ddd;
	padding: 20px 40px;
	margin: 0 0 10px;
	background: #fff;
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
	font-size: 11pt !important;
}

.home #footer {
	padding-top: 20px;
	margin-top: 0px;
}

.home-link {
	float: right;
	font-style: italic;
	color: #555;
}

img {
	float: left;
	width: 100%;
}

img.half {
	width: 70%;
	float: none;
	margin-left: auto;
	margin-right: auto;
}

img a {
	border: none;
	border-bottom: none !important;
}

.content_image {
	padding-top: 30px;
}

.content_image_caption {
	float: left;
	width: 70%;
	text-align: center;
	font-size: 10pt;
	line-height: 1.2em;
	margin: 0 15%;
	padding: 5px 0 10px;
	font-style: italic;
}

a {
	text-decoration: none;
	color: #009688;
	border-bottom: 1px solid #009688;
}

#prev_next a, #next a {
	text-decoration: none;
	color: #333;
}

h1, .blog_entry_title {
	float: left;
	font-size: 22pt;
	line-height: 1.2em;
	margin-bottom: 10px;
	width: 100%;
	font-weight: bold;
}

h1 {
	margin-top: 20px;
}

.blog_entry_title {
	font-size: 16.25pt;
	margin-bottom: 5px;
}

h2  {
	float: left;
	font-size: 24pt;
	margin: 10px 0;
}

#header h2 {
	color: #222;
}

h3 {
	float: left;
	margin: 0;
	padding-top: 50px;
}

p {
	float: left;
	width: 100%;
	padding: 25px 0 0;
	margin: 0;
}

article, #home_container {
	float: left;
	width: 765px;
	background: #fff;
	padding: 0 40px;
}

#home_container {
	border-top: none;
}

.post p, #home_posts_list .blog_entry_excerpt {
	font-family: "PT Serif", Georgia;
	font-size: 12pt;
	line-height: 1.7em;
}

.blog_entry_excerpt {
	line-height: 1.5em !important;
}

.post h3 {
	font-size: 18pt;
	width: 100%;
	line-height: 1.2em;
	margin-bottom: -2px;
}

.post h4 {
	float: left;
	font-size: 12pt;
	line-height: 1.4em;
	padding: 40px 0 0 0;
	margin: 0;
}

.post ol, .post ul {
	float: left;
	margin: 30px 0 -5px;
	padding: 0 0 0 5%;
	font-size: 12pt;
	line-height: 1.7em;
	width: 95%;
	font-family: 'PT Serif', 'Georgia', serif;
}

.post ol p, .post ul p {
	padding: 0px !important;
	margin: 0 10px 0 0 !important;
	width: 95% !important;
	float: right !important;
}

.post ol {
	list-style: none;
	counter-reset: item;
	font-family: 'PT Serif', 'Georgia', serif;
}

.post ol li {
	counter-increment: item;
	width: 100%;
}

.post ol li:before {
	content: counter(item) ".  ";
	color: #009688;
	font-weight: bold;
	margin-left: -23px;
	padding-right: 5px;
	width: 1.2em;
	text-align: center;
	display: inline-block;
}

.post li {
	float: left;
	padding-bottom: 15px;
	width: 100%;
}

blockquote, .highlight, #newsletter_mid {
	float: left;
	font-size: 12pt;
	line-height: 1.4em !important;
	border-left: 5px solid #009688;
	padding-left: 15px;
	width: 495px;
	margin: 20px 0 10px 20px;
	font-style: italic;
}

#newsletter_mid {
	border-left: 5px solid #ddd;
	margin-top: 35px;
	margin-bottom: 15px;
}

#newsletter_mid p {
	line-height: 1.5em !important;
}

#newsletter_mid button {
	float: left;
	background: none;
	color: #333;
	margin: 10px auto 0;
	padding: 3px 8px;
	border: 2px solid #009688;
	border-radius: 5px;
	font-family: Roboto, Arial;
	font-size: 10pt;
}

blockquote {
	margin-top: 30px;
}

figure {
	float: left;
	width: 100%;
	padding: 0;
	margin: 30px 0 0;
}

figcaption {
	float: left;
	width: 100%;
	text-align: center;
	font-size: 10pt;
	padding-top: 5px;
	font-style: italic;
}

.highlight {
	overflow-x: auto;
	width: 95%;
	margin-left: 0;
	background: #ddd;
	color: #333;
}

.highlight pre {
	margin-top: 0;
}

.language-python {
	float: left;
	width: 100%;
	padding-top: 5px;
	padding-bottom: 5px;
}

blockquote p:first-of-type, #newsletter_mid p:first-of-type {
	padding-top: 0 !important;
}

.meta {
	float: left;
	text-transform: uppercase;
	font-size: 12pt;
	padding-bottom: 20px;
}

.meta a {
	text-decoration: none;
	color: #333;
	border-bottom: none !important;
}

::selection {
	background: #009688;
	color: #fff;
}

.post table {
	float: left;
	width: 100%;
	margin-top: 20px;
	font-size: 11pt !important;
}

.post tr:nth-child(odd) {
	background: #eee
}

.post tr:nth-child(even) {
	background: #ddd
}

.post tr:first-of-type {
	background: #009688 !important;
}

.post tr:first-of-type a {
	color: #fff !important;
	border-bottom: 1px solid #fff !important;
}

.post table tr:first-of-type {
	border-bottom: 5px solid #009688;
	color: #fff;
}

.post td {
	padding: 5px;
}

#cta {
	float: left;
	background: #eee;
	color: #333;
	padding: 15px 15px;
	font-family: "Roboto", Arial, sans-serif;
	font-size: 11pt;
	line-height: 1.5em;
	margin: 40px 0 20px;
	border-radius: 10px;
}

#cta_button {
	color: #ffffff;
	background: #009688;
	border-radius: 5px;
	font-family: Roboto, Arial;
	border: none;
	padding: 10px;
	margin-top: -3px;
	font-size: 12pt;
}

#cta_button:hover {
	opacity: 0.8;
	cursor: pointer;
}

#cta a {
	color: #009688;
}

#fourohfour {
	float: left;
	width: 100%;
	border-bottom: 1px solid #ddd;
	padding-bottom: 20px;
}

#fourohfour p {
	padding-top: 5px;
}

nav {
	padding: 5px 0;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	font-size: 11pt;
	float: left;
	width: 100%;
	margin: 0;
	text-align: center;
}

nav.top_nav {
	background: #333;
  	text-transform: uppercase;
  	font-weight: 600;
}

hr {
	float: left;
	width: 100%;
	margin: 30px 0 -20px 0;
	border: none;
	background: #ddd;
	height: 1px;
}

.home-button {
	width: 135px;
	float: left;
	padding: 5px;
	margin-bottom: 5px;
	font-size: 11pt;
	color: #333;
	/*border: 1px solid #666;*/
	border-radius: 5px;
}

.green-button {
	color: #333;
	background: #ccc;
}

.green-button:hover {
	/*border: 1px solid #009688;*/
}

a.home-index {
	color: #333;
}

a.home-index:hover {
	opacity: 0.8;
}

#blog-index-pinned {
	float: left;
	padding: 0;
	line-height: 1.4em;
	width: 100%;
	/*border-top: 1px solid #ddd;*/
	margin-top: -25px;
	padding-top: 0px;
}

#blog-index-pinned .home_content_box_title {
	padding-top: 0 !important;
	margin-top: 0 !important;
	border-top: none !important;
}

.blog-index-pinned-post {
	float: left;
	border: 1px solid #009688;
	border-radius: 5px;
	padding: 5px 10px;
	width: 208px;
	margin-right: 20px;
	margin-bottom: 15px;
}

.blog-index-pinned-post:hover {
	opacity: 0.8;
}

.blog-index-pinned-post p {
	line-height: 1.4em;
	padding: 0 !important;
}

.blog-index-pinned-post-title {
	margin: 5px 0;
	font-weight: bold;
}

.blog-index .home_content_box_title {
	padding-top: 10px;
	border-top: 1px solid #ddd;
}

.blog-index-col {
	float: left !important;
	width: 50% !important;
}

.reading-list li {
	margin-bottom: 10px !important;
}

#side_menu, #interest_list, #other_posts_list {
	float: left;
}

#side_menu ul, #interest_list ul, #other_posts_list ul {
	float: left;
	margin: 0 !important;
	padding: 0 !important;
	list-style: none;
}

#side_menu ul li, #other_posts_list ul li {
	float: left;
	width: 130px !important;
	margin: 0 !important;
	padding: 5px !important;
	border-top: 1px solid #aaa;
	display: block;
}

#interest_list ul {
	padding-left: 5px !important;
}

#interest_list ul li {
	width: auto !important;
	float: left !important;
	padding: 1px 5px !important;
	margin: 0px 5px 5px 0 !Important;
	background: #ccc !important;
	display: block !important;
	border-radius: 5px !important;
	font-size: 9pt !important;
	text-transform: uppercase !important;
}

#other_posts_list ul li {
	font-size: 10pt !important;
	padding-top: 5px !important;
	padding-bottom: 5px !important;
}

#side_menu a, #other_posts_list a {
	color: #333;
}

#side_menu a:hover, #other_posts_list a:hover, #interest_list ul li:hover {
	opacity: 0.8;
}

#side_menu .first, #other_posts_list .first {
	border-top: none !important;
}

#home_sidebar p, #newsletter_sidebar p {
	font-size: 10pt !important;
	padding-left: 5px !important;
	width: 135px !important;
}

#newsletter_sidebar p {
	padding-top: 5px;
	line-height: 1.4em;
	font-family: "Roboto", Arial, sans-serif !important;
}

#home_sidebar .year_label {
	font-size: 11pt !important;
}

.blog-index #home_posts_list {
	width: 100% !important;
}

.blog-index h2 {
	width: 355px !important;
}

nav.top_nav a.current {
	color: #009688 !important;
}

#blog-index-cols {
	width: 100% !important;
	float: left !important;
	padding: 0px 0 20px !important;
	margin-top: -10px;
}

#blog-index-cols h2 {
	font-size: 12pt !important;
	width: 85% !important;
	color: #333 !important;
	background: none !important;
	border: 1px solid #666 !important;
	border-radius: 5px !important;
	padding: 5px 10px !important;
	font-weight: normal !important;
	margin-bottom: 5px !important;
}

#blog-index-cols h2.green-title {
	margin-top: 20px !important;
	margin-bottom: 5px !important;
	border: 1px solid #666 !important;
	color: #333 !important;
	background: #ddd !important;
}

#blog-index-cols ul {
	float: left !important;
	margin-top: 0px !important;
	margin-bottom: 20px !important;
}

#blog-index-cols li {
	float: left !important;
	width: 100% !important;
}

#blog-index-cols a:hover {
	opacity: 0.8 !important;
}

@media (prefers-color-scheme: dark) {
	#search {
		background: #333;
		border: 1px solid #444;
		color: #ddd;
	}
	#search:focus, #search:focus-visible {
		border-color: #ddd;
	}
	#header, article, #prev_next, #footer, #home_container {
		background: #222 !important;
	}
	#blog-index-cols h2 {
		color: #ddd !important;
	}
	#blog-index-pinned {
		/*border-top: 1px solid #444;*/
	}
	#blog-index-bestof {
		border-top: 1px solid #444 !important;
		border-bottom: 1px solid #444 !important;
	}
	#interest_list ul li {
		background: #555 !important;
	}
	code {
		background: #444 !important;
	}
	.big_quote {
		color: #ccc !important;
	}
	.box_cols {
		background: #333 !important;
		color: #ddd !important;
	}
	.box_cols h3 {
		border-bottom: 1px solid #ddd;
	}
	a.home_about_bio {
		color: #ddd !important;
	}
	#newsletter_mid {
		border-left: 5px solid #333 !important;
	}
	#newsletter_mid button {
		background: #009688 !important;
		color: white !important;
		padding: 5px 10px !important;
		border: none !important;
	}
}

.pagination {
	float: left !important;
	width: 100% !important;
	border: none !important;
	font-size: 11pt !important;
}

.pagination a {
	border-bottom: 1px solid #009688 !important;
	font-style: italic;	
}

.page_number {
	float: left !important;
	text-align: center !important;
	width: 40% !important;
}

div.page_previous {
	float: left !important;
	width: 30% !important;
	height: 24px !important;
}

div.page_next {
	float: right !important;
	width: 30% !important;
	height: 24px !important;
	text-align: right !important;
}

a.page_next {
	float: right !important;
}

article.blog_entry {
	border-top: none !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
}

#home_sidebar ul li {
	font-family: "Roboto", Arial, sans-serif !important;
}

h2.blog_index {
	margin-top: 0 !important;
	padding-top: 0 !important;
}

#blog-index-bestof {
	float: left;
	width: 100%;
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	margin: 10px 0;
	padding-bottom: 10px;
}

#blog-index-bestof a:hover {
	opacity: 0.8;
}

p code {
	font-family: "Courier New";
	background: #ddd;
	padding: 0 5px;
}

.big_quote {
	width: 510px;
	font-family: "PT Serif", Georgia;
	font-style: italic;
	font-size: 18pt;
	margin: 30px 0 10px 0;
	padding: 20px;
	border-left: 0;
	border-top: 2px solid #009688;
	border-bottom: 2px solid #009688;
}

#newsletter_post {
	float: left;
	text-align: center;
	margin: 30px 0 0px;
	border-top: 1px solid #ddd;
}

#newsletter_post h3 {
	font-size: 16pt !important;
	margin-bottom: 0px !important;
}

#newsletter_post p {
	padding: 5px 0 15px 0 !important;
	line-height: 1.5em !important;
}

#newsletter_post iframe {
	padding: 0 0 0 45px;
    -ms-zoom: 0.85;
    -moz-transform: scale(0.85);
    -moz-transform-origin: 0 0;
    -o-transform: scale(0.85);
    -o-transform-origin: 0 0;
    -webkit-transform: scale(0.85);
    -webkit-transform-origin: 0 0;
}

sup {
	vertical-align: top;
	position: relative;
	top: -0.5em;
	font-size: 0.6em;
}

p sup a {
	border-bottom: none !important;
}

#newsletter_sidebar {
	float: right;
	width: 145px;
	margin-top: 20px;
	margin-left: 25px;
	border-radius: 10px;
	padding: 15px;
	background: linear-gradient(to bottom right, #ede1c7, #e6dac0);
}

#newsletter_sidebar h2, #newsletter_sidebar h3 {
	float: left;
	font-size: 10pt;
	line-height: 1.2em;
	text-transform: uppercase;
	width: 100%;
	padding-bottom: 0px;
	margin-bottom: 0;
	padding-top: 0;
	margin-top: 0;
}

#newsletter_sidebar h3 {
	font-size: 20pt;
	padding-top: 2px;
	margin-left: -2px;
	margin-right: 2px;
}

a #newsletter_sidebar {
	color: #333 !important;
}

#newsletter_sidebar table, #newsletter_sidebar tr, #newsletter_sidebar td {
	background: none !important;
	padding: 0 !important;
	margin: 0 !important;
	color: #333 !important;
	border-spacing: 0 !important;
	border: none !important;
}

#newsletter_sidebar button, #home_about_newsletter button {
	float: left;
	width: 100%;
	margin-top: 10px;
	font-family: "Roboto", Arial, sans-serif;
	padding: 3px;
	font-size: 10pt;
	border: none;
	background: #4b5d75;
	color: #ddd;
	border-radius: 5px;
}

#home_about_newsletter button {
	float: none;
	width: auto;
	margin: 0;
	padding: 2px 10px;
	margin-top: 0px;
	margin-left: 6px;
}

#home_about_newsletter a {
	border-bottom: none !important;
}

#home_about_newsletter .mobile-only a {
  	border-bottom: 1px solid #009688 !important;
}

#newsletter_sidebar button:hover, #newsletter_mid button:hover, #home_about_newsletter button:hover {
	opacity: 0.8;
	cursor: pointer;
}

p.newsletter_disclaimer {
	float: right;
	text-align: center;
	width: 175px;
	font-size: 7pt !important;
	padding-top: 5px !important;
	font-family: "Roboto", Arial, sans-serif !important;
	line-height: 1.4em !important;
}

/* Mobile hamburger menu stuff */

.link_icon_menu, #mobile_nav {
	display: none !important;	
}

.link_icon_menu, .link_icon_close {
	float: right;
	height: 30px;
	width: 30px;
	margin-top: -3.5px;
	z-index: 9998;
}

.link_icon_close {
	width: 20px;
	height: 20px;
	margin-top: 10px;
}

#mobile_nav {
	position: fixed;
	margin-left: -8px;
	margin-top: -8px;
	width: 90%;
	height: 95%;
	padding: 10%;
}

#mobile_nav_links a {
	display: block;
	width: 90%;
	padding: 20px 0;
	text-align: center;
	font-size: 14pt;
}

#mobile_nav_icons {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	text-align: center;
	padding-top: 20px;
	margin-left: -10px;
	width: 90%;
}

#mobile_nav_header {
	width: 90%;
	padding-bottom: 20px;
	margin-bottom: 20px;
	float: left;
	border-bottom: 1px solid #009688;
}

#mobile_nav_icons a {
	float: right;
	border-bottom: none;
	width: 30px;
}

#mobile_nav.open {
	display: block !important;
	z-index: 9999 !important;
}

@media screen and (max-width: 859px) {
	#header {
		padding-bottom: 15px;
	}
	#search_cont {
        display: none !important;
    }
    #header_right {
    	width: 50px !important;
    }
	#search {
		display: none;
	}
	#header_right .link_icon_twitter, #header_right .link_icon_email, #header_right .link_icon_about, #header_right .link_icon_feed, #header_right .link_icon_bluesky {
		display: none !important;
	}
	nav {
		display: none;
	}
}

@media screen and (max-width: 859px) and (prefers-color-scheme: light) {
	#header {
		border-bottom: 1px solid #ddd;
	}
	.link_icon_menu.light {
		display: block !important;
	}
	#mobile_nav {
		background: #fff;
	}
	#mobile_nav_icons {
		margin-left: 10px;
	}
	#mobile_nav a {
		color: #333;
	}
}

@media screen and (max-width: 859px) and (prefers-color-scheme: dark) {
	#header {
		border-bottom: 1px solid #444;
	}
	.link_icon_menu.dark {
		display: block !important;
	}
	#mobile_nav {
		background: #222;
	}
	#mobile_nav_icons {
		margin-left: -19px;
	}
	#mobile_nav a {
		color: #ddd;		
	}
}