:root { 
--color-purple: #582c83; 
--color-gold: #e1c340; 
--color-dark-pink: #cb0040; 
--color-pale-yellow: #fef7e6; 
--color-pale-blue: #e7f4fe; 
--color-pale-pink: #FEEDE4; 
--color-pale-thistle: #ECDFEC; 
--color-thistle: #d8bfd8; 
--color-pink: #FBE1E4; 
--color-gray: #767676; 
--color-black: #000000; 
--color-white: #FFFFFF; 
}
.has-purple-background-color { background-color: var(--color-purple) !important; }
.has-purple-color { color: var(--color-purple) !important; }
.has-gold-background-color { background-color: var(--color-gold) !important; }
.has-gold-color { color: var(--color-gold) !important; }
.has-dark-pink-background-color { background-color: var(--color-dark-pink) !important; }
.has-dark-pink-color { color: var(--color-dark-pink) !important; }
.has-pale-yellow-background-color { background-color: var(--color-pale-yellow) !important; }
.has-pale-yellow-color { color: var(--color-pale-yellow) !important; }
.has-pale-blue-background-color { background-color: var(--color-pale-blue) !important; }
.has-pale-blue-color { color: var(--color-pale-blue) !important; }
.has-pale-pink-background-color { background-color: var(--color-pale-pink) !important; }
.has-pale-pink-color { color: var(--color-pale-pink) !important; }
.has-pale-thistle-background-color { background-color: var(--color-pale-thistle) !important; }
.has-pale-thistle-color { color: var(--color-pale-thistle) !important; }
.has-thistle-background-color { background-color: var(--color-thistle) !important; }
.has-thistle-color { color: var(--color-thistle) !important; }
.has-pink-background-color { background-color: var(--color-pink) !important; }
.has-pink-color { color: var(--color-pink) !important; }
.has-gray-background-color { background-color: var(--color-gray) !important; }
.has-gray-color { color: var(--color-gray) !important; }
.has-black-background-color { background-color: var(--color-black) !important; }
.has-black-color { color: var(--color-black) !important; }
.has-white-background-color { background-color: var(--color-white) !important; }
.has-white-color { color: var(--color-white) !important; }


/*
 Theme Name:   Willow Foundation
 Theme URI:    https://www.willowfoundation.org.uk
 Description:  WordPress theme for Willow Foundation.
 Author:       DigitalGarden
 Author URI:   https://digitalgarden.co
 Version:      1.5.4
*/

/*
	FONTS:
	- montserrat
	- adobe-handwriting-frank
*/

/*! ----- VARIABLES  ----- */

:root {
    --gutter: 1.5rem; /* grid gap between columns and padding content */
    --gutter-50: calc(var(--gutter) * 0.5);
    --gutter-75: calc(var(--gutter) * 0.75);
    --gutter-200: calc(var(--gutter) * 2);
    --v-space: 2.5rem; /* normal (100%) vertical space */
    --v-space-25: calc(var(--v-space) * 0.3); /* tiny (25%) vertical space */
    --v-space-50: calc(var(--v-space) * 0.5); /* small (50%) vertical space */
    --v-space-75: calc(var(--v-space) * 0.75); /* medium (75%) vertical space */
    --v-space-150: calc(var(--v-space) * 1.5); /* large (150%) vertical space */
    --content-width: 950px;
    --content-width-wide: 1380px; /*was 1280*/
    --header-height: 74px;

    --font-size: 16px;
    --h1-multiplier: 1; /* Used to size elements exponentially relative to the base font size */
    --h2-multiplier: 1;
    --h3-multiplier: 1;
    --h4-multiplier: 1;

    --form-input-padding: 8px 20px;

    --shadow-light:
        0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
    --shadow-dark:
        0 10px 15px -3px rgb(0 0 0 / 0.2), 0 4px 6px -4px rgb(0 0 0 / 0.2);

    --enlarge-1: 1.01; /* bigger elements */
    --enlarge-2: 1.02; /* smaller elements */

    --duration: 0.3s;

    --swiper-theme-color: var(--color-purple);
    --swiper-navigation-sides-offset: -50px;
    --swiper-pagination-bottom: -75px;

    /* Breakpoints */
    --sm: 414px;
    --md: 768px;
    --lg: 1024px;
    --xl: 1280px;
}

@media (min-width: 414px) {
    /* sm */
    :root {
        --header-height: 79px;
    }
}

@media (min-width: 768px) {
    /* md */
    :root {
        --gutter: 2rem;
        --v-space: 3rem;
        --h1-multiplier: 1.2;
        --h2-multiplier: 1.2;
        --h3-multiplier: 1.2;
    }
}

