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

	0. 	CSS Reset
	1. 	Variables
	2.	Typography
	3. 	Foundation
	4. 	UI Elements
	5. 	Site Header
	6. 	Menu Modal
	7. 	Page Header
	8.  Card Model
    9.  Carousel Model
	10.	Templates
	11. Entry Content
	12. Blocks
	13. Site Pagination
	14. Site Footer
    15. Transitions
	15. 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;
    overscroll-behavior: none;
}
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;
}
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;
}

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

:root {
	--fa--color--primary: #000000;
	--fa--color--secondary: #666666;
	--fa--color--tertiary: #f2f2f2;
    --fa--color--quaternary: #bebebe;
    --fa--color--quinary: #444444;
	--fa--color--background: #ffffff;
    --fa--color--shadow: rgba(0,0,0,.5);
	--fa--font--ibm-plex-mono: 'IBM Plex Mono', monospace;
	--fa--gutter: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem);
	--fa--margin: 1.75rem;
    --fa--section--gap-start: clamp(2.5rem, 2.0833rem + 2.0833vw, 3.75rem);
	--fa--section--gap-end: clamp(2.5rem, 1.6667rem + 4.1667vw, 5rem); 
	--fa--block--gap: clamp(1.25rem, 0.4167rem + 4.1667vw, 3.75rem);
}

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

