/**
 * Theme Name: Lupus Research Alliance 2025
 * Description: Custom theme for Lupus Research Alliance
 * Version: 2025.02.03
 * Author: Michael Niggel
 * Author URI: https://www.lupusresearch.org/
 */

@font-face {
	font-display: swap;
	font-family: 'Geologica';
	font-weight: 100 900;
	src: local(''),
		url('fonts/Geologica-VariableFont_CRSV,SHRP,slnt,wght.woff2') format('woff2');
}

:root {
	--font-base-thin: 100;
	--font-base-extralight: 200;
	--font-base-light: 300;
	--font-base-regular: 400;
	--font-base-medium: 500;
	--font-base-semibold: 600;
	--font-base-bold: 700;
	--font-base-extrabold: 800;
	--font-base-black: 900;
	--font-base-style-normal: normal;
	--font-base-style-oblique: oblique 10deg;
	--font-base-oblique: oblique 12deg;

	--color-black-max: 0, 0, 0;
	--color-black-rich: 34, 34, 34;
	--color-black: 89, 89, 89;
	--color-ltgray: 238, 239, 240;
	--color-ltpurple: 236, 227, 247;
	--color-dkpurple: 27, 2, 45;
	--color-white: 255, 255, 255;
	--color-purple: 100, 51, 133;
	--color-ltmagenta: 250, 224, 242;
	--color-magenta: 158, 36, 123;
	--color-red: 167, 32, 39;
	--color-blue: 66, 90, 112;

	--layout-full: 85rem;
	--layout-wide: 65rem;
	--layout-content-width: 65rem;
}

/* ============== */
/* Element defaults */

html, body {
	overflow-x: hidden;
	overflow-x: clip;
}

html {
	scroll-padding-top: 16vh;
	scroll-behavior: smooth;
}

body {
	line-height: 1.25;
	background: rgb(var(--color-white));
	color: rgb(var(--color-black));
	font-family: 'Geologica', sans-serif;
	font-weight: var(--font-base-light);
	font-variation-settings:
	    "CRSV" 1,
	    "SHRP" 0;
}

@media (max-width: 20em) {
	body {
		-ms-hyphens: auto;
		-moz-hyphens: auto;
		-webkit-hyphens: auto;
		hyphens: auto;
	}
}

a {
	color: rgb(var(--color-purple));
}

:focus-visible,
button:focus-visible {
	outline: solid 0.25rem rgba(var(--color-blue), 0.8);	
}

h1, h2, h3, h4, h5, h6 {
	text-wrap: balance;
	line-height: 1.25;
}

h1 {
	font-size: 2em;
	font-weight: var(--font-base-light);
	color: rgb(var(--color-purple));
	margin: 0;
	clear: inline-start;
}

h2 {
	font-size: 1.5em;
	margin: 0;
	font-weight: var(--font-base-light);
	color: rgb(var(--color-purple));
	clear: inline-start;
}

h3 {
	font-size: 1.2em;
	margin: 1rem 0 0.25rem;
	font-weight: var(--font-base-bold);
}

h4 {
	font-size: 1.1em;
	margin: 0.5em 0 0;
	color: rgb(var(--color-purple));
}

h5 {
	font-size: 1em;
	margin: 0.5em 0 0;
}

h6 {
	font-size: 0.83em;
	margin: 0.5em 0 0;
}

ul, ol {
	padding-left: 1.5em;
	margin: 0 0 1em;
}

p + ul, p+ ol {
	margin-top: 0.5em;
}

li {
	margin-bottom: 0.5em;
}

blockquote {
	margin: 0.5rem 0;
	line-height: 1.1;
	text-wrap: balance;
	color: rgb(var(--color-purple));
}

@media (min-width: 42em) {
	body {
		line-height: 1.6;
	}

	h1 {
		font-size: 3em;
	}

	h2 {
		font-size: 2em;
	}

	h3 {
		font-size: 1.5em;
	}

	h4 {
		font-size: 1.2em;
	}

	ul, ol {
		padding-left: 2em;
	}
}

p {
	margin: 0;
}