@media (min-width: 1024px) {
    /* lg */
    :root {
        --font-size: 18px;
    }
}

@media (min-width: 1280px) {
    /* xl */
    :root {
        --v-space: 5rem;
        --h1-multiplier: 1.4;
        --h2-multiplier: 1.3;
        --h3-multiplier: 1.3;
        --h4-multiplier: 1.1;
    }
}

/*! ----- LAYOUT  ----- */

html {
    box-sizing: border-box;
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

*,
*:before,
*:after {
    box-sizing: inherit;
}

body {
    margin: 0;
}

main {
    padding: 0 0 var(--v-space-150);
}

body.page main {
    padding-bottom: 0;
}

main > :last-child {
    margin-bottom: 0;
}

main > *:not(.alignfull) {
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--gutter);
    padding-right: var(--gutter);
}

main > *:not(.alignwide):not(.alignfull) {
    /* root container is for the block editor */
    max-width: var(--content-width);
}

main > article > *:not(.alignfull) {
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--gutter);
    padding-right: var(--gutter);
}

main > article > *:not(.alignwide):not(.alignfull) {
    /* root container is for the block editor */
    max-width: var(--content-width);
}

.alignwide {
    max-width: var(--content-width-wide);
}

/*! ----- SITE HEADER ----- */

#header {
    background: var(--color-purple);
    line-height: 1;
    padding: 0;
    position: relative;
    z-index: 10;
}

.header__inner-container {
    position: relative;
    align-items: center;
    display: flex;
    flex: 1;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    max-width: calc(var(--content-width-wide) + var(--gutter-200));
    padding: var(--v-space-25) var(--gutter);
}

.page-template-merged-header #header {
    background: transparent;
    height: var(--header-height);
    left: 0;
    right: 0;
    position: absolute;
}

.page-template-merged-header #header.menu-open {
    background: var(--color-purple);
}

.page-template-merged-header #header.menu-open .logo-full {
    display: none;
}

/*! ----- LOGO ----- */

/*.home #header:not(.menu-open) .logo {
	content: url('img/willow-logo-square-white.png');
	top: 0;
	padding: 15px 42px 25px;
	border-radius: 0 0 20px 20px;
	background: #582c83;
}*/

.logo {
    position: absolute;
    top: 27px;
    left: var(--gutter);
    width: 248px;
    /*width: 200px;*/
}

@media (max-width: 1280px) {
    /*.home #header:not(.menu-open) .logo {
		width: 120px;
		padding: 9px 25px 15px;
		border-radius: 0 0 12px 12px;
	}*/

    .logo {
        top: 18px;
        width: 205px;
    }

    /*.home.page-template-merged-header #header.menu-open .logo {
		content: unset;
	}*/
}

@media (max-width: 767px) {
    /* sm */
    .logo {
        top: 15px;
    }
}

/*! ----- HEADER ----- */

.header-right {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

/*! ----- NAV - MOBILE ----- */

body.menu-open {
    position: fixed;
    overflow-y: hidden;
    max-height: 100vh;
}

#menu-toggle {
    background-color: var(--color-white);
    border: 2px solid var(--color-purple);
    color: var(--color-purple);
    margin: 0 0 0 var(--gutter);
    padding: 0;
    position: relative;
    border: 2px;
    width: 48px;
    height: 48px;
    text-align: center;
}

#menu-toggle:hover {
    transform: scale(var(--enlarge-2));
}

#menu-toggle .icon {
    width: 36px;
    height: 36px;
    margin: auto;
}

#menu-toggle .icon-menu,
#menu-toggle.close .icon-close {
    display: block;
}

#menu-toggle.close .icon-menu,
#menu-toggle .icon-close {
    display: none;
}

#menu-toggle:hover {
    cursor: pointer;
}

#nav-mobile .menu {
    display: none;
    position: relative;
}

#nav-mobile .menu > li.menu-item-has-children {
    position: relative;
}

#nav-mobile .menu > li.menu-item-has-children > a::after {
    content: url("img/icons/plus.svg");
    width: 20px;
    line-height: 14px;
}

#nav-mobile .menu > li.menu-item-has-children.show-sub-menu > a::after {
    content: url("img/icons/minus.svg");
}

#nav-mobile .menu .sub-menu {
    display: none;
    padding: 0 0 var(--gutter);
    margin: -10px 0 0 0;
}

#nav-mobile .menu .sub-menu > li {
    padding: 5px 25px;
}

#nav-mobile .menu .sub-menu > li > a {
    color: var(--color-purple);
    display: block;
    line-height: 1.4;
    font-size: 1rem;
    font-weight: 600;
}