body {
	color: var(--fa--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: 'DM Sans', sans-serif;
}
h1, h2, h3, h4, h5, h6, dt {
	font-family: monospace;
	font-optical-sizing: auto;
}
h1, dt {
	font-weight: 400;
}
h2, h3, h4, h5, h6 {
	font-weight: 300;
}
.fonts-loaded body h1, 
.fonts-loaded body h2, 
.fonts-loaded body h3,
.fonts-loaded body h4, 
.fonts-loaded body h5, 
.fonts-loaded body h6, 
.fonts-loaded body dt {
	font-family: 'IBM Plex Mono', serif;
}
:focus {
    outline: none;
}
.is-style-space-mono {
    font-family: "Space Mono", monospace!important;
    letter-spacing: 0.1em;
}

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

html,
body {
	background-color: var(--fa--color--background);
}
body.page-template-page-sequencing,
body.tax-seq-taxonomy {
    background-color: var(--fa--color--tertiary);
}
body.menu-open { overflow: hidden }
.site-wrapper {
    position: relative;
    overflow-x: hidden;
}
main {
    color: var(--fa--color--primary);
    min-height: calc(100dvh - 500px);
    padding-block-start: clamp(5rem, 4.1667rem + 4.1667vw, 7.5rem);
    padding-block-end: calc(var(--fa--gutter) * 3);
    position: relative;
    overflow: hidden;
}
.single-fa_festivals main {
    padding-block-start: 3rem;
}
@media (min-width: 75em) and (max-width: 86em) {
    .single-fa_festivals main {
        padding-block-start: 4.875em;
    }
}
@media ( min-width: 48rem ) {
    main { overflow: visible }
}
.container,
.container-sm,
.container-lg,
.container-xl {
	margin: 0 auto;
	padding-inline: var(--fa--gutter)!important;
	position: relative;
}
.container-sm {
	max-width: 80rem;
}
.tax-seq-taxonomy .container-sm,
.page-template-page-sequencing.container-sm {
	max-width: calc(90rem + var(--fa--gutter) * 2);
}
.container-lg {
	max-width: 90rem;
}
.container-xl {
	max-width: 105rem;
}
.flex { display: flex }
.flex-1 { order: 1 }
.flex-2 { order: 2 }
.flex-3 { order: 3 }
.flex-4 { order: 4 }
.first-on-mobile {
    order: -1;
}
@media (min-width:782px) {
    .first-on-mobile {
        order: unset;
    }
}
@media ( min-width: 48rem ) {
	.flex-dly {
		display: flex;
	}
}
main::before {
    aspect-ratio: 1;
    background-repeat: no-repeat;
    background-size: cover;
    content: '';
    display: block;
    inset-block-start: clamp(-350px, calc(-350px + (100vw - 320px) / (1280 - 320) * 150), -200px);
    inset-inline-start: 50%;
    position: fixed;
    transform: translateX(clamp(-100%, calc(-40% - (100vw - 320px) / (1280 - 320) * 500), -40%));
    width: 1000px;
}
.home main::before {
    inset-block-start: initial;
    inset-block-end: clamp(-350px, calc(-350px + (100vw - 320px) / (1280 - 320) * 150), -200px);
    position: absolute;
}
.home main::before,
.page-template-page-about main::before {
    background-image: url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-shape--fulcrum.png');
}
.page-template-page-artists main::before {
    background-image: url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-shape--artists.png');
}
.page-template-page-sequencing main::before,
.tax-seq-taxonomy main::before,
.single-fa_sequencing main::before {
    background-image: url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-shape--sequencing.png');
}
.page-template-page-program main::before,
.post-type-archive-fa_program main::before,
.single-fa_resident main::before,
.single-fa_program main::before {
    background-image: url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-shape--programming.png');
}
.publishing-banner::before {
    aspect-ratio: 1;
    background-image: url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-shape--sequencing.png');
    background-repeat: no-repeat;
    background-size: cover;
    content: '';
    display: block;
    inset-block-start: clamp(-700px, calc(-350px + (100vw - 320px) / (1280 - 320) * 150), -400px);
    inset-inline-start: 50%;
    position: absolute;
    transform: translateX(clamp(-100%, calc(-40% - (100vw - 320px) / (1280 - 320) * 500), -40%));
    width: 1000px;
    z-index: 1;
}
.publishing-banner {
    overflow: hidden;
    position: relative;
}
.publishing-banner > div {
    position: relative;
    z-index: 2;
}


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

:root :where(.is-layout-flow) > *,
:root :where(.is-layout-constrained) > * {
    margin-block-start: 0 !important;
}
:root :where(.wp-block-image.is-style-rounded img,.wp-block-image .is-style-rounded img) {
    border-radius: 1.25em;
}
:where(.wp-block-group.has-background) {
    padding-block: 0!important;
    padding-inline: var(--fa--gutter)!important;
}
.wp-lightbox-overlay button {
	fill: var(--fa--color--background)!important;
}
.wp-lightbox-overlay button:hover {
	fill: var(--fa--color--secondary)!important;
}
.wp-lightbox-overlay .scrim {
	background-color: var(--fa--color--primary)!important;
}

/* --------------------------------------------------------------
= 4. UI Elements
-------------------------------------------------------------- */

/* SVG Animation  -------------------------------------------- */

svg .fill {
    transition: fill 200ms ease;
}

/* Hamburger Animation  -------------------------------------- */

.hamburger-box {
	display: inline-block;
	height: 12px;
	position: relative;
	width: 20px;
}
.hamburger-box span,
.hamburger-box span::before,
.hamburger-box span::after {
    position: absolute;
    width: 20px;
    height: 2px;
    background-color: var(--fa--color--primary);
    transition: all 300ms ease;
}
.hamburger-box span {
    top: 50%;
    transform: translateY(-50%);
}
.hamburger-box span::before,
.hamburger-box span::after {
    content: '';
}
.hamburger-box span::before {
    top: -5px;
}
.hamburger-box span::after {
    bottom: -5px;
}
/* Open State */
.mobile-nav-toggle[aria-expanded="true"] .hamburger-box span {
    width: 0;
}
.mobile-nav-toggle[aria-expanded="true"] .hamburger-box span::before {
    transform: translateY(5px) rotate(45deg);
}
.mobile-nav-toggle[aria-expanded="true"] .hamburger-box span::after {
    transform: translateY(-5px) rotate(-45deg);
}

/* --------------------------------------------------------------
= 5. Site Header
-------------------------------------------------------------- */

.site-header {
    background-color: transparent;
    grid-area: header;
    position: fixed;
    inset-block-start: 0;
    inset-inline-start: 0;
    width: 100%;
    transition: transform 300ms ease, box-shadow 300ms ease;
    will-change: transform;
    z-index: 10;
}
.site-header .container-xl {
    align-items: center;
    justify-content: space-between;
    padding-block: 1rem;
    overflow-x: hidden;
}
.site-title {
    flex-shrink: 0;
}
.site-title svg {
    height: 0.875rem;
	overflow: visible;
    width: auto;
}
.site-title svg .fill {
    fill: var(--fa--color--primary);
}
.headroom--unpinned {
    transform: translateY(-100%);
}
.headroom--not-bottom.headroom--not-top:not(.headroom--pinned):not(.headroom--unpinned),
.headroom--pinned {
    background: hsla(0, 0%, 100%, .9);
    box-shadow: 0 2px 6px var(--fa--color--shadow);
}
.headroom--pinned {
    -webkit-backdrop-filter: blur(20px);
    backdrop-filter: blur(20px);
    transform: translateY(0);
    transition: background 300ms ease, transform 300ms ease;
}
.headroom--pinned.headroom--top {
    box-shadow: none;
    -webkit-backdrop-filter: none;
    backdrop-filter: none;
    background: transparent;
}

/* --------------------------------------------------------------
= 6. Menu Modal
-------------------------------------------------------------- */

.mobile-nav-toggle {
    align-items: center;
	background: var(--fa--color--background);
    border: none;
	border-radius: 4px;
	box-shadow: 0 2px 2px var(--fa--color--quaternary);
	cursor: pointer;
    gap: 0.5rem;
    inset-inline-end: calc(var(--fa--gutter));
    inset-block-start: 10px;
    padding: 0.5rem;
	position: fixed;
    z-index: 9999;
}
.hamburger-text {
    color: var(--fa--color--primary);
	font-family: var(--fa--font--ibm-plex-mono);
    font-size: 0.75rem;
    font-weight: 400;
    text-transform: uppercase;
}
.site-menus {
    align-items: end;
    background: var(--fa--color--background);
    container-type: inline-size;
    flex-direction: column;
    height: 100vh;
    inset-block: 0;
    inset-inline-end: 0;
    line-height: 1;
    padding-top: 90px;
    position: fixed;
    transition: max-width .2s ease-out;
    width: 100%;
    z-index: 10;
    max-width: 0;
    overflow: hidden;
}
.site-menus.is-active {
    max-width: 100%;
}
.site-menus .site-menu {
	align-items: end;
	column-gap: 1rem;
	flex-direction: column;
	justify-content: end;
	list-style-type: none;
	margin: 0px;
    min-width: 0;
    padding-block: 0;
	padding-inline: calc(var(--fa--gutter));
}
.site-menus .site-menu--secondary.site-menu {
	margin-block-start: 2rem;
}
.site-menus .site-menu a {
    color: var(--fa--color--primary);
    display: inline-block;
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: inherit;
    font-weight: 300;
    letter-spacing: -0.015em;
    line-height: 1;
    padding-block: 0.45em;
    position: relative;
    text-decoration: none;
    text-transform: none;
	white-space: nowrap;
    word-spacing: -0.3em;
}
.site-menus .site-menu--primary.site-menu a {
	font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1.45rem;
	font-style: italic;
	list-style-type: none;
}
.site-menus .site-menu--secondary.site-menu a {
	font-size: 1rem;
}
.site-menus .site-menu--social.site-menu {
    align-items: start;
    flex-direction: row;
    margin-block-start: 1.5rem;
}
.site-menus .site-menu--social.site-menu svg {
    height: 20px;
    width: 20px;
    vertical-align: sub;
    stroke-linecap: round;
}
.site-menus .site-menu--social.site-menu svg.facebook {
    width: 16px;
}
.site-menus .site-menu--social.site-menu svg .fill {
    fill: var(--fa--color--primary);
}
@media (min-width: 75rem) {
    .mobile-nav-toggle,
    .hide-on-desktop,
    .site-menus .site-menu--social.site-menu {
        display: none;
    }
    .site-menus {
        align-items: end;
        background: transparent;
        flex-direction: column;
        gap: 0.875em;
        height: auto;
        inset: initial;
        max-width: 100%;
        position: static;
        padding: 0;
        position: relative;
        overflow: visible;
        transform: translatex(0);
    }
    .site-menus .site-menu {
        align-items: center;
        column-gap: 2.25rem;
        flex-direction: row;
        padding-inline: 0;
    }
    .site-menus .site-menu--secondary.site-menu {
        margin-block-start: 0;
    }
    .site-menus .site-menu a {
        color: var(--fa--color--primary);
        font-size: 0.875rem!important;
        font-weight: 400;
        letter-spacing: .105em;
        font-style: normal! important;
        padding-block: 0;
        position: relative;
        text-transform: uppercase;
    }
    .site-menus .site-menu a:after {
        background: var(--fa--color--primary);
        bottom: -3px;
        content: "";
        height: 1.5px;
        left: 0;
        position: absolute;
        transition: width .2s ease-in-out;
        width: 0;
    }
    .site-menu a:hover:after {
        width: 100%;
    }
}
@media (min-width: 86rem) {
    .site-header .container-xl {
        column-gap: 3.25rem;
    }
    .site-menus {
        align-items: center;
        flex-direction: row;
        justify-content: space-between;
    }
    .site-menus .site-menu--primary.site-menu {
        column-gap: 3.25rem;
    }
    .site-menus .site-menu--secondary.site-menu {
        column-gap: 2.5rem;
    }
}

/* --------------------------------------------------------------
= 7. Page Header
-------------------------------------------------------------- */

.page-header {
    margin-block-end: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem);
    margin-inline: auto;
    max-width: 75rem;
}
.page-title {
    color: var(--fa--color--secondary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1rem;
    font-style: normal;
    font-weight: 400;
    letter-spacing: .105em;
    line-height: 1;
    line-height: 1.15;
    text-transform: uppercase;
}
.entry-title {
    color: var(--fa--color--primary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: clamp(2.25rem, 2.1667rem + 0.4167vw, 2.5rem);
    font-style: italic;
    font-weight: 300;
    letter-spacing: -0.015em;
    line-height: 1.2em;
    margin-block-end: 0.5rem;
}
.entry-location {
    color: var(--fa--color--secondary);
    font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem);
    font-weight: 700;
    line-height: 1.4em;
}
.entry--subtitle {
    color: var(--fa--color--quinary);
    font-size: 1rem;
    font-weight: 700;
    line-height: 1.4em;
}
.entry-taxonomy {
    color: var(--fa--color--primary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 0.8125rem;
    font-weight: 400;
    letter-spacing: .105em;
    line-height:  1.2em;
    margin-block-end: 0.25rem;
    text-transform: uppercase;
}
.entry--date-range {
    color: var(--fa--color--secondary);
    line-height: 1.4em;
    font-size: clamp(1.125rem, 1.0833rem + 0.2083vw, 1.25rem);
}
.entry-featured-image,
.entry-featured-video {
    margin-block-end: 2.5rem!important;
}
.page-header .entry-featured-image,
.page-header .entry-featured-video {
    margin-block-start: 2.5rem!important;
    margin-block-end: 0!important;
}
.entry-featured-image img {
    aspect-ratio: 16 / 9;
    display: block;
    height: auto;
    width: 100%;
}
.entry-featured-image.is-style-rounded img {
    border-radius: 1.25em;
}
.entry-featured-video .entry-featured-video--wrapper {
    aspect-ratio: 16 / 9;
	position: relative;
    overflow: hidden;
}
.entry-featured-video.is-style-rounded .entry-featured-video--wrapper {
    border-radius: 1.25em;
}
.entry-featured-video .entry-featured-video--wrapper iframe {
	position: absolute;
    height: 100%;
	inset: 0;
    width: 100%;
}

/* --------------------------------------------------------------
= 8. Card Model
-------------------------------------------------------------- */

.post-card .entry-title {
    font-size: clamp(1.75rem, 1.5833rem + 0.8333vw, 2.25rem);
    line-height: 1.15em;
    backface-visibility: hidden;
}
.col-3 .post-card .entry-title {
    font-size: 1.75rem;
}
.post-card .entry-title a {
    color: var(--fa--color--primary);
    text-decoration: none!important;
}
.post-card .post-card--taxonomy {
    color: var(--fa--color--primary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 0.8125rem;
    font-weight: 400;
    letter-spacing: .105em;
    line-height:  1.2em;
    margin-block-end: 0.25rem;
    text-transform: uppercase;
}
.post-card--date-range,
.post-card--location {
    color: var(--fa--color--secondary);
    line-height: 1.4em;
}
.post-card--date-range {
    font-size: clamp(1.125rem, 1.0833rem + 0.2083vw, 1.25rem);
}
.post-card--location {
    font-size: clamp(0.875rem, 0.8333rem + 0.2083vw, 1rem);
    font-weight: 700;
    margin-block-start: 0.2rem;
}
.post-card .wp-block-image {
    aspect-ratio: 16 / 9;
    box-shadow: none;
    transition: box-shadow 300ms ease;
    overflow: hidden;
}
.entry-content .post-card .wp-block-image {
    margin-block-end: 0.75em!important;
}
.entry-content .post-card .wp-block-image.is-style-rounded {
    border-radius: 1.25em;
}
.entry-content .post-card .wp-block-image.is-style-rounded img {
    border-radius: none!important;
}
.post-card .wp-block-image img {
    height: 100%;
    object-fit: cover;
    transform: scale(1);
    transition: transform 300ms ease;
    width: 100%;
    will-change: transform;
}
.post-card a:hover .wp-block-image {
    box-shadow: 1px 1px 10px var(--fa--color--shadow);
}
.post-card a:hover .wp-block-image img {
    transform: scale(1.01);
}
.entry-content .post-card p {
    color: var(--fa--color--secondary);
    margin-block-start: 0.75em;
    margin-block-end: 0;
}
.post-grid .post-card p.is-truncated {
    display: -webkit-box;
    -webkit-line-clamp: 2;
            line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    height: auto;
}
.post-grid.col-1 .post-card p.is-truncated {
    -webkit-line-clamp: 3;
            line-clamp: 3;
}
.post-card .wp-block-button {
    margin-block-start: 1.25em;
}
.post-grid {
    width: 100%;
    display: flex;
    flex-direction: column;
    gap: calc(var(--fa--gutter) * 1.5);
}
@media ( min-width: 48rem ) {
    .post-grid.col-2, 
    .post-grid.col-3 {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: calc(var(--fa--gutter) * 1.5) var(--fa--gutter);
    }  	
}
@media ( min-width: 64rem ) {
    .post-grid.col-3 {
        grid-template-columns: repeat(3, 1fr);
    }  
}

/* Sequencing  ----------------------------------------------- */

.post-card .entry-title.is-style-space-mono {
    font-size: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem);
    font-style: normal;
    font-weight: 700;
    line-height: 1.1em;
}
.post-card .author.is-style-space-mono {
    line-height: 1.1em;
    text-align: right;
    text-transform: uppercase;
}
.post-card .issue-no.is-style-space-mono {
    color: var(--fa--color--secondary);
    font-size: clamp(1rem, 0.9583rem + 0.2083vw, 1.125rem);
    font-style: italic;
    line-height: 1.1em;
    margin-block-end: 1.25rem;
}
.post-card .sequencing-tax.is-style-space-mono {
    color: var(--fa--color--quaternary);
    font-size: 1rem;
    letter-spacing: 0.25em;
    list-style: none;
    margin-block: 1.25rem 0;
    margin-inline: 0;
    padding: 0;
    text-transform: uppercase;
}
.post-card .sequencing-tax.is-style-space-mono li {
    display: inline-block;
    margin-inline-end: clamp(1.25rem, 0.9375rem + 1.5625vw, 2.1875rem);;
}

/* --------------------------------------------------------------
= 9. Carousel Model
-------------------------------------------------------------- */

/* Flickity Navigation  -------------------------------------- */

.slider-header {
    flex-wrap: nowrap;
    justify-content: space-between;
    margin-inline: auto;
    max-width: 75rem;
}
.single-fa_sequencing .slider-header {
    max-width: 90rem;
}
html .entry-content .slider-nav {
    align-items: center;
    gap: 0.625rem;
    justify-content: end;
    margin-block-end: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem)!important;
}
.slider-nav .button-icon {
    background: transparent;
    border: none;
    cursor: pointer;
}
.slider-nav .button-icon svg {
    height: 1.25rem;
    width: 1.25rem;
}
.slider-nav .button-icon.prev svg {
    transform: rotate(180deg);
}
.slider-nav .button-icon svg .fill {
    fill: var(--fa--color--secondary);
}
.slider-nav .button-icon:hover svg .fill {
    fill: var(--fa--color--primary);
}
.counter {
    color: var(--fa--color--secondary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1rem;
    letter-spacing: -0.05em;
    width: 3rem;
    text-align: center;
}
.flickity-enabled:focus {
    box-shadow: none;
}

/* Flickity Alt Navigation  ---------------------------------- */

.fa-gallery--border {
    border-block-start: 1px solid var(--fa--color--quaternary);
    color: transparent;
    margin-block-end: 2.5rem;
}
.single-fa_program .image-slider-wrapper .fa-gallery--border {
    max-width: 75rem;
}
.single-fa_sequencing .image-slider-wrapper .fa-gallery--border {
    max-width: 90rem;
}
.button-dummy {
    display: block;
    height: 1.25rem;
    width: 1.25rem;
}
.flickity-button.flickity-prev-next-button {
    opacity: 0.57!important;
}
.flickity-button.flickity-prev-next-button:hover {
    opacity: 1!important;
}
.flickity-button.flickity-prev-next-button:disabled {
    opacity: 0.2!important;
}
.fa-post-slider .flickity-button.flickity-prev-next-button svg,
.image-carousel:not(.is-fullscreen) .flickity-button.flickity-prev-next-button svg {
    display: none;
}
.fa-post-slider .flickity-button.flickity-prev-next-button,
.image-carousel:not(.is-fullscreen) .flickity-button.flickity-prev-next-button {
    background: transparent url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-sprite--arrows.png') 0 0 / 40px 20px no-repeat;
    border-radius: 0!important;
    height: 1.25rem;
    inset-block-start: calc((clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem) * -1) - 22px);
    transition: opacity 300ms ease;
    transform: none;
    width: 1.25rem;
}
.fa-post-slider .flickity-button.flickity-prev-next-button.previous,
.image-carousel:not(.is-fullscreen) .flickity-button.flickity-prev-next-button.previous {
    inset-inline-start: unset;
    inset-inline-end: 88px;
}
.fa-post-slider .flickity-button.flickity-prev-next-button.next,
.image-carousel:not(.is-fullscreen) .flickity-button.flickity-prev-next-button.next {
    background-position: -20px 0;
    inset-inline-end: 0;
}
.fa-post-slider .flickity-button.flickity-prev-next-button.previous:hover,
.image-carousel:not(.is-fullscreen) .flickity-button.flickity-prev-next-button.previous:hover {
    background: transparent url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-sprite--arrows.png') 0 0 / 40px 20px no-repeat;
}
.fa-post-slider .flickity-button.flickity-prev-next-button.next:hover,
.image-carousel:not(.is-fullscreen) .flickity-button.flickity-prev-next-button.next:hover {
    background: transparent url('https://dev6.3n.design/wp-content/themes/fulcrumarts/assets/img/fa-sprite--arrows.png') -20px 0 / 40px 20px no-repeat;
    background-position: -20px 0;
}
.image-carousel.is-fullscreen .flickity-button.flickity-prev-next-button svg {
    display: block;
}
.image-carousel.is-fullscreen .flickity-button {
    position: absolute;
    background: transparent;
    border: 2px solid var(--fa--color--primary);
    color: var(--fa--color--primary);
}
.image-carousel.is-fullscreen .flickity-prev-next-button {
    top: 50%;
    width: 32px;
    height: 32px;
    border-radius: 50%;
    transform: translateY(-50%);
}
.image-carousel.is-fullscreen .flickity-prev-next-button .flickity-button-icon {
    position: absolute;
    left: 10%;
    top: 10%;
    width: 80%;
    height: 80%;
}
.image-carousel.is-fullscreen .flickity-prev-next-button.next {
    inset-inline-end: clamp(0.625rem, 0rem + 3.125vw, 2.5rem);
}
.image-carousel.is-fullscreen .flickity-prev-next-button.previous {
    inset-inline-start: clamp(0.625rem, 0rem + 3.125vw, 2.5rem);
}
.image-carousel .close-fullscreen {
    background-color: transparent;
    inset-block-start: clamp(0.625rem, 0rem + 3.125vw, 2.5rem);
    inset-inline-end: clamp(0.625rem, 0rem + 3.125vw, 2.5rem);
    height: 32px;
    position: absolute;
    width: 32px;
    z-index: 101;
}
.image-carousel .close-fullscreen { display: none; }
.image-carousel.is-fullscreen .close-fullscreen { display: block; }
.image-carousel .close-fullscreen:before,
.image-carousel .close-fullscreen:after {
    background-color: var(--fa--color--primary);
    content: '';
    inset-block-start: 50%;
    inset-inline-start: 50%;
    height: 2px;
    position: absolute;
    transition: background-color 300ms ease;
    width: 30px;
}
.image-carousel .close-fullscreen:before {
    transform: translate(-50%, -50%) rotate(-45deg);
}
.image-carousel .close-fullscreen:after {
    transform: translate(-50%, -50%) rotate(45deg);
}
.image-carousel .close-fullscreen:hover:before,
.image-carousel .close-fullscreen:hover:after {
    background-color: var(--fa--color--secondary);
}

/* Flickity Gallery  ----------------------------------------- */

.entry-content .image-slider-wrapper {
    margin-block-end: 0!important;
    min-height: 23.4375rem; /* 375px */
    overflow: hidden;
}
.entry-content .image-slider-wrapper .image-carousel {
    margin-inline: auto;
    max-width: 75rem;
    min-height: 200px;
    padding-block-end: 5rem!important;
}
.single-fa_sequencing .image-slider-wrapper .image-carousel {
    max-width: 90rem;
}
.image-slider-wrapper .image-carousel .flickity-viewport {
    overflow: visible!important;
}
.image-slider-wrapper .image-carousel .image-carousel__item {
    display: inline-block!important;
    min-width: 150px;
    width: auto;
    max-width: none;
    height: 200px;
}
@media screen and (min-width: 48rem) {
    .entry-content .image-slider-wrapper {
        min-height: 34.375rem; /* 550px */
    }
    .entry-content .image-slider-wrapper .image-carousel {
        min-height: 400px;
        padding-block-end: 3rem!important;
    }
    .image-slider-wrapper .image-carousel .image-carousel__item {
        height: 400px;
    }
}
@media screen and (min-width: 64rem) {
    .entry-content .image-slider-wrapper {
        min-height: 52rem; /* 832px */
    }
    .entry-content .image-slider-wrapper .image-carousel {
        min-height: 600px;
        padding-block-end: 7.75rem!important;
    }
    .image-slider-wrapper .image-carousel .image-carousel__item {
        height: 650px;
    }
}
.image-slider-wrapper .image-carousel img {
    display: block;
    height: 100%;
    width: auto;
    border-radius: 1.25rem;
}
.image-slider-wrapper .image-carousel.is-fullscreen img {
    border-radius: 0!important;
}
.image-slider-wrapper .image-carousel.is-fullscreen .image-carousel__item {
    max-width: 100%;
    width: 100%;
}
.image-slider-wrapper .image-carousel.is-fullscreen img {
    height: auto;
    margin-inline: auto;
    max-height: calc(100dvh - 11.75em); /* 128px */
    max-width: 70%;
    text-align: center;
    width: auto;
}
.image-slider-wrapper .image-carousel:not(.is-fullscreen) .image-carousel__item {
    cursor: zoom-in;
}
.image-slider-wrapper .image-carousel:not(.is-fullscreen) .image-carousel__item figcaption {
    position: absolute;
    inset-block-end: 0;
    inset-inline-start: 0;
    display: block !important;
    opacity: 0;
    transform: translateY(calc(100% + 10px));
    transition: opacity 300ms ease;
}
.image-slider-wrapper .image-carousel:not(.is-fullscreen) .image-carousel__item:hover figcaption {
    opacity: 1;
}
.image-slider-wrapper .image-carousel.is-fullscreen figcaption {
    display: block;
    margin-block-start: clamp(0.625rem, 0.0893rem + 2.6786vw, 2.5rem); /* 10px - 40px (320px to 1440px) */
    margin-inline: auto;
    width: 70%;
}
.image-slider-wrapper .image-carousel__item:not(:last-of-type) {
    margin-inline-end: var(--fa--gutter)!important;
}
.image-slider-wrapper .image-carousel {
    transition: opacity 0.3s ease-in-out 0.3s;
}
.image-slider-wrapper .image-carousel.image-slider-finally-loaded {
    opacity: 1;
}
.image-slider-wrapper .image-carousel.is-fullscreen {
    z-index: 100;
}
.entry-content .image-slider-wrapper .image-carousel.is-fullscreen {
    padding-block-start: 4rem!important;
}
.image-slider-wrapper .image-carousel.is-fullscreen .image-carousel__item {
    height: 100%;
    display: flex;
    flex-wrap: wrap;
    align-content: center;
}
.image-slider-wrapper .image-carousel.is-fullscreen .image-carousel__item {
    align-items: center;
}
.image-slider-wrapper .image-carousel.is-fullscreen {
    background-color: var(--fa--color--background);
    max-width: 100%!important;
    opacity: 1;
}
.image-slider-wrapper .image-carousel.is-fullscreen .flickity-viewport {
    height: 100% !important;
}
.image-slider-wrapper .image-carousel:not(.is-fullscreen) {
    transform: scale(1);
    opacity: 1;
}

/* --------------------------------------------------------------
= 10. Templates Parts
-------------------------------------------------------------- */

/* Breadcrumbs  ---------------------------------------------- */

.is-breadcrumb {
    color: inherit;
    display: inline;
    font-size: inherit;
    letter-spacing: inherit;
    line-height: inherit;
}
.breadcrumb-separator {
    margin: 0 0.5em;
}
.fa-breadcrumbs a {
    position: relative;
    text-decoration: none;
    transition: color 200ms ease;
}
.fa-breadcrumbs a:hover {
    color: var(--fa--color--primary);
    position: relative;
    text-decoration: none;
}
.fa-breadcrumbs a::after {
    background: var(--fa--color--secondary);
    content: "";
    height: 1.5px;
    inset-block-end: -0.2em;
    inset-inline-start: 0;
    position: absolute;
    transition: all 200ms ease-in-out;
    width: 0;
}
.fa-breadcrumbs a:hover::after {
    background: var(--fa--color--primary);
    width: 100%;
}
.site-header .fa-breadcrumbs a::after {
    inset-block-end: 0.2em;
}
.site-header .fa-breadcrumbs a:hover::after {
    inset-block-end: 0.2em;
}

/* Gravity Forms  -------------------------------------------- */

.gform_wrapper.gravity-theme .gfield_label {
    margin-block-end: 0;
}
.gform_wrapper.gravity-theme .field_description_above .gfield_description {
    padding-block-start: 0;
}
.gform_wrapper.gravity-theme input[type=color], 
.gform_wrapper.gravity-theme input[type=date], 
.gform_wrapper.gravity-theme input[type=datetime-local], 
.gform_wrapper.gravity-theme input[type=datetime], 
.gform_wrapper.gravity-theme input[type=email], 
.gform_wrapper.gravity-theme input[type=month], 
.gform_wrapper.gravity-theme input[type=number], 
.gform_wrapper.gravity-theme input[type=password], 
.gform_wrapper.gravity-theme input[type=search], 
.gform_wrapper.gravity-theme input[type=tel], 
.gform_wrapper.gravity-theme input[type=text], 
.gform_wrapper.gravity-theme input[type=time], 
.gform_wrapper.gravity-theme input[type=url], 
.gform_wrapper.gravity-theme input[type=week], 
.gform_wrapper.gravity-theme select, 
.gform_wrapper.gravity-theme textarea,
.gform_wrapper.gravity-theme .gfield textarea {
    background-color: var(--fa--color--background);
    border: none;
    border-radius: 10px;
}
.gform_wrapper.gravity-theme .ginput_complex select,
.gform_wrapper.gravity-theme .gfield_list_group_item select {
    height: 40px;
}
.gform_wrapper.gravity-theme input[type="checkbox"], 
.gform_wrapper.gravity-theme input[type="radio"] {
    border: 3px solid var(--fa--color--background);
    background-color: var(--fa--color--background);
    height: 17px;
    width: 17px;
    vertical-align: text-bottom;
}
.gform_wrapper.gravity-theme input[type="checkbox"]:checked, 
.gform_wrapper.gravity-theme input[type="radio"]:checked {
    background-color: var(--fa--color--primary);
}
/* Programming Archive  -------------------------------------- */

.archive-header {
    flex-wrap: nowrap;
    justify-content: space-between;
    margin-inline: auto;
    max-width: 75rem;
}
html .entry-content .archive-nav {
    align-items: center;
    gap: 0.625rem;
    justify-content: end;
    margin-block-end: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem)!important;
}
.archive-nav .button-icon {
    background: transparent;
    border: none;
    cursor: pointer;
}
.archive-nav .button-icon svg {
    height: 1.25rem;
    width: 1.25rem;
}
.archive-nav .button-icon.prev svg {
    transform: rotate(180deg);
}
.archive-nav .button-icon svg .fill {
    fill: var(--fa--color--quaternary);
}
.archive-nav .button-icon a svg .fill {
    fill: var(--fa--color--secondary);
}
.archive-nav .button-icon a:hover svg .fill {
    fill: var(--fa--color--primary);
}
.current-year {
    color: var(--fa--color--secondary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1rem;
    letter-spacing: 0.105em;
    min-width: 2rem;
    text-align: center;
}

/* Sequencing Archive  --------------------------------------- */

.seq-taxonomy-header {
    flex-direction: column;
    gap: 1.875rem;
    margin-block: clamp(2.5rem, 2.0833rem + 2.0833vw, 3.75rem) clamp(3.75rem, 2.9167rem + 4.1667vw, 6.25rem)!important;
}
.seq-taxonomy-header--title {
    color: var(--fa--color--primary);
    font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem);
    font-weight: 700;
    line-height: 1.5em;
    text-transform: uppercase;
}
.seq-taxonomy-header--title a {
    white-space: nowrap;
}
.seq-taxonomy-header--back {
    color: var(--fa--color--primary);
    display: inline-block;
    transition: color 300ms ease;
    vertical-align: baseline;
}
.seq-taxonomy-header--back svg {
    display: inline-block;
    height: auto;
    width: 18px;
}
.single .seq-taxonomy-header--back svg {
    display: inline;
}
.seq-taxonomy-header--title a:hover,
.single .seq-taxonomy-header--back:hover {
    color: var(--fa--color--secondary);
}
.seq-taxonomy-header--back svg .fill {
    fill: var(--fa--color--primary);
}
.seq-taxonomy-header--back:hover svg .fill {
    fill: var(--fa--color--secondary);
}
.seq-taxonomy-header--description {
    line-height: 1.5em;
}
@media ( min-width: 48rem ) {
    .seq-taxonomy-header {
        flex-direction: row;
    }
    .seq-taxonomy-header--title {
        white-space: nowrap;
    }
}

