/*
Theme Name: Gabie Strong
Theme URI: https://www.3n.design
Description: This is a custom theme for Gabie Strong designed and developed by 3n Design.
Author: 3n Design
Author URI: https://www.3n.design
Version: 1.0
*/

/*--------------------------------------------------------------
>>> TABLE OF CONTENTS:
----------------------------------------------------------------

	0. 	CSS Reset
	1. 	Variables
	2.	Typography
	3. 	Foundation
	4. 	Site Header
	5. 	Menu Modal
	6. 	Page Header
	7.  Grid Model
	8.	Templates
	9.  Entry Content
	10. Blocks
	11. Site Pagination
	12. Site Footer
    13. Transitions
	14. Accessibility

-------------------------------------------------------------- */

/* --------------------------------------------------------------
= 0. CSS Reset
-------------------------------------------------------------- */

html {
	box-sizing: border-box;
	scroll-behavior: smooth;
	-webkit-text-size-adjust: 100%;
	text-rendering: optimizeSpeed;
}
html,
body {
	border: none;
	margin: 0;
	padding: 0;
}
h1, h2, h3, h4, h5, h6,
p, blockquote, address, big,
cite, code, em, font, img,
small, strike, sub, sup,
li, ol, ul, dl, dt, dd,
fieldset, form, label, legend, button,
table, caption, tr, th, td {
	border: none;
	font-size: inherit;
	line-height: inherit;
	margin: 0;
	padding: 0;
	text-align: inherit;
}
blockquote::before,
blockquote::after {
	content: "";
}
article, aside, details, figcaption, figure, 
footer, header, hgroup, main, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
a {
  text-decoration: none;
  color: inherit;
}
:focus {
  outline: 2px solid var(--gs--color--secondary);
  outline-offset: 2px;
}
p {
  margin: 0;
}
ol, ul, menu {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote::after,
q::before, q::after {
	content: '';
	content: none;
}
img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}
*, *::before, *::after {
	box-sizing: inherit;
}
* {
	-webkit-tap-highlight-color: transparent !important;
}
button,
input,
textarea {
	-webkit-appearance: none;
	        appearance: none;
}
input,
button,
textarea,
select {
	font: inherit;
}
figure {
	margin: 0 !important;
}

/* --------------------------------------------------------------
= 1. Variables
-------------------------------------------------------------- */

:root {
	--gs--color--primary: #422321;
	--gs--color--secondary: #d2527f;
	--gs--color--tertiary: #ffffff; 
	--gs--color--background: #f4ede4;
	--gs--header--hght: clamp(5.625rem, 5rem + 3.125vw, 7.5rem); /* 90px - 120px (320px - 1280px) */
	--gs--header--pad: clamp(1.875rem, 1.6667rem + 1.0417vw, 2.5rem); /* 30px - 40px (320px - 1280px) */
    --gs--footer--hght: 70px;
	--gs--gutter: clamp(0.875rem, 0.5417rem + 1.6667vw, 1.875rem); /* 10px - 30px (320px - 1280px) */
	--gs--margin: 20px;
	--gs--section--gap: clamp(3.75rem, 3.3333rem + 2.0833vw, 5rem); /* 60px - 80px (320px - 1280px) */
	--gs--block--gap: 1.5em;
}

/* --------------------------------------------------------------
= 2. Typography
-------------------------------------------------------------- */

@font-face {
	font-family: 'League Spartan';
	src: url('../gabiestrong/assets/fonts/league-spartan/league-spartan-wght-normal.woff2') format('woff2');
	font-weight: 100 900;
	font-style: normal italic;
	font-display: swap;
}
@font-face {
	font-family: 'EB Garamond';
	src: url('../gabiestrong/assets/fonts/eb-geramond/eb-garamond-wght-italic.woff2') format('woff2');
	font-weight: 100 900;
	font-style: italic;
	font-display: swap;
}
body {
	color: var(--gs--color--primary);
	font-family: sans-serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}
.fonts--loaded body {
	font-family: "League Spartan", sans-serif;
}
h1, h2, h3, blockquote, .nav-title {
	font-family: serif;
	font-optical-sizing: auto;
	font-weight: 700;
	font-style: italic;
}
.fonts--loaded body h1, 
.fonts--loaded body h2, 
.fonts--loaded body h3,
.fonts--loaded blockquote,
.fonts--loaded .nav-title {
	font-family: "EB Garamond", serif;
}
i, em { 
	font-weight: 400; 
	font-style: italic; 
}
b, strong,
h4, h5, h6 {
	font-weight: 700;
	font-style: normal;
}
cite {
	font-family: sans-serif;
}
.fonts--loaded  cite {
	font-family: "League Spartan", sans-serif;
}