#nav-mobile .menu .sub-menu a:hover {
    color: var(--color-purple);
    text-decoration: underline;
}

#nav-mobile .menu .menu-item-has-children.show-sub-menu .sub-menu {
    background-color: var(--color-white);
    display: block;
    list-style: none;
    padding: 0;
    border-radius: 0 0 8px 8px;
}

#nav-mobile .sub-menu > li:last-child {
    padding-bottom: 28px;
}

#header.menu-open {
    height: 100vh;
    overflow-y: scroll;
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

#header.menu-open #nav-mobile {
    background-color: var(--color-purple);
    display: block;
    position: absolute;
    top: var(--header-height);
    z-index: 2;
    width: 100%;
    left: 0;
}

#header.menu-open #nav-mobile .menu {
    display: block;
}

#nav-mobile .menu {
    list-style: none;
    margin: 0;
    padding: 0 0 100px; /* required for iOS scroll */
}

#nav-mobile .menu > li {
    margin: 0 var(--gutter) var(--v-space-25);
}

#header.menu-open #nav-mobile .menu li a {
    background-color: white;
    color: var(--color-purple);
    display: block;
    text-decoration: none;
    font-size: 17px;
}

#header.menu-open #nav-mobile .menu > li > a {
    margin: 0;
    padding: 0 25px;
    height: 64px;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--color-black);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

#nav-mobile .fundraise-up-donate {
    text-align: center;
}

/*! ----- NAV - DESKTOP ----- */

#nav-desktop {
    display: flex;
    margin: 0 var(--gutter-50) 0 0;
}

#nav-desktop .menu {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-basis: auto;
}

#nav-desktop .menu > li {
    margin: 0 var(--gutter) var(--v-space-25);
}

#nav-desktop .menu > li > a {
    color: var(--color-white);
    font-weight: 700;
    text-decoration: none;
    margin: 0;
    padding: 5px;
    display: block;
}

#nav-desktop .menu .sub-menu {
    display: none;
    padding: 0 0 var(--gutter);
    margin: -10px 0 0 0;
}

#nav-desktop .menu .sub-menu > li {
    padding: 8px 25px;
}

#nav-desktop .menu .sub-menu > li > a {
    color: var(--color-purple);
    display: block;
    line-height: 1.4;
    font-size: 1rem;
    font-weight: 600;
}

#nav-desktop .menu .sub-menu a:hover {
    color: var(--color-purple);
    text-decoration: underline;
}

#nav-desktop .menu > li.menu-item-has-children {
    position: relative;
}

#nav-desktop .menu .menu-item-has-children.show-sub-menu .sub-menu {
    background-color: var(--color-white);
    border-radius: 8px;
    box-shadow: var(--shadow-dark);
    top: 50px;
    left: 50%;
    right: 0;
    transform: translateX(-50%);
    margin: 0 auto;
    padding: 0;
    position: absolute;
    width: 240px;
    min-width: 240px;
    display: block;
    list-style: none;
}

#nav-desktop .menu .sub-menu > li:first-child {
    padding-top: 28px;
}

#nav-desktop .sub-menu > li:last-child {
    padding-bottom: 28px;
}

#nav-desktop .menu .sub-menu > li:first-child::before {
    content: "";
    position: absolute;
    width: 0;
    height: 0;
    border-bottom: 8px solid var(--color-white);
    border-left: 4px solid transparent;
    border-right: 4px solid transparent;
    left: 0;
    right: 0;
    margin-left: auto;
    margin-right: auto;
    top: -7px;
}

#nav-desktop .menu > li {
    margin: 0;
}

#nav-desktop .menu > li > a {
    margin: 10px;
    padding: 5px;
}

/*! ----- META / FIELDS ----- */

.meta {
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--color-gray);
}

/*! ----- PAGINATION ----- */

main .wpgb-facet .wpgb-pagination li a,
main .wpgb-facet .wpgb-pagination li a:hover {
    font-weight: 600 !important;
}

main .wpgb-facet .wpgb-pagination li a[aria-current] {
    color: var(--color-black);
}

.pagination,
.wp-block-query-pagination {
    margin: var(--gutter);
    justify-content: center;
    display: flex;
}

.pagination > *,
.wp-block-query-pagination-numbers > * {
    padding: 0.5em;
}

/*! ----- COVER ----- */

.wp-block-cover {
    padding: 0;
}

.wp-block-cover + *:not([class^="wp-block-"]) {
    padding-top: var(--v-space) !important;
}

.wp-block-cover .wp-block-cover__inner-container {
    color: var(--color-black);
    margin-left: auto !important;
    margin-right: auto !important;
    max-width: var(--content-width);
    padding: var(--v-space) var(--gutter);
    width: 100% !important;
}