/* Sequencing Issue  ----------------------------------------- */

.sequencing-page-header {
    margin-inline: auto;
    max-width: 75rem;
}
.sequencing-header {
    margin-block-end: 2.5rem;
}
.sequencing-header .entry-title {
    font-size: clamp(1.875rem, 1.25rem + 3.125vw, 3.75rem);
    font-style: normal;
    font-weight: 700;
    line-height: 1.1em;
    margin-block-end: 1rem;
    text-transform: uppercase;
}
.sequencing-header .entry-meta {
    justify-content: space-between;
}
.sequencing-header .author {
    font-size: clamp(1.125rem, 1rem + 0.625vw, 1.5rem);
    line-height: 1.1em;
    text-align: right;
    text-transform: uppercase;
}
.sequencing-header .issue-no {
    color: var(--fa--color--secondary);
    font-size: clamp(1rem, 0.9583rem + 0.2083vw, 1.125rem);
    font-style: italic;
    line-height: 1.1em;
    margin-block-end: 1.25rem;
}
.sequencing-header .author span,
.sequencing-header .issue-no span {
    display: block;
}
.sequencing-header .wp-block-button {
    margin-block-start: 0.75rem;
}
ul.sequencing-tax {
    flex-direction: column;
    gap: 0.625rem;
    list-style: none!important;
    margin: 0;
    padding: 0!important;
    text-transform: uppercase;
}
ul.sequencing-tax a {
    color: var(--fa--color--secondary)!important;
    font-size: clamp(1rem, 0.9167rem + 0.4167vw, 1.25rem)!important;
    font-weight: 400;
    line-height: 1.5em;
    text-decoration: none!important;
}
ul.sequencing-tax a:hover {
    color: var(--fa--color--primary)!important;
}
@media ( min-width: 48rem ) {
    .sequencing-header .issue-no span {
        display: inline-block;
    }
}