p + p,
ul + p,
ol + p,
P + div,
ul + div,
ol + div {
	margin-top:  1rem;
}

* + h2 {
	margin-top: 2rem;
}

* + h3, * + h4, * + h5, * + h6 {
	margin-top: 1rem;
}

h1 + ul, h2 + ul, h3 + ul, h4 + ul, h5 + ul, h6 + ul,
h1 + ol, h2 + ol, h3 + ol, h4 + ol, h5 + ol, h6 + ol {
	margin-top: 1rem;
}

figure {
	margin: 0;
}

img {
	max-width: 100%;
	height: auto;
}

iframe {
	max-width: 100%;
}

b, strong {
	font-weight: var(--font-base-extrabold);
}

small {
	font-size: 0.8em;
}

button, input, select, textarea {
	color: #222;
}

::-moz-selection {
	background: rgba(var(--color-blue), 0.8);
	color: rgb(var(--color-white));
	text-shadow: none;
}

::selection {
	background: rgba(var(--color-blue), 0.8);
	color: rgb(var(--color-white));
	text-shadow: none;
}

table {
	border-collapse: collapse;
	display: block;
	max-width: 100%;
	overflow: auto;
}

tr:nth-child(2n) {
	background-color: rgb(var(--color-ltgray));
}

td {
	border: solid 1px rgb(var(--color-ltgray));
	padding: 0.5em;
}

hr {
	display: block;
	height: 1px;
	border: 0;
	border-top: 1px solid rgb(var(--color-ltpurple));
	margin: 3rem 0;
	padding: 0;
}

form>ol,
fieldset>ol {
	margin: 0;
	padding: 0;
	list-style: none;
}

form>ol>li,
fieldset>ol>li {
	margin: 0;
	padding: 0;
}

input, textarea {
	box-sizing: border-box;
	width: 30em;
	max-width: 100%;
	background: rgb(var(--color-white));
	border: solid thin rgb(var(--color-purple));
	padding: 0.5em;
}

input[type="checkbox"],
input[type="radio"] {
	width: auto;
}

button,
.button,
.btn.btn-default,
input[type="submit"],
input[type="button"] {
	background: rgb(var(--color-purple));
	color: rgb(var(--color-white));
	text-align: center;
	text-decoration: none;
	display: inline-block;
	border: solid 0.2em rgb(var(--color-purple));
	border-radius: 0.25rem;
	padding: 0.25rem 1rem;
	cursor: pointer;
	font-weight: 700;
	font-size: 0.8rem;
	transition: color 0.2s, background-color 0.2s;
	width: auto;
}

button:hover,
button:focus-visible,
.button:hover,
.button:focus-visible,
.btn.btn-default:hover,
.btn.btn-default:focus-visible,
input[type="submit"]:hover,
input[type="submit"]:focus-visible,
input[type="button"]:hover,
input[type="button"]:focus-visible {
	background-color:rgb(var(--color-white));
	color: rgb(var(--color-purple));
	text-decoration: none;
}

main button,
main .button,
main .btn.btn-default,
main input[type="submit"],
main input[type="button"] {
	font-size: 1.2em;
}

main a[href="#"] {
	font-size: 0.8em;
}

::backdrop {
	background-color: rgba(0,0,0,0.8);
}


/* ============== */
/* Common */

.structure-only {
	display: none;
}

/* ============== */
/* Main layout */

body {
	display: flex;
	flex-direction: column;
	width: 100%;
	min-height: 100vh;
}

header {
	order: 10;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	padding: 0;
	margin: 0;
	width: 100%;
	background: rgba(var(--color-white), 0.97);
	box-shadow: 0 0 0.25em 0.25em rgba(0, 0, 0, 0.03);
}

/*
@supports (backdrop-filter: blur(1em)) {
	header {
		background: rgba(var(--color-white), 0.80);
		backdrop-filter: blur(1em);
	}
}
*/

body.admin-bar {
	min-height: calc(100vh - 32px);
}

.admin-bar header {
	top: 32px;
}

@media (max-width:782px) {
	body.admin-bar {
		min-height: calc(100vh - 46px);
	}

	.admin-bar header {
		top: 46px;
	}
}