.wp-block-cover.has-black-background-color .wp-block-cover__inner-container {
    color: var(--color-white);
}

.wp-block-cover.is-position-center-left .wp-block-cover__inner-container,
.wp-block-cover.is-position-top-left .wp-block-cover__inner-container {
    max-width: calc(var(--content-width-wide) + var(--gutter-200));
}

.wp-block-cover .wp-block-cover__inner-container > * {
    margin-left: auto;
    margin-right: auto;
}

.wp-block-cover .wp-block-cover__inner-container > h1 {
    margin-top: 0;
}

.home .wp-block-cover .wp-block-cover__inner-container > h1 {
    max-width: 800px;
    text-shadow: 0 0 8px var(--color-black);
}

.wp-block-cover.is-position-center-left .wp-block-cover__inner-container > h1,
.wp-block-cover.is-position-top-left .wp-block-cover__inner-container > h1 {
    text-align: left;
    margin-left: 0;
}

.wp-block-cover > .wp-block-cover__inner-container > :last-child {
    margin-bottom: 0;
}

.wp-block-cover h1 {
    font-size: 2.1rem;
}

@media (min-width: 769px) {
    .wp-block-cover .wp-block-cover__inner-container {
        /*padding-top: var(--header-height);*/
        padding-bottom: var(--v-space); /* Height of merged header */
    }
    .wp-block-cover.has-black-background-color
        .wp-block-cover__inner-container {
        padding-top: calc(var(--header-height) + var(--v-space));
        padding-bottom: calc(var(--header-height) + var(--v-space));
    }
}

/*! ----- TYPOGRAPHY  ----- */

html,
button,
input,
select,
textarea {
    color: var(--color-black);
    font-family: "Montserrat", sans-serif;
    font-weight: 400;
    text-transform: none;
    font-size: var(--font-size);
    line-height: 1.7;
}

h1,
h2,
h3,
h4,
h5 {
    color: var(--color-purple);
    font-weight: normal;
    line-height: 1.3;
    margin-top: var(--v-space-75);
    margin-bottom: var(--v-space-25);
}

.has-purple-background-color h1,
.has-purple-background-color h2,
.has-purple-background-color h3,
.has-purple-background-color h4,
.has-purple-background-color h5,
.has-purple-background-color p {
    color: var(--color-white);
}

h1:first-child,
h2:first-child,
h3:first-child,
h4:first-child,
h5:first-child {
    margin-top: 0;
}

h1 {
    font-size: calc(2rem * var(--h1-multiplier));
    font-weight: 700;
    letter-spacing: -0.1rem;
}

h2 {
    font-size: calc(1.5rem * var(--h2-multiplier));
}

h3 {
    color: var(--color-purple);
    font-size: calc(1.5rem * var(--h3-multiplier));
    font-weight: 700;
    letter-spacing: -0.1rem;
}

h4 {
    font-size: calc(1.25rem * var(--h4-multiplier));
    font-weight: 700;
    margin-top: var(--v-space-50);
    margin-bottom: var(--v-space-25);
}

h5 {
    font-size: 1.25rem;
    margin-top: var(--v-space-50);
    margin-bottom: var(--v-space-25);
}

p {
    margin: 0 0 var(--v-space-25);
}

p > strong {
    font-weight: 600;
}

/*! ----- LINKS ----- */

a,
a:visited,
a:active {
    color: var(--color-purple);
    font-weight: 600;
    text-decoration: none;
}

a:hover {
    text-decoration: underline;
}

.has-purple-background-color p a {
    color: var(--color-white);
    text-decoration: underline;
}

/*! ----- BUTTONS & FILES ----- */

.wp-block-buttons,
.wp-block-file {
    display: flex;
    margin-top: 2.5rem;
    margin-bottom: 2.5rem;
    gap: 20px;
}

.wp-block-file .wp-block-file__button {
    display: inline-block;
    margin-left: 0;
    margin-right: 20px;
    margin-top: 10px;
}

.wp-block-buttons > .wp-block-button:first-child,
.wp-block-file .wp-block-file__button:first-child {
    margin-left: 0;
}
.wp-block-buttons > .wp-block-button:last-child {
    margin-right: 0;
    margin-bottom: 0;
}

.wp-block-button__link,
button:not(.components-button),
.wp-block-file .wp-block-file__button,
.gform-button,
.gform_button,
.search-submit {
    color: var(--color-white);
    cursor: pointer;
    background-color: var(--color-purple);
    border: none;
    border-radius: 4px !important;
    font-size: 18px;
    font-weight: 700;
    line-height: 30px;
    padding: 10px 34px;
    transition: all var(--duration) ease;
}