/* --------------------------------------------------------------
= 11. Blocks Global Styles
-------------------------------------------------------------- */

.entry-content {
    font-size: clamp(1rem, 0.9583rem + 0.2083vw, 1.125rem);
    font-weight: 400;
	line-height: 1.35em;
}
.entry-content > * {
    margin-inline: auto!important;
    max-width: 75rem;
}
.alignwide {
    margin-inline: auto;
    max-width: 90rem;
}
.alignfull {
    margin-inline: calc(var(--fa--gutter) * -1)!important;
    max-width: calc(100% + var(--fa--gutter) * 2)!important;
    width: calc(100% + var(--fa--gutter) * 2)!important;
}
.is-layout-flow > .alignleft,
.is-layout-flow > .alignright {
    float: none!important;
}
@media ( min-width: 782px ) {
    .is-layout-flow > .alignleft,
    .is-layout-flow > .alignright {
        width: calc(50% - var(--fa--gutter) / 2)!important;
    }
    .is-layout-flow > .alignleft {
        float: left!important;
        margin-inline-end: var(--fa--gutter)!important;
    }
    .is-layout-flow > .alignright {
        float: right!important;
        margin-inline-start: var(--fa--gutter)!important;
    }    
}
@media ( min-width: 64rem ) {
    .is-layout-flow > .alignleft,
    .is-layout-flow > .alignright {
        width: calc(33.33% - var(--fa--gutter) / 2)!important;
    }
    .is-layout-flow > .alignleft.size-large,
    .is-layout-flow > .alignright.size-large {
        width: calc(50% - var(--fa--gutter) / 2)!important;
    }
}
.entry-content a:not(.wp-block-button__link) {
	color: var(--fa--color--primary);
	text-decoration: underline;
	transition: color 300ms ease;
}
.entry-content p a:hover {
	color: var(--fa--color--secondary);
}
.entry-content sup a:focus {
    font-weight: 700;
    outline: none;
}
.entry-content p,
.entry-content dl,
.entry-content ol,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6,
.entry-content blockquote,
.entry-content .custom-button-block {
	margin-block-end: 1.5em;
}
.entry-content h2.wp-block-heading {
    color: var(--fa--color--primary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: clamp(1.75rem, 1.5833rem + 0.8333vw, 2.25rem);
    font-weight: 300;
    letter-spacing: -0.015em;
    line-height: 1.15em;
    margin-block-end: 2.25rem;
    backface-visibility: hidden;
}
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
    color: var(--fa--color--secondary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1rem;
    font-style: normal;
    font-weight: 400;
    letter-spacing: .105em;
    line-height: 1;
    line-height: 1.15;
    margin-block-end: 1.25em;
    text-transform: uppercase;
}
.entry-content h3,
.entry-content h3:last-child {
    margin-block-end: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem)!important;
}
.entry-content h6 {
    font-size: 0.8125em;
    line-height: 1em;
    margin-block-end: 0.5rem;
}
.entry-content address {
    font-style: normal;
}
.entry-content sup {
    font-size: 0.75em;
    line-height: 1;
    vertical-align: super;
}
.entry-content p .code {
    background-color: rgba(231, 231, 231, 0.5);
    font-family: 'Space Mono', monospace;
    font-weight: 400;
    font-style: normal;
    padding: 0 0.25em;
}