header .site-title {
	pointer-events: none;
	clip: rect(1px, 1px, 1px, 1px);
	position: absolute;
	font-size: 1rem;
	margin: 0;
}

#skip {
  position: absolute;
  top: 0;
  z-index: 99999;
}

#skip a,
#skip a:hover,
#skip a:visited {
  position: absolute;
  left: 0;
  top: -500px;
  width: 1px;
  height: 1px;
  overflow: hidden;
  color: #00f;
  background: #fff;
  padding: 1em;
  border: solid 1px #000;
}

#skip a:active,
#skip a:focus-visible {
  position: static;
  width: auto;
  height: auto;
}

.header-content {
	margin: 0 auto;
	max-width: var(--layout-full);
	height: auto;
	padding: 0 1rem;
	column-gap: 1em;
	display: grid;
}

#logo {
	grid-area: logo;
	align-self: center;
	justify-self: start;
	width: 11.125rem;
	margin: 0.5rem 0;
	max-width: 100%;
}

#logo a {
	display: block;
	position: relative;
	width: 100%;
	height: 100%;
}

#logo svg,
#logo img {
    width: 100%;
    height: 100%;
	display: block;
	object-fit: contain;
	object-position: 0% 50%;
}

#search-main {
	grid-area: search;
	padding: 0 0.5em;
	text-align: right;
	display: flex;
	align-items: center;	
}

.search-form {
	width: 18em;
	max-width: calc(100vw - 2rem);
}

.search-form label {
	width: 11.5em;
	display: inline-block;
	flex: 1 0 0;
}

.search-form .search-field {
	background: #fff;
	border: none;
	padding: 0.25rem;
	font-family: inherit;
	font-size: inherit;
	width: 100%;
	height: 100%;
	box-sizing: border-box;
	display: block;
	font-size: 1em;
	border: solid 0.125em rgb(var(--color-black));
}

.search-form .search-submit {
	color: rgb(var(--color-white));
	text-align: center;
	text-transform: uppercase;
	text-decoration: none;
	display: inline-block;
	cursor: pointer;
	padding: 0 0.5rem;
	box-sizing: border-box;
	margin-top: 0;
}

.js-on body > header .search-form {
	display: none;
	padding: 0.5rem;
	background-color: rgb(var(--color-ltpurple));
	gap: 0.5rem;
	position: absolute;
	z-index: 1;
	right: 0;
	top: 0;
	align-items: stretch;
	opacity: 0;
	transition: opacity 400ms;
	pointer-events: none;
}

@media(min-width:62em) {
	.js-on body > header .search-form {
		top: 100%;
		right: 0.5em;
	}
}

.js-on body > header .search-form.open,
.js-on body > header .search-form:focus-within {
	display: flex;
	opacity: 1;
	pointer-events: auto;
}

.search-show {
	background: url(img/magnifier.svg) 50% 50% no-repeat;
	background-size: auto 1em;
	padding: 0 0 0 1.5em;
	border: none;
	font-family: inherit;
	font-weight: inherit;
	font-size: inherit;
	display: block;
	height: 1.6em;
}

.search-show:hover,
.search-show:focus-visible {
	background-color: transparent;
}

#header-utils {
	grid-area: utils;
}

#header-utils ul {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

#header-utils li {
	flex: 0 1 auto;
}

#header-utils li a {
	background: rgb(var(--color-purple));
	color: rgb(var(--color-white));
	text-align: center;
	text-transform: uppercase;
	text-decoration: none;
	display: inline-block;
	border: solid 0.2em rgb(var(--color-purple));
	border-radius: 0.25rem;
	padding: 0.25rem 1rem;
	cursor: pointer;
	font-weight: 700;
	font-size: 0.8rem;
	transition: color 0.2s, background-color 0.2s;
	width: auto;
}

#header-utils li a:hover,
#header-utils li a:focus-visible {
	background-color:rgb(var(--color-white));
	color: rgb(var(--color-purple));
	text-decoration: none;
}

#header-utils li:nth-child(3) a {
	background: rgb(var(--color-red));
	border: solid 0.2em rgb(var(--color-red));
}