/* --------------------------------------------------------------
= 3. Foundation
-------------------------------------------------------------- */

html,
body {
	background-color: var(--gs--color--background);
}
body.menu--active { overflow: hidden }
main {
    min-height: calc(100dvh - var(--gs--footer--hght));
    padding-top: var(--gs--header--hght);
}
.inner {
	margin: 0 auto;
	max-width: 1600px;
	padding-inline: var(--gs--gutter)!important;
	position: relative;
}
.pad { padding-inline: calc(var(--gs--margin) / 2)!important }
.flex { display: flex }
.flex-1 { order: 1 }
.flex-2 { order: 2 }
.flex-3 { order: 3 }
.flex-4 { order: 4 }

@media ( min-width: 48em ) {
	.flex-dly {
		display: flex;
	}
}

/* Wordpress Overrides  -------------------------------------- */

.wp-lightbox-overlay button {
	fill: var(--gs--color--primary)!important;
}
.wp-lightbox-overlay button:hover {
	fill: var(--gs--color--secondary)!important;
}
.wp-lightbox-overlay .scrim {
	background-color: var(--gs--color--background)!important;
}

/* --------------------------------------------------------------
= 4. Site Header
-------------------------------------------------------------- */

body::before {
	background: linear-gradient(180deg,rgba(244, 237, 228, 1) 10%, rgba(244, 237, 228, 0) 100%);
	content: '';
	display: block;
	height: var(--gs--header--hght);
	inset: 0;
	position: fixed;
	z-index: 999;
}
.site-header {
	inset-block-start: 0;
	inset-inline: 0;
	min-height: var(--gs--header--hght);
	position: fixed;
	z-index: 1000;
	transition: all 300ms ease;
}
.site-header .inner {
	flex-wrap: wrap;
	justify-content: space-between;
}
.site-title {
	font-size: clamp(1.5625rem, 1.4583rem + 0.5208vw, 1.875rem);
	line-height: var(--gs--header--pad);
	padding-block: var(--gs--header--pad);
	transition: color 300ms ease;
}
.site-title a {
	text-decoration: none!important;
}
@media ( min-width: 48em ) {
	.site-header .inner {
		flex-wrap: nowrap;
	}
}

/* Menu Active  ---------------------------------------------- */

.menu--active .site-header {
	background-color: var(--gs--color--secondary);
	min-height: 100dvh;
}
.menu--active .site-title {
	color: var(--gs--color--tertiary);
}

/* --------------------------------------------------------------
= 5. Menu Modal
-------------------------------------------------------------- */

.site-mobile-toggle {
	background-color: transparent;
	color: var(--gs--color--primary);
	font-size: 1.25rem;
	font-weight: 500;
	line-height: var(--gs--header--pad);
	margin-block-start: calc(var(--gs--header--pad) + 4px);
	margin-block-end: calc(var(--gs--header--pad) - 6px);
}
.menu--active .site-mobile-toggle {
	color: var(--gs--color--tertiary);
}
.site-navigation {
	display: none;
	margin-block: 0;
	overflow: hidden;
	width: 100%;
}
.site-navigation a {
	color: var(--gs--color--tertiary);
	display: block;
	font-size: 1.25rem;
	font-weight: 500;
	line-height: var(--gs--header--pad);
	text-decoration: none;
}
.site-navigation a:hover,
.site-mobile-toggle:hover {
	color: var(--gs--color--secondary);
}
.site-navigation a:hover,
.site-navigation .current-menu-item a,
.site-mobile-toggle:hover {
	text-decoration: underline;
	text-decoration-color: var(--gs--color--secondary);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.2em;
}
.site-navigation li { 
	opacity: 0; 
	text-align: right;
	transform: none; 
}
.menu--active .site-navigation li { 
	animation-name: fadeInOn; 
	animation-duration: 1s; 
	animation-fill-mode: forwards; 
}
.site-navigation li:nth-child(1) { animation-delay: 100ms }
.site-navigation li:nth-child(2) { animation-delay: 200ms }
.site-navigation li:nth-child(3) { animation-delay: 300ms }
.site-navigation li:nth-child(4) { animation-delay: 400ms }
.site-navigation li:nth-child(5) { animation-delay: 500ms }
.site-navigation li:nth-child(6) { animation-delay: 600ms }
.site-navigation li:nth-child(7) { animation-delay: 700ms }
.site-navigation li:nth-child(8) { animation-delay: 800ms }