.entry-content *:last-child {
    margin-block-end: 0!important;
}

/* Block: Global Styles  ------------------------------------- */

.entry-content .has-text-align-center {
	text-align: center;
}
.entry-content iframe {
    display: block;
}
.entry-content .is-style-sticky {
    position: sticky;
    top: var(--fa--gutter);
}
.entry-content .has-large-font-size {
    line-height: 1.5em;
}
.entry-content .has-x-large-font-size {
    font-weight: 300;
    line-height: 1.3em;
}
.entry-content .has-double-gap {
    gap: calc(var(--fa--gutter) * 3)!important;
}

/* --------------------------------------------------------------
= 12. Blocks
-------------------------------------------------------------- */

/* Block: List  ---------------------------------------------- */

.entry-content ul {
	list-style: disc outside;
    margin-block-end: 2em;
	padding-inline-start: 1.25em;
}
.entry-content ul ul {
	list-style: circle outside;
	margin-block-end: 0;
	padding-inline-start: var(--fa--block--gap);
}

/* Block: Group  --------------------------------------------- */

.entry-content > .wp-block-group {
    margin-block-end: var(--fa--section--gap-end);
}
.entry-content > .wp-block-group .wp-block-group {
    margin-block-end: var(--fa--block--gap);
}

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

.entry-content img {
	display: block;
	height: auto;
	width: 100%;
}
.entry-content.aligncenter img {
    max-width: 100%;
    width: auto;
}
.entry-content .wp-block-image {
    margin-block-end: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem);
    overflow: hidden;
}
.entry-content .is-layout-flex > .wp-block-image:last-child {
    margin-block-end: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem)!important;
}
.entry-content .wp-block-image.alignfull {
    border-radius: 0;
    margin-block-end: clamp(1.25rem, 0.4167rem + 4.1667vw, 3.75rem)!important;
}
figcaption {
    color: var(--fa--color--secondary)!important;
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 0.75rem!important;
	line-height: 1.4em;
	padding-block: 0.3125rem 0;
    padding-inline: 0;
    text-align: left!important;
}
.alignfull figcaption {
    padding-inline: calc(var(--fa--gutter) * 1)!important;
}