#header-utils li:nth-child(3) a:hover,
#header-utils li:nth-child(3) a:focus-visible {
	background-color:rgb(var(--color-white));
	color: rgb(var(--color-red));
}

#nav-main {
	grid-area: nav;
	align-self: end;
	color: rgb(var(--color-purple));
	text-wrap: balance;
}

#nav-main a {
	color: rgb(var(--color-purple));
	text-decoration: none;
	line-height: 1.1;
	display: inline-block;
}

#nav-main ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

#nav-main li {
	padding: 0;
}

#nav-main>ul {
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: flex-end;
}

#nav-main>ul>li {
	margin: 0;
	position: relative;
	display: flow-root;
	padding-bottom: 0.5rem;
}

#nav-main>ul>li.current-menu-ancestor>a,
#nav-main>ul>li.current-menu-item>a {
	font-weight: 700;
}

#nav-main li li.current-menu-ancestor>a::before,
#nav-main li li.current-menu-item>a::before {
	content: '\25cf';
	color: rgb(var(--color-magenta));
	padding-right: 0.25em;
}

#nav-main ul.sub-menu {
	padding-left: 0.5rem;
}

#nav-main>ul>li>ul.sub-menu {
	display: none;
	opacity: 0;
	transition: all 0.2s allow-discrete;
	padding: 0 1rem;
	margin: 0;
}

#nav-main>ul>li.show-menu>ul.sub-menu {
	display: block;
	opacity: 1;
	transition-duration: 0.5s;
}

@starting-style {
	#nav-main>ul>li.show-menu>ul.sub-menu {
		opacity: 0;
	}
}

#nav-main>ul>li>ul.sub-menu li {
	margin: 0.5rem 0;
}

#nav-main>ul>li>ul.sub-menu>li {
	margin: 0.5rem 0;
}

#nav-main>ul>li>ul.sub-menu>li+li {
	margin-top: 1.5rem;
}

#nav-main>ul>li>ul.sub-menu>li>a {
	font-weight: bold;
}

#nav-main button {
	padding: 0 1rem;
	background: transparent;
	color: inherit;
	border: 0;
}

#nav-main button::before {
	content: '\25BC';
}

#nav-main .show-menu button::before {
	content: '\25B2';
}

@media (max-width:61.9999em) {
	body.nav-over {
		max-height: 100%;
		overflow-y: clip;
	}

	header {
		overflow-x: clip;
	}

	body.nav-over header {
		max-height: calc(100vh - 44px);
		overflow-y: auto;
	}

	.header-content {
		padding: 0;
		max-width: 100%;
		grid-template-areas:
			"logo search hamburger"
			"nav nav nav"
			"utils utils utils";
		grid-template-columns: 1fr auto auto;		
	}

	#logo {
		order: 1;
		width: auto;
		height: 3rem;
		margin: 0.25rem 0 0.25em 1rem;
	}

	.js-on .hamburger {
		order: 1;
		display: block;
		margin: 0 1rem 0 0;
		padding: 0 2.75em 0 0;
		line-height: 1.6;
		background: url(img/hamburger.svg) center center no-repeat;
		width: calc(100% - 11rem);
		text-align: right;
		border: none;
		min-height: 2.75em;
		grid-area: hamburger;
		align-self: center;
	}	

	.js-on .nav-over .hamburger {
		background-image: url(img/close.svg);
	}

	#nav-main {
		order: 2;
		flex: 1 1 100%;
		margin-top: 0.5em;
		padding: 0 1rem;
	}

	.js-on #nav-main,
	.js-on #header-utils {
		display: none;
	}

	.js-on .nav-over #nav-main,
	.js-on .nav-over #header-utils {
		display: block;
	}

	.js-on .nav-over {
		max-height: 100vh;
		overflow: hidden;
	}

	.js-on .nav-over header {
		position: absolute;
		background: rgb(var(--color-white));
	}

	.js-on .nav-over .header-content {
		padding: 0 0 1.5rem;
	}

	.js-on .nav-over .search-form {
		top: 3rem;
	}

	#nav-main>ul>li {
		width: 100%;
		border-top: solid 1px rgb(var(--color-ltpurple));
		padding: 1rem 0;
		display: grid;
		grid-template-columns: 1fr auto;
		gap: 0.5rem;
	}

	#nav-main>ul>li>ul.sub-menu {
		grid-column: 1 / -1;
		grid-row: 2;
	}

	.nav-over main:after {
		position: fixed;
		background: rgba(0, 0, 0, 0.75);
		top: 0;
		bottom: 0;
		left: 0;
		right: 0;
		content: " ";
		display: block;
		z-index: 10;
	}	

	.sub-menu {
		padding-left: 1em;
	}
	
	#header-utils {
		padding: 0 1rem;
	}
}