@keyframes fadeInOn { 
	0%   { opacity: 0; transform: translate3d(0px, -10px, 0px) }
	100% { opacity: 1; transform: none; }
}
@media ( min-width: 48em ) {
	.site-mobile-toggle {
		display: none;
	}
	.site-navigation {
		display: flex;
		flex-direction: row;
		gap: var(--gs--margin);
		justify-content: flex-start;
		padding-block-start: calc(var(--gs--header--pad) + 4px);
		padding-block-end: calc(var(--gs--header--pad) - 6px);
		width: 50%;
	}
	.site-navigation li { 
		opacity: 1; 
		text-align: left;
	}
	.site-navigation a {
	color: var(--gs--color--primary);
	}
}

/* Menu Active  ---------------------------------------------- */

.menu--active .site-navigation {
	display: block;
}
.menu--active .site-mobile-toggle {
	color: var(--gs--color--tertiary);
}
.menu--active .site-navigation a:hover,
.menu--active .site-mobile-toggle:hover {
	color: var(--gs--color--tertiary);
}
.menu--active .site-navigation a:hover,
.menu--active .site-navigation .current-menu-item a,
.menu--active .site-mobile-toggle:hover {
	text-decoration-color: var(--gs--color--tertiary);
}

/* --------------------------------------------------------------
= 6. Page Header
-------------------------------------------------------------- */

.page .page-header,
.archive .page-header {
	margin-block-end: var(--gs--section--gap);
}
.single .page-header {
	margin-block-end: clamp(1.5625rem, 1.3542rem + 1.0417vw, 2.1875rem); /* 25px - 35px (320px - 1280px) */
}
.page-title {
	font-size: clamp(1.25rem, 1.0417rem + 1.0417vw, 1.875rem); /* 20px - 30px (320px - 1280px) */
	margin-block-end: var(--gs--block--gap);
}
.page-header .page-title {
	margin-block-end: calc(var(--gs--margin) - 0.125em);
}
.single .page-header .page-title {
	margin-block-end: calc(var(--gs--margin) - 0.5em);
}

/* Filter  --------------------------------------------------- */

.page .filter-container,
.archive .filter-container {
	border-block-start: 2px solid var(--gs--color--primary);
	padding-block-start: calc(var(--gs--margin) / 2);
}
.filter-container .filters {
	gap: calc(var(--gs--margin) / 2);
}
.filter-container .filters li {
	line-height: var(--gs--margin);
	margin-block-start: calc(var(--gs--margin) / 2);
}
.filter-container .filters li::after {
	content: ', ';
}
.filter-container .filters .filter-title::after,
.filter-container .filters li:last-child::after {
	content: '';
}
.filter-container .filter-title {
	font-size: clamp(0.875rem, 0.8333rem + 0.2083vw, 1rem); /* 14px - 16px (320px - 1280px) */
	font-weight: 700;
	text-transform: uppercase;
}
.filter-container .filter a {
	color: var(--gs--color--primary);
	text-decoration: none;
}
.filter-container .filter a:hover {
	color: var(--gs--color--secondary);
	text-decoration: underline;
	text-decoration-color: var(--gs--color--secondary);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.2em;
}
.filter-spacer {
	display: none;
}
@media all and (min-width: 48em) {
	.page .filter-container,
	.archive .filter-container {
		flex-wrap: nowrap;
		gap: var(--gs--margin);
	}
	.page .filter-container .filters,
	.archive .filter-container .filters {
		width: calc(100% / 2);
	}
	.single .filter-container {
		gap: calc(var(--gs--margin) / 2);
	}
	.filter-spacer {
		background-color: var(--gs--color--primary);
		display: block;
		height: 10px;
		margin-block-start: 13px;
		width: 2px;
	}
}

/* --------------------------------------------------------------
= 7. Grid Model
-------------------------------------------------------------- */