/* Block: Button --------------------------------------------- */

.button-block {
    margin-block-end: var(--fa--block--gap);
}
.button,
.button.primary,
.wp-block-button__link {
    background: var(--fa--color--primary)!important;
    border: 2px solid transparent!important;
    border-radius: 3rem;
    /* box-shadow: .1em .1em 0 hsla(0, 0%, 100%, .5); */
    color: var(--fa--color--background)!important;
    cursor: pointer;
    display: inline-block;
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    line-height: 1.5;
    margin: 0;
    outline: none;
    padding: 12px 24px;
    text-align: center;
    text-decoration: none!important;
    text-transform: uppercase;
    text-wrap: nowrap;
    transition:background-color 300ms ease-in-out, color 300ms, border-color 300ms;
    width: auto!important;
}
.single-fa_sequencing .wp-block-button__link {
    font-weight: 600;
}
.button:active, 
.button:focus,
.button:hover, 
.wp-block-button__link:hover {
    background: transparent!important;
    border: 2px solid hsla(0, 0%, 75%, .5)!important;
    box-shadow:0 0 15px -6px var(--fa--color--primary), inset 0 0 14px -6px!important;
    color: var(--fa--color--primary)!important;
}
.wp-block-button__link:has(svg) {
    padding-inline-end: 55px!important;
    position: relative;
}
.wp-block-button__link svg {
    height: auto;
    inset-block-start: 1.03125rem;
    inset-inline-end: 24px;
    position: absolute;
    width: 21px;
}
.wp-block-button__link[target="_blank"] svg {
    transform: rotate(-45deg);
}
.wp-block-button__link svg .fill {
    fill: var(--fa--color--background);
}
.wp-block-button__link:hover svg .fill,
.wp-block-button__link:focus svg .fill {
    fill: var(--fa--color--primary);
}
.button:has(svg),
.wp-block-button__link:has(svg) {
    padding-inline-end: 55px!important;
    position: relative;
}
.button svg,
.wp-block-button__link svg {
    height: auto;
    inset-block-start: 1.03125rem;
    inset-inline-end: 24px;
    position: absolute;
    width: 21px;
}
.button[target="_blank"] svg,
.wp-block-button__link[target="_blank"] svg {
    transform: rotate(-45deg);
}
.button svg .fill,
.wp-block-button__link svg .fill {
    fill: var(--fa--color--background);
}
.button:hover svg .fill,
.button:focus svg .fill,
.wp-block-button__link:hover svg .fill,
.wp-block-button__link:focus svg .fill {
    fill: var(--fa--color--primary);
}

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