@media(min-width: 62em) {
	.header-content {
		padding: 0 2rem;
		width: 100rem;
		max-width: calc(100% - 4rem);
		grid-template-areas:
			"logo utils search"
			"nav nav nav";
		grid-template-columns: auto 1fr auto;
	}

	#logo {
		order: 2;
		width: 10em;
		margin-left: 0.5rem 0 0.5rem 0;
	}

	.js-on .hamburger {
		display: none;
	}

	#header-utils {
		align-content: center;
	}

	#search-main {
		position: relative;
		align-content: center;
	}

	.js-on body > header .search-form {
		top: 50%;
		transform: translateY(-50%);
		font-size: 1.5rem;
	}

	#nav-main>ul>li.menu-item-has-children:hover>a,
	#nav-main>ul>li.menu-item-has-children:focus-visible>a {
		background: rgb(var(--color-ltpurple));
		color: rgb(var(--color-black-rich));
		position: relative;
	}

	#nav-main>ul>li.menu-item-has-children:hover>a::after,
	#nav-main>ul>li.menu-item-has-children:focus-visible>a::after {
		content: ' ';
		position: absolute;
		top: -0.25em;
		left: -0.25em;
		right: -0.25em;
		bottom: -0.25em;
		border-radius: 0.25em;
		background-color: rgb(var(--color-ltpurple));
		z-index: -1;
	}

	#nav-main a:hover,
	#nav-main a:focus-visible,
	#nav-main>ul>li:hover>a:hover,
	#nav-main>ul>li:hover>a:focus-visible {
		background: rgb(var(--color-purple));
		color: rgb(var(--color-white));
		position: relative;
		outline: 0;
	}

	#nav-main a:hover::after,
	#nav-main a:focus-visible::after,
	#nav-main>ul>li:hover>a:hover::after,
	#nav-main>ul>li:hover>a:focus-visible::after {
		content: ' ';
		position: absolute;
		top: -0.25em;
		left: -0.25em;
		right: -0.25em;
		bottom: -0.25em;
		border-radius: 0.25em;
		background-color: rgb(var(--color-purple));
		z-index: -1;
	}

	#nav-main>ul {
		gap: 1rem;
	}

	#nav-main button {
		padding: 0.25rem;
		margin: 0 0 0 0.25rem;
		vertical-align: 0.2em;
	}

	#nav-main button[aria-expanded=true] {
		background: rgb(var(--color-magenta));
		color: rgb(var(--color-white));
	}

	#nav-main button::before {
		content: '\25BE';
	}
	
	#nav-main .show-menu button::before {
		content: '\25B4';
	}

	#nav-main>ul>li.hovered>ul {
		position: relative;
	}

	#nav-main>ul>li>ul.sub-menu {
		display: none;
		position: absolute;
		left: 0;
		width: 16rem;
		columns: 15rem;
		widows: 1;
		orphans: 1;
		background: rgba(var(--color-white), 0.85);
    	backdrop-filter: blur(1em);
		z-index: 1;
		box-shadow: 0 0.25em 0.5em -0.25em rgba(0,0,0,0.15);
	}

	#nav-main>ul>li.hovered>ul.sub-menu,
	#nav-main>ul>li.show-menu>ul.sub-menu {
		display: block;
		opacity: 1;
	}	

	@starting-style {
		#nav-main>ul>li.hovered>ul.sub-menu,
		#nav-main>ul>li.show-menu>ul.sub-menu {
			display: block;
			opacity: 0;
		}	
	}

	#nav-main>ul>li:hover>ul.sub-menu,
	#nav-main>ul>li>:focus-visible ~ ul.sub-menu {
		z-index: 2;
	}

	#nav-main>ul>li>ul.sub-menu:focus-within {
		z-index: 3;
	}

	#nav-main>ul>li.hovered button::before {
		content: '\25B4';
	}

	#nav-main #menu-item-12767>.sub-menu,
	#nav-main #menu-item-12791>.sub-menu {
		width: 32rem;
	}

	#nav-main #menu-item-12816>.sub-menu {
		left: auto;
		right: 0;
		width: 48rem;
	}

	#nav-main #menu-item-12767>.sub-menu>li,
	#nav-main #menu-item-12791>.sub-menu>li,
	#nav-main #menu-item-12816>.sub-menu>li {
		margin: 0;
		padding: 0.5rem 0;
		width: 100%;
		display: inline-block;
	}

	#header-utils ul {
		justify-content: end;
	}
}