.grid {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	justify-content: space-between;
	margin-block-end: var(--gs--section--gap);
}
.grid:after {
	display: block;
	content: '';
	flex: 999 999 auto;
}
#related-posts.grid { margin-block-end: 0!important }
.grid-cell { width: 100% }
@media all and (min-width: 48em) {
	.grid-cell { width: calc(100% / 2) }
	.grid-cell.width-full { width: 100%!important }
	.grid-cell.align-bottom-left,
	.grid-cell.align-bottom-right {
		display: flex;
		flex-direction: column;
		justify-content: flex-end;
	}
	.grid-cell.width-full.align-top-left,
	.grid-cell.width-full.align-bottom-left { padding-inline-start: calc(100% / 4 + var(--gs--margin) * 1.5)!important}
	.grid-cell.width-full.align-top-right,
	.grid-cell.width-full.align-bottom-right { padding-inline-end: calc(100% / 4 + var(--gs--margin) * 1.5)!important }
}
@media all and (min-width: 64em) {
	#related-posts .grid-cell { width: calc(100% / 3) }
	.grid-cell.width-quarter { width: calc(100% / 2) }
}
@media all and (min-width: 80em) {
	.grid-cell.width-half { width: calc(100% / 2) }
	.grid-cell.width-third { width: calc(100% / 3) }
	.grid-cell.width-quarter { width: calc(100% / 4) }
	.grid-cell.width-half.align-top-left,
	.grid-cell.width-half.align-bottom-left { padding-inline-end: calc(100% / 6 + var(--gs--margin) * 1.5)!important }
	.grid-cell.width-half.align-top-right,
	.grid-cell.width-half.align-bottom-right { padding-inline-start: calc(100% / 6 + var(--gs--margin) * 1.5)!important }
	.grid-cell.width-full.align-top-left,
	.grid-cell.width-full.align-bottom-left { padding-inline-end: calc(100% / 3 + var(--gs--margin) * 1.5)!important}
	.grid-cell.width-full.align-top-right,
	.grid-cell.width-full.align-bottom-right { padding-inline-start: calc(100% / 3 + var(--gs--margin) * 1.5)!important }
}

/* Grid Cell Details  ---------------------------------------- */

.grid-cell {
	margin-block-end: var(--gs--section--gap);
}
#related-posts .grid-cell {
	margin-block-end: var(--gs--margin);
}
.grid-cell .entry-details {
	flex-wrap: wrap;
	margin-block-start: calc(var(--gs--margin) / 2);
}
.grid-cell .entry-title {
	font-size: 1.25rem;
	line-height: 1.5rem;
}
.grid-cell .entry-type {
	font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem); /* 16px - 20px (320px - 1280px) */
	font-weight: 500;
	line-height: 1.5rem;
	width: 100%;
}
.grid-cell a .entry-title,
.grid-cell a .entry-type {
	color: var(--gs--color--primary);
	transition: color 500ms ease;
}
.grid-cell a:hover .entry-title,
.grid-cell a:hover .entry-type {
	color: var(--gs--color--secondary);
}
.grid-cell figure {
	background-color: var(--gs--color--tertiary);
	position: relative;
}
.grid-cell a figure img {
	filter: none;
	flex: 1 0 100%;
	height: auto;
	max-width: 100%;
	mix-blend-mode: multiply;
	opacity: 1;
	position: relative;
	width: 100%;
	transition: filter 500ms ease;
}
.grid-cell a:hover figure img {
	filter: grayscale(100%);
}
.grid-cell a figure .gs-place-holder {
	aspect-ratio: 3 / 2;
	background-color: var(--gs--color--secondary);
	transition: background-color 500ms ease;
}
.grid-cell a:hover figure .gs-place-holder {
	background-color: var(--gs--color--primary);
}
.grid-cell a figure::before {
	background-color: var(--gs--color--secondary);
	content: '';
	height: 100%;
	inset: 0;
	mix-blend-mode: lighten;
	opacity: 0;
	position: absolute;
	width: 100%;
	z-index: 1;
	transition: opacity 500ms ease;
}
.grid-cell a:hover figure::before {
	opacity: 1;
}
@media all and (min-width: 48em) {
	.grid-cell .entry-type {
		width: auto;
	}
	.entry-details {
		flex-wrap: nowrap;
		gap: var(--gs--margin);
		justify-content: space-between;
	}
}

/* --------------------------------------------------------------
= 8. Templates
-------------------------------------------------------------- */

/* Homepage: Post  ------------------------------------------- */

.home .type-gs_work a,
.home .type-gs_research a {
	display: block;
}
.home .type-gs_work a figure img,
.home .type-gs_research a figure img {
	display: block;
	height: auto;
	width: 100%;
}