.entry-content .wp-block-columns {
    margin-block-end: var(--fa--block--gap);
}
@media ( min-width: 48rem ) {
    .entry-content .wp-block-columns {
        margin-block-end: var(--fa--block--gap);
    }
}

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

.wp-block-embed,
.wp-block-video {
    margin-block-end: var(--fa--block--gap) !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-bottom: 56.25%;
	position: relative;
}
.wp-block-embed.wp-embed-aspect-4-3 .wp-block-embed__wrapper {
	padding-bottom: 75%; /* 4:3 */
}
.wp-block-embed.wp-embed-aspect-16-9 .wp-block-embed__wrapper {
	padding-bottom: 56.25%; /* 16:9 */
}
.wp-block-embed.wp-embed-aspect-21-9 .wp-block-embed__wrapper {
	padding-bottom:  41.5625%; /* 21:9 */
}
.wp-block-embed.wp-embed-aspect-1-1 .wp-block-embed__wrapper {
	padding-bottom:  100%; /* 1:1 */
}
.wp-block-embed .wp-block-embed__wrapper iframe {
    position: absolute;
    height: 100%;
    inset: 0;
    width: 100%;
}

/* Block: Quotes --------------------------------------------- */

.entry-content .wp-block-quote {
    border: none !important;
    border-left: none !important;
    padding-left: clamp(2.5rem, 1.6667rem + 4.1667vw, 5rem) !important;
    margin: 0;
}
.entry-content .wp-block-quote,
.entry-content .wp-block-pullquote {
    margin-block-end: 1.5em!important;
}
.entry-content .wp-block-quote p:only-child,
.entry-content .wp-block-quote p:nth-last-child(2),
.entry-content .wp-block-pullquote blockquote p:only-child,
.entry-content .wp-block-pullquote blockquote p:nth-last-child(2) {
	margin-block-end: 0;
}
.entry-content .wp-block-quote cite,
.entry-content .wp-block-pullquote blockquote cite {
    color: var(--fa--color--secondary);
    font-family: var(--fa--font--ibm-plex-mono);
	font-size: 1rem;
}

/* Block: Horizontal Rule ------------------------------------ */

.entry-content hr.wp-block-separator {
    border-block-start: 1px solid var(--fa--color--quaternary);
    color: transparent;
    margin-block: 2.5rem;
}

/* Block: Code ----------------------------------------------- */

.entry-content .wp-block-code {
    background-color: rgba(231, 231, 231, 0.5);
    border: none;
    border-radius: 0;
    font-family: 'Space Mono', monospace;
    font-weight: 400;
    font-style: normal;
    margin-block-end: 1.5em;
    padding: 0 0.5em;
}
.wp-block-code code {
    direction: ltr;
    display: block;
    font-family: inherit;
    overflow-wrap: break-word;
    text-align: initial;
    white-space: pre-wrap
    /*!rtl:end:ignore*/;
}
.entry-content .wp-block-code code {
    white-space: normal;
}