@media(min-width: 72em) {
	body {
		font-size: 1.2rem;
	}
}

@media(min-width: 82em) {
	#nav-main>ul {
		gap: 1.75rem;
	}
}

@media(min-width: 100em) {
	.header-content {
		grid-template-areas:
			"logo utils search"
			"logo nav nav";
	}

	#logo {
		width: 12em;
	}
}

main {
	order: 30;
	display: flex;
	flex-direction: column;
	width: 100%;
	margin: 0 0 4rem;
}

main::before {
	content: '';
	display: block;
	width: 100%;
	aspect-ratio: 9;
	background: url(img/global-banner.svg);
	background-size: cover;
	order: -10;
}

main.has-post-thumbnail::before {
	content: none;
}

.post-thumb img {
	width: 100%;
}

#breadcrumbs {
	order: -1;
	font-size: 0.75em;
	margin: 0 auto;
	width: var(--layout-content-width);
	max-width: calc(100% - 2rem);	
}

main > .entry-title {
	margin: 2rem auto 1rem;
	width: var(--layout-content-width);
	max-width: calc(100% - 2rem);
	text-wrap: balance;
}

.entry-title > h1 {
	font-size: 1.1rem;
	margin: 0;
	text-transform: uppercase;
	font-weight: 700;
	color: rgb(var(--color-magenta));
	letter-spacing: 0.025em;	
}

.entry-title > h1::after {
	content: ":"
}

.entry-title > p {
	font-size: 2em;
	font-weight: var(--font-base-light);
	color: rgb(var(--color-purple));
	margin: 0;
	line-height: 1.1;
}

@media (min-width: 42em) {
	.entry-title > p {
		font-size: 3em;
	}
}

main > .post-thumb {
	order: -1;
}

aside#section-nav {
	order: 20;
	background: rgba(var(--color-magenta));
	color: rgba(var(--color-white));
}

aside#section-nav ul {
	list-style: none;
	margin: 0;
	padding: 1rem;
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
	justify-content: center;
	text-align: center;
	font-size: 0.8rem;
	line-height: 1.2;
}

aside#section-nav li a {
	color: rgba(var(--color-white));
}

aside#section-nav .current-menu-item {
	font-weight: 700;
}

@media (min-width: 50em) {
	aside#section-nav ul {
		flex-wrap: nowrap;
		font-size: 1rem;
		gap: 1.5rem;
	}
}

/* ============== */
/* Blocks */

.block-basic {
	margin: 0 auto 1rem;
	width: var(--layout-content-width);
	max-width: calc(100% - 2rem);
}

.block-cards {
	margin: 0 auto 1rem;
	width: var(--layout-full);
	max-width: calc(100% - 2rem);
}

.block-cards .articles {
	display: grid;
	gap: 2rem;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 20rem), 1fr));
	justify-items: center;
}

.block-cards article {
	border: solid 1px rgb(var(--color-magenta));
	border-radius: 0.5rem;
	max-width: 30rem;
	display: flex;
}

.block-cards article a {
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
}

