
html {
	margin: 0;
	padding: 0;
}
body {
	background-color: #f5f3f1;
	color: #333;
	font-family: Arial, Helvetica;
	/*font-size: 1.1em;*/
	/*font-size: 1.5vw;*/
	line-height: 1.3;
	padding: 0;
	margin: 0;
	min-height: 100vh;
	/*overflow-y: hidden;*/
	/*overflow-x: hidden;*/

}
header {
	background-color: #D0103A;
	color: #eee;
	box-shadow: inset 0 -10px 10px -10px #333;
	border-bottom: 1px solid #333;
}
.header-spacing {
	padding: 0.5em 1em 0.5em;
	max-width: 60em;
	margin: 0 auto;

}

header h1 {
	font-family: Arial, Helvetica;
	font-size: 3em; 
	margin: 0;
}


header a:link, header a:visited {
	color: white;
	text-decoration: none;
}

header .header-spacing {
	display: flex;
}

.header-links {
	flex-grow: 1;
	text-align: right;	
	margin-top: auto;
	margin-bottom: 0.5rem;
}

.header-links a {
	padding: 0 0.8em;
	padding-bottom: 1.0rem;
	margin-bottom: -1.0rem;
	  position:relative;
}

.header-links a.current,
.header-links a:hover {
	text-shadow: 0px 0px 5px #ddd, 0px 0px 5px #ddd;

}

.header-links a.current:after {
  width: 0; 
  height: 0;  
  border-left: 8px solid transparent; 
  border-right: 8px solid transparent; 
  border-bottom: 8px solid #f5f3f1; 
  display:block; 
  position:absolute; 
  bottom:-2px; 
  content:''; 
  left:50%;
  margin-left: -0.5rem;
}

.header-links a.current:before {
  width: 0; 
  height: 0;  
  border-left: 8px solid transparent; 
  border-right: 8px solid transparent; 
  border-bottom:8px solid #333; 
  display:block; 
  position:absolute; 
  bottom:-1px; 
  content:''; 
  left:50%;
  margin-left: -0.5rem;
}

.main-spacing {
	max-width: 60em;
	margin: 1em auto;
	/* make room for footer */
	padding: 0 1em 3em 1em;
	overflow: auto;
}

#keep-footer-down {
	overflow-x: hidden;
	min-height: 100vh;
	position: relative;
	margin: 0px;
	padding: 0px;
	display: block;
	overflow-y: hidden;
}

.viewport-wrapper {
	width: calc(100vw - 30px);
}

footer {
    box-shadow: inset 0 10px 10px -10px #333;
    background-color: #D0103A;

    color: #eee;
    display: block;
	height: 2.2em;
	position: absolute;
	bottom: 0px;
	width: 100%;
	margin: 0px;
	padding: 0;
	text-align: center;
}

.footer-spacing {
	padding: 0.5em 1em;
}

h2 {
	font-size: 1.5em;
	margin-bottom: .7rem;
	margin-top: 1.5rem;
	font-weight: bold;
}

p {
	margin-top: 1rem;
	margin-bottom: 1rem;
	max-width: 40em;
}

.post-summary {
	margin-top: 0;
	margin-bottom: 2rem;
}

h2 + p, .post-header + .post-summary, .main-spacing > *:first-child {
	margin-top: 0;
}

.listheader {
	display: flex;
	width: 100%;
}

.listheader p {
	flex-grow: 1;
	margin-top: 0;
}

.sortlinks {
	flex-grow: 0;
	text-align: right;
}

.sortlinks a:link {
	text-decoration: none;
}

.linkbox {
	display: flex;
	margin: 1em 0;
}

.linkbox-text {
	flex-grow: 1;
	padding: 0.8em 0;
	order: 1;
}

.linkbox-text > * {
	margin: 0.25rem 0;
}

.linkbox-text > *:first-child {
	margin-top: 0;
}

.linkbox-image {
	margin-right: 1.5em;
	order: 0;
}

.linkbox-image img {
	border: 1px solid #ccc;
	background-color: white;
	border-radius: 5px;

	display: inline-block;
}

h2.link {
	font-size: 1.2em;
	font-weight: normal;
}

h2.link a {
	text-decoration: none;
}

h2.link a:hover {
	text-decoration: underline;
}

.linkaddr {
	color: #555;
}

.linkdate {
	color: #555;
}

a:link {
	/* color: #1A0DAB;
	color: #0000EE; */
	color: #0C0CD1;
}

a:visited {
	color: #680CD1;
}