.wp-block-button__link:active,
.wp-block-button__link:focus,
.wp-block-button__link:visited,
.wp-block-file .wp-block-file__button:visited {
    color: var(--color-gold);
}

.wp-block-button__link:hover,
button:hover,
.wp-block-file .wp-block-file__button:hover,
.gform_button:hover,
.gform-button:hover,
.search-submit:hover {
    color: var(--color-white);
    text-decoration: none;
    transform: scale(var(--enlarge-2));
}

.wp-block-button__link.has-purple-color:hover,
button.has-purple-color:hover {
    color: var(--color-black) !important;
}

.is-style-outline > .wp-block-button__link {
    padding: 8px 32px;
}

.is-style-outline > .wp-block-button__link:not(.has-text-color) {
    color: var(--color-purple);
}

.wp-block-file a:first-child::after {
    content: "\A";
    white-space: pre;
}

.wp-block-file:not(.wp-element-button) {
    font-size: 1em;
}

/*! ----- DOWNLOADS BLOCK ----- */

.wp-block-downloads {
    margin: 75px 0 40px;
}

/*! ----- FORMS ----- */

form {
    margin-top: 0;
    margin-bottom: var(--v-space-50);
}

form.align-center {
    justify-content: center;
}

form input {
    border: 1px solid var(--color-purple);
    flex: 1;
    padding: 8px 32px;
    max-width: 400px;
}

@media (max-width: 599px) {
    form {
        flex-direction: column;
    }

    form > * {
        margin: 0 0 var(--v-space-50);
    }

    form > :last-child {
        margin-bottom: 0;
    }
}

/*! ----- NEWSLETTER FORM ----- */

.newsletter {
    margin: 40px 0;
}

.newsletter .gform_body {
    width: 100%;
    margin: 0 auto;
}

.newsletter .gform_footer {
    display: none !important;
}

.newsletter input[type="text"],
.newsletter input[type="email"] {
    font-size: 18px !important;
    padding: var(--form-input-padding) !important;
    height: 50px;
}

.gform_ajax_spinner {
    margin-left: 15px;
}

.gform_confirmation_message {
    text-align: center;
    background-color: #f0fdf4;
    color: #166534;
    font-weight: 500;
    padding: 20px;
}

/*! ----- FACETS ----- */

.wpgb-facet {
    margin: var(--gutter-75) 0;
}

.wpgb-facet .wpgb-checkbox-facet .wpgb-checkbox .wpgb-checkbox-control {
    background-color: var(--color-white);
}

/*.wpgb-facet .wpgb-input, .wpgb-facet .wpgb-select, .wpgb-facet .wpgb-button:not(button), .wpgb-facet .wpgb-radio .wpgb-radio-control, .wpgb-facet .wpgb-checkbox .wpgb-checkbox-control, .wpgb-facet .wpgb-checkbox .wpgb-checkbox-control::before {
  border-color: var(--color-gray) !important;
}

.wpgb-facet .wpgb-input:hover, .wpgb-facet .wpgb-select:hover, .wpgb-facet .wpgb-button:hover:not(button):not([aria-pressed="true"]):not([tabindex="-1"]), .wpgb-facet .wpgb-radio:hover:not([tabindex="-1"]) .wpgb-radio-control, .wpgb-facet .wpgb-checkbox:hover:not([tabindex="-1"]) .wpgb-checkbox-control {
  border-color: var(--color-purple) !important;
}*/

/*! ----- QUOTES ----- */

.wp-block-quote {
    color: var(--color-purple);
    margin: 3.25rem 0 2rem;
    text-align: center;
}

.wp-block-quote p {
    font-family: adobe-handwriting-frank;
    font-weight: 700;
    font-size: 2.25rem;
    line-height: 1.2;
}

.wp-block-quote cite {
    font-size: 1.25rem;
    font-style: normal;
}

/*! ----- COLUMNS ----- */

.wp-block-columns {
    gap: var(--gutter);
    margin-bottom: 0;
}

.wp-block-columns .wp-block-media-text {
    margin-bottom: var(--gutter);
}

.wp-block-columns.equal-heights .wp-block-media-text {
    min-height: 330px;
}

@media (max-width: 1024px) {
    .wp-block-columns.stack-tablet {
        display: block;
    }
    .wp-block-columns.stack-tablet .wp-block-column {
        flex-basis: 100% !important;
        margin-left: 0 !important;
    }
}