/* Homepage: Image  ------------------------------------------ */

.home .type-image figure {
	margin: 0!important;
}
.home .type-image figure img {
	display: block;
	height: auto;
	width: 100%;
}

/* Homepage: Video  ------------------------------------------ */

.home .type-video .video-wrapper {
	height: 0;
	padding-block-end: 56.25%;
	position: relative;
	width: 100%;
}
.home .type-video .video-wrapper.aspect-ratio-4-3 {
	padding-block-end: 75%; /* 4:3 */
}
.home .type-video .video-wrapper.aspect-ratio-16-9 {
	padding-block-end: 56.25%; /* 16:9 */
}
.home .type-video .video-wrapper.aspect-ratio-9-16 {
	padding-block-end:  177.7778%; /* 9:16 */
}
.home .type-video .video-wrapper iframe {
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 0;
	width: 100%;
	height: 100%;
}

/* Homepage: Quote  ------------------------------------------ */

.home .type-quote blockquote {
	font-size: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem); /* 20px - 40px (320px - 1280px) */
	line-height: clamp(1.875rem, 1.5625rem + 1.5625vw, 2.8125rem); /* 30px - 45px (320px - 1280px) */
	padding-block: clamp(2.1875rem, 1.0417rem + 5.7292vw, 5.625rem); /* 35px - 90px (320px - 1280px) */
	padding-inline: clamp(2.5rem, 1.25rem + 6.25vw, 6.25rem); /* 40px - 100px (320px - 1280px) */
}
.home .type-quote blockquote p {
	margin-block-end: 1em;
}
.home .type-quote blockquote p:last-of-type {
	margin-block-end: 0.25em;
}
.home .type-quote blockquote cite {
	display: block;
	font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem); /* 16px - 20px (320px - 1280px) */
	font-style: normal;
	font-weight: 500;
	line-height: 1.5em;
}
.home .type-quote blockquote.theme-white-on-pink,
.home .type-quote blockquote.theme-white-on-brown { color: var(--gs--color--tertiary) }
.home .type-quote blockquote.theme-pink-on-white,
.home .type-quote blockquote.theme-brown-on-white { background-color: var(--gs--color--tertiary) }
.home .type-quote blockquote.theme-white-on-pink { background-color: var(--gs--color--secondary) }
.home .type-quote blockquote.theme-pink-on-white { color: var(--gs--color--secondary) }
.home .type-quote blockquote.theme-white-on-brown { background-color: var(--gs--color--primary) }
.home .type-quote blockquote.theme-brown-on-white { color: var(--gs--color--primary) }

/* Homepage: Audio Embed  ------------------------------------ */

.home .type-audio iframe {
    max-width: 100% !important;
}

/* Work / Research  ------------------------------------------ */

.year-title {
	border-block-end: 2px solid var(--gs--color--primary);
	font-weight: 700;
	line-height: var(--gs--margin);
	margin-block-end: var(--gs--margin);
	padding-block-end: calc(var(--gs--margin) / 2);
}

/* About  ---------------------------------------------------- */

.biography {
	flex-wrap: nowrap;
}
.portrait img {
	display: block;
	height: auto;
	width: 100%;
}
.biography .entry-content,
.biography .portrait {
	margin-block-end: var(--gs--section--gap)!important;
}
.cv {
	margin-block-end: calc(var(--gs--section--gap) * 2);
}
@media all and (min-width: 64em) {
	.biography .entry-content,
	.biography .portrait {
		width: 50%;
	}
}

/* --------------------------------------------------------------
= 9. Entry Content
-------------------------------------------------------------- */