/* Block: Narrow --------------------------------------------- */

p.is-style-narrow,
.is-style-narrow p,
.is-style-narrow ul {
    max-width: 62.5rem!important;
    margin-right: auto!important;
    margin-left: 0!important;
}
p.is-style-two-thirds,
.is-style-two-thirds p,
.is-style-two-thirds ul {
    max-width: 49.1875rem!important;
    margin-right: auto!important;
    margin-left: 0!important;
}

/* --------------------------------------------------------------
= 13. Site Pagination
-------------------------------------------------------------- */

/* --------------------------------------------------------------
= 14. Site Footer
-------------------------------------------------------------- */

.site-footer {
    background-color: var(--fa--color--tertiary);
    color: var(--fa--color--secondary);
    line-height: 1.4em;
    padding-block: 2.5rem calc(var(--fa--gutter) * 2);
    position: relative;
}
.site-footer p,
.site-footer h6,
.site-footer ul,
.site-footer menu {
    margin-block-end: 0.5rem;
}
.site-footer p:last-child,
.site-footer h6:last-child,
.site-footer ul:last-child,
.site-footer menu:last-child {
    margin-block-end: 0;
}
.site-footer h6 {
    color: var(--fa--color--primary);
    font-weight: 400;
    letter-spacing: .105em;
    text-transform: uppercase;
}
.site-footer ul,
.site-footer menu {
    margin-block-start: 0;
    margin-inline: 0;
    padding: 0;
}
.site-footer address {
    font-style: normal;
}
.footer-columns {
    flex-direction: column;
    gap: 1.5em;
    padding-block-end: clamp(1.875rem, 1.4583rem + 2.0833vw, 3.125rem);
}
.site-footer .hide-on-mobile {
    display: none;
}
@media ( min-width: 48rem ) {
    .footer-columns {
        flex-direction: row;
        flex-wrap: wrap;
        gap: var(--fa--gutter);
    }
    .footer-columns .footer-column {
        width: calc(50% - var(--fa--gutter) / 2);
    }
}
@media ( min-width: 64rem ) {
    .footer-columns {
        flex-wrap: nowrap;
        gap: var(--fa--gutter);
    }
    .footer-columns .footer-column {
        width: calc(25% - var(--fa--gutter) / 3);
    }
    .footer-columns #footer-follow-us.footer-column {
        width: calc(30% - var(--fa--gutter) / 3);
    }
    .footer-columns #footer-about-us.footer-column {
        width: calc(20% - var(--fa--gutter) / 3);
    }
}

/* Column One  ---------------------------------------------- */

.footer-column:first-child {
    padding-block-end: 1.75rem;
}
.site-footer .site-socials,
.site-socials .footer-menu--social {
    flex-direction: row;
}
.site-footer .site-socials {
    align-items: center;
    gap: 1.5rem;
    margin-block-end: 1.25rem;
}
.site-socials .footer-menu--social {
    gap: 0.375em;
}
.menu-icon {
    background-color: var(--fa--color--background);
    border-radius: 50%;
    height: 40px;
    position: relative;
    width: 40px;
    transition: background-color 200ms ease;
}
.menu-icon:hover {
    background-color: var(--fa--color--primary);
    box-shadow:0 0 7px -3px var(--fa--color--primary);
}
.menu-icon svg {
    height: 22px;
    inset-block-start: 50%;
    inset-inline-start: 50%;
    position: absolute;
    transform: translate(-50%, -50%);
    width: auto;
}
.menu-icon svg .fill {
    fill: var(--fa--color--primary);
}
.menu-icon:hover svg .fill {
    fill: var(--fa--color--background);
}

/* Column Two  ---------------------------------------------- */

.footer-menu--about {
    flex-direction: column;
    justify-content: start;
}
.footer-menu--about a {
    color: var(--fa--color--primary);
    font-family: var(--fa--font--ibm-plex-mono);
    font-size: 1rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    line-height: 1.75em;
    text-decoration: underline;
    text-transform: uppercase;
    text-decoration-thickness: 1.5px;
    text-underline-offset: 3px;
}
.footer-menu--about a:hover {
    text-decoration: none;
}
@media ( min-width: 64rem ) {
    .footer-about-us {
        justify-content: center;
    }
    .footer-menu--about {
        flex-shrink: 0;
    }
}

/* Column three  -------------------------------------------- */

.hours-of-operation__hours {
    margin-block-end: 1.25rem!important;
}

/* Column Four  --------------------------------------------- */

.site-footer .contact-details {
    margin-block-end: 1.5rem;;
}
.footer-menu--about a.phone-number {
    text-decoration: none!important;
}
.site-footer .contact-details a.email-address {
    color: var(--fa--color--secondary);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
}
.site-footer .contact-details a.email-address:hover {
    text-decoration: none;
}

/* Colophon  ------------------------------------------------ */

.site-footer .colophon {
    border-block-start: var(--fa--color--quaternary) solid 1px;
    justify-content: space-between;
    line-height: 1.25rem;
    padding-block-start: clamp(1.25rem, 0.8333rem + 2.0833vw, 2.5rem);
}
.colophon-column {
    width: 50%;
}
.site-copyright a {
    color: var(--fa--color--secondary);
    text-decoration: none;
    transition: color 200ms ease;
}
.site-copyright a:hover {
    color: var(--fa--color--primary);
}
.back-to-top {
    text-align: right;
}
.back-to-top button {
    background: transparent;
    color: var(--fa--color--secondary);
    font-family: var(--fa--font--ibm-plex-mono);
    text-transform: uppercase;
    transition: color 200ms ease;
}
.back-to-top button:hover {
    color: var(--fa--color--primary);
}
.back-to-top button svg {
    display: inline-block;
    height: 1.25rem;
    transform: rotate(-90deg);
    vertical-align: bottom;
    width: auto;
}
.back-to-top button svg .fill {
    fill: var(--fa--color--secondary);
}
.back-to-top button:hover svg .fill {
    fill: var(--fa--color--primary);
}
@media ( min-width: 48rem ) {
    .site-footer .hide-on-mobile {
        display: inline;
    }
}

/* --------------------------------------------------------------
= 15. Transitions
-------------------------------------------------------------- */

body {
    opacity: 0;
    transition: opacity 500ms ease-in-out;
}
body.is-loaded {
    opacity: 1;
}
.fade-in > * {
	opacity: 0;
	transform: translateY(1rem);
	transition: opacity 1.3s, transform 1.3s;
}
.fade-in .is-visible {
	opacity: 1;
	transform: translatey(0);
}

/* --------------------------------------------------------------
= 16. Accessibility
-------------------------------------------------------------- */

/* Text meant only for screen readers. */
.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;
}
/* Do not show the outline on the skip link target. */
#primary[tabindex="-1"]:focus {
	outline: 0;
}