@media (min-width: 600px) {
    .wp-block-columns
        > .wp-block-column
        > :not(.wp-block-media-text):last-child {
        margin-bottom: 0; /* may cause an issue when columns within text */
    }
}

@media (max-width: 781px) {
    .wp-block-column.mobile-width-100 {
        flex-basis: 100% !important;
        margin-left: 0;
    }
}

/*! ----- LISTS ----- */

.list,
.grid {
    gap: var(--gutter);
    outline: none;
    margin: 0 0 var(--gutter);
}

.gap-75 {
    gap: var(--gutter-75);
}

.list {
    display: flex;
    flex-direction: column;
    margin: 0 0 var(--gutter);
}

.grid {
    display: grid;
    grid-auto-rows: 1fr;
}

.col-2 {
    grid-template-columns: repeat(2, 1fr);
}
.col-3 {
    grid-template-columns: repeat(3, 1fr);
}
.col-4 {
    grid-template-columns: repeat(4, 1fr);
}
.col-5 {
    grid-template-columns: repeat(5, 1fr);
}

@media (min-width: 415px) {
    .col-2-sm {
        grid-template-columns: repeat(2, 1fr);
    }
    .col-3-sm {
        grid-template-columns: repeat(3, 1fr);
    }
    .col-4-sm {
        grid-template-columns: repeat(4, 1fr);
    }
    .col-5-sm {
        grid-template-columns: repeat(5, 1fr);
    }
}

@media (min-width: 768px) {
    .col-2-md {
        grid-template-columns: repeat(2, 1fr);
    }
    .col-3-md {
        grid-template-columns: repeat(3, 1fr);
    }
    .col-4-md {
        grid-template-columns: repeat(4, 1fr);
    }
    .col-5-md {
        grid-template-columns: repeat(5, 1fr);
    }
}

@media (min-width: 1024px) {
    .col-2-lg {
        grid-template-columns: repeat(2, 1fr);
    }
    .col-3-lg {
        grid-template-columns: repeat(3, 1fr);
    }
    .col-4-lg {
        grid-template-columns: repeat(4, 1fr);
    }
    .col-5-lg {
        grid-template-columns: repeat(5, 1fr);
    }
}

@media (min-width: 1280px) {
    .col-2-xl {
        grid-template-columns: repeat(2, 1fr);
    }
    .col-3-xl {
        grid-template-columns: repeat(3, 1fr);
    }
    .col-4-xl {
        grid-template-columns: repeat(4, 1fr);
    }
    .col-5-xl {
        grid-template-columns: repeat(5, 1fr);
    }
}

.card.item {
    display: flex;
    flex-direction: column;
    background: white;
}

.card {
    position: relative;
    transition: all var(--duration) ease;
    box-shadow: var(--shadow-light);
}

.card:hover {
    transform: scale(var(--enlarge-1));
    box-shadow: var(--shadow-dark);
}

.card.polaroid:hover {
    transform: scale(var(--enlarge-2));
}

.card.item img {
    aspect-ratio: 3 / 2;
    object-fit: cover;
    flex: 1 1 100%;
    width: 100%;
}

.card.item.has-logo-image img {
    object-fit: contain;
    padding: var(--gutter-50) 0 var(--gutter-50) var(--gutter-75);
}

.card.item .content {
    display: flex;
    flex-direction: column;
    flex: 1 1 100%;
    padding: var(--gutter-75) var(--gutter-75);
    gap: var(--gutter-50);
}

.card.item .content > * {
    margin-top: 0;
    margin-bottom: 0;
}

.card a {
    display: block;
}

.card a:hover {
    text-decoration: none;
}