a.cogwheel {
	text-decoration: none;
	color: inherit;
	padding: 0 0.2em;
	opacity: 0.5;
	position: relative;
	top: -0.03em;
}
a.cogwheel:hover {
	opacity: 1;
}


	
/* mobile device */
@media only screen
and (max-width : 750px) {
    body {
    	font-size: 0.9rem;
    }

	header h1 {
		font-size: 2em; 
	}

	.linkbox {
		margin: 0.5em 0;
	}
	.linkbox-text {
		padding: 0 0 0.8rem 0;
	}
	.linkbox-image {
		display: none;
	}
	.viewport-wrapper {
		width: auto;
	}

	header .header-spacing {
		display: block; /* not flex */
	}

	.header-links {
		margin: 0.3rem 0;
	}

	.header-links a {
		padding-left: 0.4em;
		padding-right: 0.4em;
		/* 1.0 minus 0.3*/
		padding-bottom: 0.7rem;
		margin-bottom: -0.7rem;
	}

}

/* tag list */

.taglist {
	column-width: 15em;
	-moz-column-width: 15em;
	padding: 0 0 0 2em;
}

.taglist li {
	list-style: none;
	margin-bottom: 0.5em;
}

/* posts */

.post {
	border: 1px solid #888;
	padding: 0 2rem;
	margin: 0.5rem 0 1.5rem;
	background-color: #f7f7f7;
	box-shadow: 0 10px 10px -10px #333;
}

.post-header {
	display: flex;
	margin-bottom: 0.7rem;
	margin-top: 1.5rem;
}
.post-header > * {
	margin: 0;
}

.post-header h2 {
	flex-grow: 1;

}

.post-date {
	padding-top: 0.5rem;
	text-align: right;
	white-space: nowrap;
} 

.post-source {
	margin-top: -0.5rem;
	margin-bottom: 0.5rem;
	color: #555;
} 

.search-items .linkbox {
	margin: 0;
}

.searchbox {
	padding-left: 8em;
	padding-top: 2em;
	padding-bottom: 2em;
}

label.search {
	font-size: 160%;
	font-family: inherit;
	margin-right: 0.5em !important;
}

input.search {
	font-size: 160%;
	padding: 0.2em 0.35em 0.2em 0.35em;
	width: 20em;
	box-shadow: inset 0px 1px 3px -1px #333;
	background-color: hsl(30, 17%, 98%);
	border-radius: 2px;
	border: 1px solid  hsl(30, 5%, 70%);
}

.search-term {
    font-weight: bold;
}

.searchform {
	display: flex;
	width: 50%;
	vertical-align: middle;
}

.frontpage-search .searchform {
	margin: 2rem auto 4rem;
}

label[for="id_q"] {
	display: none;
}

#id_q {
	margin-right: 0.5em;
	flex: 1;
	font-size: 1.2em;
	padding: 3px 6px;
	border-radius: 2px;
	box-shadow: 0px 1px 2px #999 inset;	
	border: 1px solid #999;
}

#id_q:focus {
	box-shadow: 0px 1px 2px #999 inset, 0 0 2px highlight, 0 0 10px -6px highlight inset;	
}

#id_q::placeholder {
	font-style: italic;
}

.searchbutton {
	border: 1px solid #999;
	border-radius: 2px;
	--base-gradient: linear-gradient(#f7f4f2, #e9e7e5);	
	--base-shadow: 0px 1px 2px #999;
	--pressed-shadow: 0px 0px 2px #999;
	--focus-shadow: 0 0 2px highlight;
	background: var(--base-gradient);
	box-shadow: var(--base-shadow);	
	font-family: inherit;
	font-size: 100%;
	padding: 6px 12px;
	margin: 0px 0px 1px 0px;
}

.searchbutton:hover,
.searchbutton:active {
	background: linear-gradient(
		hsla(347, 86%, 88%, 0.2),
		hsla(347, 86%, 88%, 0.5)
		), var(--base-gradient)	;
}

.searchbutton:focus {
	box-shadow: 0px 1px 2px #999, 0 0 2px highlight;	
	box-shadow: var(--base-shadow), var(--focus-shadow);
}

.searchbutton:active {
	box-shadow: var(--pressed-shadow);	
}

.searchbutton:active:hover {
	--base-gradient: linear-gradient(to top, #f7f4f2, #e9e7e5);
	margin: 1px 0 0 0;
}

.search-results {
	display: flex;
}

.search-details {
	order: 2;
	width: 15em;
}