.entry-content {
	font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem); /* 16px - 20px (320px - 1280px) */
	line-height: 1.5em;
}
.entry-content a {
	text-decoration: underline;
	text-decoration-color: var(--gs--color--primary);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.2em;
}
.entry-content a:hover {
	color: var(--gs--color--secondary);
	text-decoration-color: var(--gs--color--secondary);
}
.entry-content p,
.entry-content ul,
.entry-content dl,
.entry-content ol,
.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6,
.entry-content blockquote {
	margin-block-end: var(--gs--block--gap);
}
.entry-content h2,
.entry-content h3 {
	font-size: clamp(1.25rem, 1.0417rem + 1.0417vw, 1.875rem); /* 20px - 30px (320px - 1280px) */
}
.entry-content h4,
.entry-content h5,
.entry-content h6 {
    font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem); /* 16px - 20px (320px - 1280px) */
}
.entry-content h4 {
	padding-block-start: var(--gs--block--gap);
}
.entry-content h2 + h4 {
	padding-block-start: 0;
}
.entry-content > *:last-child {
    margin-block-end: 0;
}
.entry-content ul {
	list-style: disc outside;
	padding-inline-start: var(--gs--block--gap);
}
.entry-content ul ul {
	list-style: circle outside;
	margin-block-end: 0;
	padding-inline-start: var(--gs--block--gap);
}
.entry-content dd ul,
.cv .entry-content ul {
	list-style: none;
	padding-inline-start: 0;
}
.entry-content dd p,
.entry-content dd ul li,
.cv .entry-content ul li { 
	margin-block: 0;
	margin-inline: 25px 0;
	text-indent: -25px;
}
.entry-content dt {
	font-weight: 600;
}
.entry-content .has-text-align-center {
	text-align: center;
}
.entry-content blockquote {
	font-size: 1.066em;
    position: relative;
}
.entry-content blockquote p {
	line-height: 1.125em;
}
.entry-content blockquote p:only-child,
.entry-content blockquote p:nth-last-child(2) {
	margin-block-end: 0;
}
.entry-content blockquote cite {
	font-size: 0.75em;
}
.entry-content hr.wp-block-separator {
	border-top: 1px solid var(--gs--color--primary);
	border-bottom: none;
	margin-block-end: calc(var(--margin) * 2);
}
.entry-content iframe {
    display: block;
}
@media ( min-width: 48em ) {
	.entry-content dl {
		display: grid;
		grid-template-columns: 120px 1fr;
		gap: 0;
	}
	.entry-content dt {
		font-weight: 400;
		grid-column: 1;
	}
	.entry-content dd {
		grid-column: 2;
	}
	.entry-content dd ul {
		margin-bottom: 0;
	}
	.entry-content .has-small-font-size {
		font-size: 0.75em;
		line-height: 1.5em;
	}
	.entry-content hr.wp-block-separator {
		margin-block-end: var(--gs--block--gap);
	}
}

/* --------------------------------------------------------------
= 10. Blocks
-------------------------------------------------------------- */

.entry-content.blocks > * {
    max-width: 1600px;
    margin-inline: auto!important;
	padding-block: 0;
    padding-inline: calc(var(--gs--margin) / 2);
}
.entry-content.blocks .alignfull {
    max-width: calc(100% + (var(--gs--gutter) + 10px) * 2);
}

/* Block: Image  --------------------------------------------- */

.entry-content img {
	display: block;
	height: auto;
	max-width: 100%;
}
.entry-content.blocks > .wp-block-image {
    margin-block-end: var(--gs--margin) !important;
}
.entry-content.blocks .wp-block-image figcaption {
	line-height: 1.5em;
	padding-block: 5px 0;
	padding-inline: 0;
}
@media ( min-width: 48em ) {
    .entry-content.blocks .wp-block-image figcaption {
        font-size: 1rem;
    }	
}
@media ( min-width: 64em ) {
	.alignright figcaption {
		text-align: right;
	}
}

/* Block: Columns -------------------------------------------- */

.gs-columns-block {
	margin-block-start: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem); /* 20px - 40px (320px - 1280px) */
}
article:not(.category-parent-work) .gs-columns-block:first-child {
	margin-block-start: 0!important;
}
.entry-content.blocks .wp-block-columns {
	gap: 0;
}
.entry-content.blocks > .wp-block-columns {
    padding-inline: 0!important;
}
.entry-content.blocks > .wp-block-columns > .wp-block-column {
    margin-block-end: 0;
    padding-block: 0;
	padding-inline: calc(var(--gs--margin) / 2);
}
.entry-content.blocks .wp-block-columns .wp-block-column > * {
    margin-block-end: var(--gs--margin)!important;
}
@media ( min-width: 48em ) {
	.entry-content.blocks .wp-block-columns {
		gap: var(--gs--margin);
	}
}

/* Block: Embed ---------------------------------------------- */