.card a::before {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.card .meta,
.card .excerpt,
.card p {
    font-size: 0.95rem;
    line-height: 1.45;
}

.card .excerpt p:last-child {
    margin-bottom: 0;
}

@media (max-width: 414px) {
    .card.item img {
        max-height: 200px;
    }
}

@media (min-width: 415px) {
    .card.item {
        flex-direction: row;
    }
    .card.item img {
        aspect-ratio: 1 / 1;
        flex: 0 0 25%;
        width: 25%;
        min-width: 200px;
    }

    .card.item .content {
        flex: 1 1 75%;
    }
}

@media (min-width: 1200px) {
    .grid .card.item img {
        aspect-ratio: 1 / 1;
        flex: 0 0 33%;
        width: 33%;
    }

    .grid .card.item .content {
        flex: 1 1 67%;
    }
}

/*! ----- MEDIA & TEXT BLOCK ----- */

.wp-block-media-text .wp-block-media-text__content {
    line-height: 1.3;
    padding: var(--gutter);
}

.wp-block-media-text.alignfull .wp-block-media-text__content {
    padding: calc(var(--gutter) * 2) var(--gutter);
}

.wp-block-media-text.is-image-fill .wp-block-media-text__media {
    min-height: 197px;
}

.wp-block-media-text.alignfull.is-image-fill .wp-block-media-text__media {
    min-height: 550px;
}

.image-has-margin > figure {
    margin: 4.5em !important;
}

.wp-block-media-text.has-logo-image .wp-block-media-text__media {
    background-size: contain;
    background-repeat: no-repeat;
    background-color: var(--color-white);
    border: var(--gutter) solid var(--color-white);
}

/*! ----- SEPARATOR BLOCK ----- */

.wp-block-separator {
    margin-top: 50px;
    margin-bottom: 50px;
    width: 100px;
    color: var(--color-gold);
}

/*! ----- GALLERY BLOCK ----- */

.wp-block-gallery .wp-block-image {
    flex-grow: 0 !important; /* stop last row with less items from bring over-sized */
}
.wp-block-gallery .wp-block-image img {
    aspect-ratio: 1 / 1;
}
.wp-block-gallery .wp-block-image figcaption {
    font-weight: 500;
    line-height: 1.3;
}
.wp-block-gallery.columns-6 .wp-block-image figcaption {
    font-size: 12px;
    padding: 4px;
}

/*! ----- GROUPS (SECTIONS) ----- */

.wp-block-group {
    padding: var(--v-space-50) 0;
}

.wp-block-group .wp-block-group {
    padding: 0;
}

main > .wp-block-group {
    padding: var(--v-space) var(--gutter);
}

.wp-block-group:not(.has-background) + .wp-block-group:not(.has-background) {
    padding-top: 0; /* If we have two adjacent sections with no background colour, reduce the padding so it doesn't look like a double gap */
}

.wp-block-group > .wp-block-group__inner-container {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: 0;
}

.wp-block-group.alignfull > .wp-block-group__inner-container {
    max-width: var(--content-width-wide);
}

.wp-block-group > .wp-block-group__inner-container > * {
    margin-left: auto;
    margin-right: auto;
}

.wp-block-group > .wp-block-group__inner-container > h2 {
    max-width: var(--content-width);
}

.wp-block-group > .wp-block-group__inner-container > :last-child {
    margin-bottom: 0;
}

/*! ----- IMAGES ----- */

.wp-block-image,
.gb-block-image {
    margin: 0 0 var(--v-space-25);
}

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

.polaroid,
.wp-block-image.is-style-polaroid figure,
figure.wp-block-image.is-style-polaroid {
    background-color: var(--color-white);
    box-shadow: var(--shadow-light);
    line-height: 1;
    margin-top: 0;
    margin-bottom: var(--v-space-50);
    padding: 5.5%;
}

.grid .polaroid,
.grid .wp-block-image.is-style-polaroid figure,
.grid figure.wp-block-image.is-style-polaroid {
    margin-bottom: 0;
}

.wp-block-image a:hover {
    border: none;
}

.polaroid h4,
.wp-block-image figcaption {
    color: var(--color-black);
    font-size: 18px;
    height: 43px;
    line-height: 1.2;
    margin-top: 5.5% !important;
    margin-bottom: 0 !important;
    /*overflow: hidden;*/
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
}

.wp-block-image figcaption p:last-child {
    margin-bottom: 0;
}

.has-purple-background-color .polaroid a {
    color: var(--color-black);
}

/*! ----- FEATURED POST BLOCK ----- */

.wp-block-featured-post {
    max-width: 350px !important;
    text-align: center;
}

.wp-block-featured-post.aligncenter {
    margin-left: auto;
    margin-right: auto;
}

/*! ----- VIDEOS ----- */

.wp-block-embed.is-type-video {
    margin-bottom: var(--v-space-50);
}

/*! ----- UTILITY ----- */

.no-margin-top {
    margin-top: 0;
}

.no-margin-bottom {
    margin-bottom: 0;
}

.long-text > a {
    font-size: 0.9em;
    line-height: 1.2em;
}

p.has-small-font-size {
    font-size: 15px !important;
}

img.aspect-ratio-square {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: contain;
    display: block;
}

/*! ----- HIDE & SHOW ----- */

.hide {
    display: none !important;
}

.show {
    display: unset !important;
}

@media (min-width: 415px) {
    .hide-xs {
        display: none !important;
    }
    .show-xs {
        display: unset !important;
    }
}

@media (min-width: 575px) {
    .hide-sm {
        display: none !important;
    }
    .show-sm {
        display: unset !important;
    }
}

@media (min-width: 768px) {
    .hide-md {
        display: none !important;
    }
    .show-md {
        display: unset !important;
    }
}

@media (min-width: 1024px) {
    .hide-lg {
        display: none !important;
    }
    .show-lg {
        display: unset !important;
    }
}

@media (min-width: 1280px) {
    .hide-xl {
        display: none !important;
    }
    .show-xl {
        display: unset !important;
    }
}

/*! ----- SLIDER ----- */

@media (max-width: 1485px) {
    .wp-swiper .swiper-button-next,
    .wp-swiper .swiper-button-prev {
        display: none !important;
    }
}

.wp-swiper {
    padding-bottom: 50px;
}

.wp-swiper .wp-swiper__slide-content {
    padding-left: 0px;
    padding-right: 0px;
}

@media (min-width: 768px) {
    .wp-swiper .wp-swiper__slide-content {
        padding-left: 10%;
        padding-right: 10%;
    }
}

.wp-swiper .swiper-button-next.swiper-button-disabled,
.wp-swiper .swiper-button-prev.swiper-button-disabled {
    opacity: 0.2;
}

.wp-swiper img {
    aspect-ratio: 3 / 2;
    object-fit: cover;
    margin-left: auto;
    margin-right: auto;
}

.wp-swiper h3.has-text-align-center,
.wp-swiper p.has-text-align-center {
    max-width: 525px;
    margin-left: auto;
    margin-right: auto;
}

/*! ----- FOOTER ----- */

#footer {
    background: var(--color-purple);
    color: var(--color-white);
    padding: var(--v-space) 0;
}