.block-cards article .card-banner {
	order: -3;
	background-color: rgb(var(--color-magenta));
	color: rgb(var(--color-white));
	padding: 0.25rem 1rem;
	border-radius: 0.5rem 0.5rem 0 0;
	margin: -1px -1px 0;
}

.block-cards article .card-banner.news-update {
	background-color: rgb(var(--color-purple));
}

.block-cards article .card-banner.story {
	background-color: rgb(var(--color-red));
}

.block-cards article .post-thumbnail {
	order: -2;
	aspect-ratio: 3/2;
	box-shadow: 0 0 1em 0 rgba(0,0,0,0.1);
}

.block-cards article .post-thumbnail img {
	aspect-ratio: 3/2;
	height: auto;
	width: 100%;
	object-fit: contain;
	object-position: center;
	display: block;
}

.block-cards article .entry-title {
	font-size: 1.4em;
	font-weight: 300;
	margin: 1rem 1rem 0;
}

.block-cards article .post-meta {
	margin: 1rem 1rem 0;
	order: -1;
	color: rgb(var(--color-purple));
	text-transform: uppercase;
	letter-spacing: 0.04em;
	font-size: 0.8em;
	font-weight: 700;
}

.block-cards article .content {
	margin: 0.5rem 1rem 1rem;
	font-weight: 200;
}


/* Resource Center */

.block-link-list>ul,
ul.link-blocks
 {
	list-style: none;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(16rem, 1fr));
	gap: 1.5em;
	margin: 1.5em 0;
	padding: 0;
}

.block-link-list>ul>li,
ul.link-blocks>li {
	margin: 0;
	padding: 1rem;
	text-wrap: balance;
}

ul.link-blocks>li {
	font-size: 1.5rem;
	font-weight: bold;
	color: rgb(var(--color-purple));
}

.block-link-list>ul>li a,
ul.link-blocks>li a {
	display: flex;
	flex-direction: column;
	margin: -1rem;
	padding: 1rem;
	text-decoration: none;
	height: 100%;
	background: #eee;
	border-radius: 0.5rem;
	color: inherit;
	transition: 0.2s all;
	border: solid medium;
}

.block-link-list>ul>li a {
	justify-content: center;
	text-align: center;
}

.block-link-list>ul>li a:hover,
.block-link-list>ul>li a:focus,
ul.link-blocks>li a:hover,
ul.link-blocks>li a:focus {
	background: rgb(var(--color-magenta));
	color: #fff;
	border-color: rgb(var(--color-magenta))t;
}

.block-link-list>ul>li em,
ul.link-blocks>li em {
	display: block;
	font-size: 0.85rem;
	margin-top: auto;
	font-weight: normal;
	text-wrap: normal;
	padding-top: 0.5em;
	color: rgb(var(--color-black));
	font-style: normal;
}

.block-link-list>ul>li a:hover em,
.block-link-list>ul>li a:focus em,
ul.link-blocks>li a:hover em,
ul.link-blocks>li a:focus em {
	color: #fff;
}


/* ============== */
/* Special pages */

.blog main > .entry-title {
	width: var(--layout-full);
}

.archive main > .entry-title {
	width: var(--layout-full);
}

.single .post-thumb {
	margin: 0 auto;
}

.single .post-thumb img {
	display: block;
	max-width: 36em;
	max-height: 24em;
	height: auto;
	width: auto;
	object-fit: contain;
}

.post-intro {
	font-style: italic;
}

/*
.single h1 {
	margin-top: 0;
}

.single #breadcrumbs {
	margin-top: 2rem;
}
*/

.block-grantee-info {
	margin: 2rem auto 1rem;
	width: var(--layout-content-width);
	max-width: calc(100% - 2rem);	
}

@media (min-width: 30em) {
	.block-grantee-info {
		display: flex;
		gap: 1rem;
	}

	.block-grantee-info .grantee-photo {
		flex: 0 0 calc(50% - 0.5rem);
	}

	.block-grantee-info .grantee-details {
		flex: 1;
	}
}

@media (min-width: 42em) {
	.block-grantee-info {
		gap: 2rem;
	}
	
	.block-grantee-info .grantee-photo {
		flex: 0 0 calc(33% - 1rem);
	}
}