.wp-block-embed,
.wp-block-video {
    margin-block-end: var(--gs--margin) !important;
}
.wp-block-video audio,
.wp-block-video video,
.wp-block-embed iframe {
	width: 100%;
}
.wp-block-embed .wp-block-embed__wrapper {
	height: 0;
	padding-block-end: 56.25%;
	position: relative;
}
.wp-block-embed.wp-embed-aspect-4-3 .wp-block-embed__wrapper {
	padding-block-end: 75%; /* 4:3 */
}
.wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper {
	padding-block-end: 56.25%; /* 16:9 */
}
.wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper {
	padding-block-end:  41.5625%; /* 21:9 */
}
.wp-block-embed .wp-block-embed__wrapper iframe {
	position: absolute;
	inset-block-start: 0;
	inset-inline-start: 0;
	width: 100%;
	height: 100%;
}

/* --------------------------------------------------------------
= 11. Site Pagination
-------------------------------------------------------------- */

.nav {
	flex-wrap: nowrap;
	justify-content: space-between;
	padding-block: var(--gs--section--gap);
}
.nav a {
	color: var(--gs--color--primary);
	text-decoration: none;
}
.nav a:hover .nav-meta {
	color: var(--gs--color--secondary);
	text-decoration: underline;
	text-decoration-color: var(--gs--color--secondary);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.2em;
}
.nav .nav-meta {
	font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem); /* 16px - 20px (320px - 1280px) */
	font-weight: 500;
	line-height: 1.25em;
}
.nav .nav-title {
	display: none;
	font-size: clamp(1.25rem, 1.0417rem + 1.0417vw, 1.875rem); /* 20px - 30px (320px - 1280px) */
	font-weight: 700;
	line-height: 1.125em;
}
@media ( min-width: 48em ) {
	.nav a {
		display: inline-flex;
		flex-direction: column;
		align-items: flex-start;
	}
	.nav .nav-next,
	.nav .nav-previous {
		width: 50%;
	}
	.nav .nav-title {
		display: inline-block;
	}
	.nav a:hover .nav-meta {
		text-decoration: none;
	}
	.nav a:hover .nav-title {
		color: var(--gs--color--secondary);
		text-decoration: underline;
		text-decoration-color: var(--gs--color--secondary);
		text-decoration-thickness: 2px;
		text-underline-offset: 0.2em;
	}
}

/* --------------------------------------------------------------
= 12. Site Footer
-------------------------------------------------------------- */

.site-footer {
	height: var(--gs--footer--hght);
}
.site-footer a {
	text-decoration: none;
}
.site-footer a:hover {
	color: var(--gs--color--secondary);
	text-decoration: underline;
	text-decoration-color: var(--gs--color--secondary);
	text-decoration-thickness: 2px;
	text-underline-offset: 0.2em;
}
.site-footer .inner {
	justify-content: space-between;
}
.site-footer .inner::before {
	background-color: var(--gs--color--primary);
	content: '';
	display: block;
	height: 2px;
	inset-block-start: 0;
	inset-inline: calc(var(--gs--gutter) + var(--gs--margin) / 2);
	position: absolute;
}
.site-copyright,
.site-social-media {
	font-size: clamp(1rem, 0.9583rem + 0.2083vw, 1.125rem); /* 16px - 18px (320px - 1280px) */
	font-weight: 500;
	line-height: 1.75rem;
	padding-block: var(--gs--block--gap);
}
.site-social-media {
	gap: var(--gs--gutter);
	justify-content: flex-end;
	margin-block: 0!important;
}
.site-copyright span {
	display: none;
}
@media ( min-width: 48em ) {
	.site-copyright span {
		display: inline;
	}
}

/* --------------------------------------------------------------
= 13. Transitions
-------------------------------------------------------------- */

body {
    opacity: 0;
    transition: opacity 500ms ease;
}
body.page--loaded {
    opacity: 1;
}

/* --------------------------------------------------------------
= 14. Accessibility
-------------------------------------------------------------- */

.screen-reader-text {
	border: 0;
	clip: rect(1px, 1px, 1px, 1px);
	clip-path: inset(50%);
	height: 1px;
	margin: -1px;
	overflow: hidden;
	padding: 0;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}
.screen-reader-text:focus {
	background-color: #f1f1f1;
	border-radius: 3px;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	clip-path: none;
	color: #21759b;
	display: block;
	font-size: 0.875rem;
	font-weight: 700;
	height: auto;
	left: 5px;
	line-height: normal;
	padding: 15px 23px 14px;
	text-decoration: none;
	top: 5px;
	width: auto;
	z-index: 100000;
}
#primary[tabindex="-1"]:focus {
	outline: 0;
}