.footer__inner-container {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    max-width: var(--content-width-wide);
    padding: 0 var(--gutter);
}

.footer__inner-container > * {
    flex: 1;
}

#footer a {
    color: var(--color-white);
}

@media (max-width: 600px) {
    #footer {
        text-align: left;
    }
}

#footer-menu {
    margin: 0 0 20px;
    padding: 0;
    column-count: 2;
    column-gap: 20px;
}

#footer-menu > li {
    line-height: 1.4;
    list-style: none;
    margin-bottom: 15px;
    word-wrap: normal;
}

#copyright-menu {
    margin: 40px 0 0 0;
    padding: 0;
}

#copyright-menu > li {
    line-height: 1.4;
    list-style: none;
    font-size: 15px;
    margin-bottom: 10px;
}

.footer-logo {
    margin: 30px 0 0;
}

/*! ----- SCREEN READER ----- */

.screen-reader {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border-width: 0;
}

.show-focus:focus {
    position: static;
    width: auto;
    height: auto;
    padding: 0;
    margin: 0;
    overflow: visible;
    clip: auto;
    white-space: normal;
}

/*! ----- EDITOR ----- */

.acf-block-preview a {
    pointer-events: none;
}

/*! ----- STICKER ----- */

.sticker {
    position: absolute;
    top: 0;
    right: 0;
    color: var(--color-white);
    background-color: var(--color-purple);
    font-size: 13px;
    padding: 5px 10px;
}

/*! ----- SEARCH ICON ----- */

#search-icon {
    color: white;
    display: flex;
    align-items: center;
    font-size: 24px;
    padding: 0 0 0.1rem;
    display: none;
}

@media (min-width: 375px) {
    #search-icon {
        display: inline-flex;
    }
}

@media (min-width: 500px) {
    #search-icon {
        margin-right: var(--gutter-50);
    }
}

@media (min-width: 800px) {
    #search-icon {
        margin-right: var(--gutter);
    }
}

@media (min-width: 1280px) {
    #search-icon {
        font-size: 20px;
    }
}

/*! ----- SEARCH FORM ----- */

.search-form {
    display: flex;
    justify-content: center;
    gap: var(--gutter-50);
}

.search-field::placeholder {
    display: none;
}

.search-submit {
    cursor: pointer;
    flex-grow: 0;
}

/*! ----- POPUP MAKER ----- */

.pum-overlay {
    backdrop-filter: blur(3px);
}

.pum-theme-content-only .popmake-close {
    display: none !important;
}

html.pum-open-overlay .cb__aside {
    padding-right: 17px;
}

/*! ----- IMAGES (classic, used in popups) ----- */

img.alignleft {
    margin: 0 20px 20px 0;
}

@media (min-width: 400px) {
    img.alignleft {
        float: left;
    }
}

img.alignright {
    margin: 0 0 20px 20px;
}

@media (min-width: 400px) {
    img.alignright {
        float: right;
    }
}

img.aligncenter {
    margin: 0 auto;
    display: block;
}

/*! ----- CUSTOMIZER ----- */

.customize-partial-edit-shortcut-button {
    display: none !important;
}
