:root {

    --primary-bg:       #fff2e5;
    --primary-light:    #ffe6d2;
    --primary-mid:      #ffc29e;
    --primary:          #ee7b30;
    --primary-dark:     #ad510a;

    --secondary-bg:     #eeffff;
    --secondary-light:  #d4f4ff;
    --secondary-mid:    #a7daff;
    --secondary:        #0784c6;
    --secondary-dark:   #003c68;

    --accent-bg:        #effff4;
    --accent-light:     #d7fae0;
    --accent-mid:       #84d59c;
    --accent:           #048948;
    --accent-dark:      #0f6234;

    --neutral-bg:       #fafafa;
    --neutral-light:    #e3e3e3;
    --neutral-mid:      #a5a5a5;
    --neutral:          #525252;
    --neutral-dark:     #1a1a1a;

    --site-bg:          #f8f7f4;
    --white:            #fff;

    --theme: var(--primary);

    /* @link https://utopia.fyi/clamp/calculator?a=448,1344,3—4|6—8|12—16|16—20|20—24|28—32|36—48|42—64|48—96|64—128&p=space */
    /* 448px --> 1344px */
    --space-tiny: clamp(0.1875rem, 0.1563rem + 0.1116vw, 0.25rem);  /* 3-4px */
    --space-xs: clamp(0.375rem, 0.3125rem + 0.2232vw, 0.5rem);      /* 6-8px */
    --space-sm: clamp(0.75rem, 0.625rem + 0.4464vw, 1rem);          /* 12-16px */
    --space-base: clamp(1rem, 0.875rem + 0.4464vw, 1.25rem);        /* 16-20px */
    --space-md: clamp(1.25rem, 1.125rem + 0.4464vw, 1.5rem);        /* 20-24px */
    --space-lg: clamp(1.75rem, 1.625rem + 0.4464vw, 2rem);          /* 28-32px */
    --space-xl: clamp(2.25rem, 1.875rem + 1.3393vw, 3rem);          /* 36-48px */
    --space-xxl: clamp(2.625rem, 1.9375rem + 2.4554vw, 4rem);       /* 42-64px */
    --space-huge: clamp(3rem, 1.5rem + 5.3571vw, 6rem);             /* 48-96px */
    --space-mega: clamp(4rem, 2rem + 7.1429vw, 8rem);               /* 64-128px */

    /* @link https://utopia.fyi/clamp/calculator?a=448,1344,11—13|14—16|17—21|20—24|23—30|27—36|32—60&p=text */
    /* 448px --> 1344px */
    --text-xs: clamp(0.6875rem, 0.625rem + 0.2232vw, 0.8125rem);        /* 11-13px */
    --text-sm: clamp(0.875rem, 0.8125rem + 0.2232vw, 1rem);             /* 14-16px */
    --text-base: clamp(1.0625rem, 0.9375rem + 0.4464vw, 1.3125rem);     /* 17-21px */
    --text-md: clamp(1.25rem, 1.125rem + 0.4464vw, 1.5rem);             /* 20-24px */
    --text-lg: clamp(1.4375rem, 1.2188rem + 0.7813vw, 1.875rem);        /* 23-30px */
    --text-xl: clamp(1.6875rem, 1.4063rem + 1.0045vw, 2.25rem);         /* 27-36px */
    --text-xxl: clamp(2rem, 1.125rem + 3.125vw, 3.75rem);               /* 32-60px */

    --text-nav:    1.125rem; /* 18px */

    --font-weight-thin: 300;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    
    --max-narrow:   36rem; /* 576px */
    --max-content:  60rem; /* 960px */
    --max-wide:     90rem; /* 1440px */

    --shadow-sm: 0 var(--space-xs) var(--space-sm) rgba(0,0,0,0.06);
    --shadow-md: 0 var(--space-sm) var(--space-md) rgba(0,0,0,0.06);

    --radius-sm: var(--space-xs);
    --radius-base: var(--space-sm);
    --radius-md: var(--space-base);
    --radius-lg: var(--space-md);
    --radius-xl: var(--space-lg);

    --gutter: clamp(1rem, -1.5rem + 8.9286vw, 6rem); /* 16px->96px */


}

/*--------------------------------------------------------------------------- */
/* MARK: FONTS
*/

/* Plus Jakarta Sans Var */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/plus-jakarta-sans-var/plus-jakarta-sans-var.woff2') format('woff2-variations'),
            url('/assets/fonts/plus-jakarta-sans-var/plus-jakarta-sans-var.ttf') format('truetype-variations');
    font-weight: 200 800;
    font-display: swap;
}
/* Plus Jakarta Sans Var Italic */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/plus-jakarta-sans-var/plus-jakarta-sans-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/plus-jakarta-sans-var/plus-jakarta-sans-var-italic.ttf') format('truetype-variations');
    font-weight: 200 800;
    font-display: swap;
    font-style: italic; 
}
/* Nunito Var */
@font-face {
    font-family: 'font-secondary';
    src:    url('/assets/fonts/nunito-var/nunito-var.woff2') format('woff2-variations'),
            url('/assets/fonts/nunito-var/nunito-var.ttf') format('truetype-variations');
    font-weight: 200 1000;
    font-display: swap;
}
/* Nunito Var Italic */
@font-face {
    font-family: 'font-secondary';
    src:    url('/assets/fonts/nunito-var/nunito-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/nunito-var/nunito-var-italic.ttf') format('truetype-variations');
    font-weight: 200 1000;
    font-display: swap;
    font-style: italic; 
}

/* Caveat Var */
@font-face {
    font-family: 'font-script';
    src:    url('/assets/fonts/caveat-var/caveat-var.woff2') format('woff2-variations'),
            url('/assets/fonts/caveat-var/caveat-var.ttf') format('truetype-variations');
    font-weight: 400 700;
    font-display: swap;
        
}
.font-script { font-family: 'font-script', sans-serif; font-style: normal; }
.font-script-400 { font-family: 'font-script', sans-serif; font-style: normal; font-weight: 400; }
.font-script-500 { font-family: 'font-script', sans-serif; font-style: normal; font-weight: 500; }
.font-script-600 { font-family: 'font-script', sans-serif; font-style: normal; font-weight: 600; }
.font-script-700 { font-family: 'font-script', sans-serif; font-style: normal; font-weight: 700; }



/*--------------------------------------------------------------------------- */
/* MARK: RESET
*/

/* heavily based on https://www.joshwcomeau.com/css/custom-css-reset/ */
*, *::before, *::after {
    box-sizing: border-box;
}
* {
    margin: 0;
}
*:focus {
    outline: 3px solid #0000ee;
    outline-offset: 2px;
}
@media (prefers-reduced-motion: no-preference) {
    html {
        interpolate-size: allow-keywords;
        scroll-behavior: smooth;
    }
}
img, picture, video, canvas, svg {
    display: block;
    max-width: 100%;
}
input, button, textarea, select {
    font: inherit;
}
p, h1, h2, h3, h4, h5, h6 {
    overflow-wrap: break-word;
}
h1, h2, h3, h4, h5, h6 {
    text-wrap: balance;
}
p {
    text-wrap: pretty;
}
strong {
    font-weight: var(--font-weight-bold);
}

/*--------------------------------------------------------------------------- */
/* MARK: HTML/BODY
*/

html {
    background-color: var(--site-bg);
    padding: 0;
}

body {
    /* don't set background-color here, apply to html https://css-tricks.com/html-vs-body-in-css/#aa-quirky-background-color */
    color: var(--neutral);
    font-family: 'font-primary', system-ui, sans-serif;
    font-size: var(--text-base);
    font-weight: var(--font-weight-regular);
    line-height: 1.5;
    -webkit-font-smoothing: antialiased;
}

/*--------------------------------------------------------------------------- */
/* MARK: Site HEADER
*/

.site-header {
    background-color: var(--theme);
    display: grid;
    gap: var(--space-xs);
    padding: 0 var(--space-sm);
}

.site-header > .courtesy {
    display: grid;
    gap: var(--space-xs) var(--space-base);
    grid-template-columns: auto auto;
    grid-template-areas: 
    "hours toggle"
    "search search";
    line-height: 1;
    width: 100%;
}

.site-header > .courtesy > .info {
    align-self: center;
    color: var(--white);
    font-size: var(--text-sm);
    font-weight: var(--font-weight-semibold);
    grid-area: hours;
    line-height: 1;
    justify-items: start;
    padding-top: calc(0.5 * var(--space-xs));
    width: 100%;

}

.site-header .lang-toggle {
    align-self: flex-start;
    border-radius: 0 0 var(--radius-sm) var(--radius-sm);
    grid-area: toggle;
    margin-left: auto;
    overflow: hidden;
    width: max-content;
}
.site-header .search {
    grid-area: search;
}

.site-header .search-form {
    font-size: 1rem;
    gap: 0;
    margin-left: auto;
    height: 100%;
    width: 100%;
}
.site-header .search-form input[type="search"] {
    background-color: var(--site-bg);
    border-radius: var(--radius-sm) 0 0 var(--radius-sm);
    border: 0;
    padding: var(--space-tiny) var(--space-xs);
}
.site-header .search-form .btn {
    background-color: var(--neutral);
    border-color: var(--neutral);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    color: var(--white);
    font-size: var(--text-sm);
    padding: 0 var(--space-xs);
}

.site-header > .inner {
    background-color: white;
    border-radius: var(--radius-base);
    align-items: center;
    display: flex;
    justify-content: space-between;
    gap: var(--space-base);
    padding: var(--space-sm);
}

.site-header .logo {
    align-items: center;
    display: block;
    text-decoration: none;
}
.site-header .logo svg {
    height: calc(1.5 * var(--space-huge));
    max-height: 6rem;
    width: auto;
}

/* navigation starts here */

.site-nav {
    display: none; /* for mobile */
    z-index: 5;
}

.mobile-nav-toggle {
    background: transparent;
    border: 2px solid var(--neutral-light);
    border-radius: var(--radius-sm);
    color: var(--neutral);
    cursor: pointer;
    display: block; /* for mobile */
    height: calc( 1.33 * var(--space-huge) );
    padding: var(--text-xs);
    width: calc( 1.33 * var(--space-huge) );
}
.mobile-nav-icon {
    aspect-ratio: 1/1;
    width: 100%;
    height: 100%;
}

/* the parent menu and primary nav items */
.site-nav > .menu {
    display: flex;
    flex-wrap: nowrap;
    font-size: var(--text-nav);
    gap: var(--space-sm) 0;
    justify-content: center;
    line-height: 1.2;
    list-style: none;
    height: 100%;
    padding: 0;
}
.site-nav > .menu.omega-btn > li:last-of-type {
    background-color: var(--primary);
    color: var(--white);
}
.site-nav > .menu > li {
    border-right: 2px solid var(--neutral-light);
    display: flex;
}
.site-nav > .menu > li:last-of-type {
    border-right: 0;
}
.site-nav > .menu > li.has-submenu {
    position: relative;
}
.site-nav > .menu > li > a {
    align-items: center;
    justify-content: center;
    color: var(--neutral);
    display: flex;
    font-weight: var(--font-weight-semibold);
    padding: var(--space-sm) var(--space-xs);
    text-decoration: none;
    max-width: min-content;
    min-width: 8.5rem;
    text-align: center;
}

.site-nav > .menu > li > a:hover {
}

/* the drop-down menu and kids */
.site-nav .submenu {
    background-color: var(--white);
    border: var(--space-tiny) solid var(--neutral);
    border-radius: var(--radius-md);
    display: none;
    left: 50%;
    list-style: none;
    margin-left: calc(-0.5 * 18rem);
    padding: var(--space-sm);
    position: absolute;
    text-align: center;
    top: calc(100% + var(--space-xs));
    width: 18rem;
    z-index: 5;
}
.site-nav .submenu:before {
    border-bottom: 1rem solid var(--neutral);
    border-left: 1rem solid transparent;
    border-right: 1rem solid transparent;
    content: '';
    pointer-events: none;
    position: absolute;
    top: -1.1rem;
    left: 50%;
    margin-left: -1rem;
}

.site-nav .submenu a {
    border-radius: var(--radius-sm);
    color: var(--neutral);
    display: block;
    font-weight: var(--font-weight-bold);
    padding: var(--space-sm) 0;
    position: relative;
    text-decoration: none;
    z-index: 2;
}

.site-nav .submenu a:hover {
    background-color: var(--primary-light);
}
.site-nav .submenu :last-child a {
    border: 0;
}

/*--------------------------------------------------------------------------- */
/* MARK: Page Title
*/

.page-title {
    background-color: var(--theme);
    color: var(--white);
    display: grid;
    gap: var(--space-huge);
    padding: var(--space-huge) var(--gutter);
    text-align: center;
}
.page-title h1 {
    line-height: 1.1;
}
.page-title > .copy {
    display: grid;
    gap: var(--space-sm);
    max-width: var(--max-content);
    margin-inline: auto;
    position: relative;
    width: 100%;
}
.page-title > .copy a {
    color: inherit;
}

.page-title .kicker {
    font-size: var(--text-xl);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}
.page-title .kicker a {
    text-decoration: none;
}

.page-title > .copy .lede {
    margin-inline: auto;
    max-width: 36ch;
    width: 100%;
}

.page-image {
    position: relative;
    display: grid;
    grid-template-areas: "stack";
}

.page-image > * {
    grid-area: stack;
    margin-inline: auto;
    width: 100%;
}

.page-image > svg {
    fill: var(--theme);
    height: calc(100% + 4px);
    width: 100%;
    position: absolute;
    inset: 0;
}

.page-img {
    aspect-ratio: 1;
    height: auto;
    margin-block: auto;
    object-fit: cover;
    width: 96%;
}

.fade-in {
	animation: fade-in 1.2s cubic-bezier(0.390, 0.575, 0.565, 1.000) 0.2s both;
}
@-webkit-keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fade-in {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}


.page-icon {
    position: absolute;
    height: calc(2 * var(--space-huge));
    width: calc(2 * var(--space-huge));
    top: calc(-0.75 * var(--space-huge));
    left: 50%;
    margin-left: calc(-1 * var(--space-huge));
}

.wobble-hor-bottom {
	-webkit-animation: wobble-hor-bottom 0.8s both;
	        animation: wobble-hor-bottom 0.8s both;
}
.scale-in-center {
	-webkit-animation: scale-in-center 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
	        animation: scale-in-center 0.5s cubic-bezier(0.250, 0.460, 0.450, 0.940) both;
}
@-webkit-keyframes scale-in-center {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}
@keyframes scale-in-center {
  0% {
    -webkit-transform: scale(0);
            transform: scale(0);
    opacity: 1;
  }
  100% {
    -webkit-transform: scale(1);
            transform: scale(1);
    opacity: 1;
  }
}

@-webkit-keyframes wobble-hor-bottom {
  0%,
  100% {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
  }
  15% {
    -webkit-transform: translateX(-30px) rotate(-6deg);
            transform: translateX(-30px) rotate(-6deg);
  }
  30% {
    -webkit-transform: translateX(15px) rotate(6deg);
            transform: translateX(15px) rotate(6deg);
  }
  45% {
    -webkit-transform: translateX(-15px) rotate(-3.6deg);
            transform: translateX(-15px) rotate(-3.6deg);
  }
  60% {
    -webkit-transform: translateX(9px) rotate(2.4deg);
            transform: translateX(9px) rotate(2.4deg);
  }
  75% {
    -webkit-transform: translateX(-6px) rotate(-1.2deg);
            transform: translateX(-6px) rotate(-1.2deg);
  }
}
@keyframes wobble-hor-bottom {
  0%,
  100% {
    -webkit-transform: translateX(0%);
            transform: translateX(0%);
    -webkit-transform-origin: 50% 50%;
            transform-origin: 50% 50%;
  }
  15% {
    -webkit-transform: translateX(-30px) rotate(-6deg);
            transform: translateX(-30px) rotate(-6deg);
  }
  30% {
    -webkit-transform: translateX(15px) rotate(6deg);
            transform: translateX(15px) rotate(6deg);
  }
  45% {
    -webkit-transform: translateX(-15px) rotate(-3.6deg);
            transform: translateX(-15px) rotate(-3.6deg);
  }
  60% {
    -webkit-transform: translateX(9px) rotate(2.4deg);
            transform: translateX(9px) rotate(2.4deg);
  }
  75% {
    -webkit-transform: translateX(-6px) rotate(-1.2deg);
            transform: translateX(-6px) rotate(-1.2deg);
  }
}


.page-icon svg {
    aspect-ratio: 1;
    height: auto;
    margin-inline: auto;
    width: 100%;
}

.page-icon svg path {
    fill: var(--white);
    opacity: 0.9;
}





/*--------------------------------------------------------------------------- */
/* MARK: Site MAIN
*/

main {
    display: flex;
    flex-direction: column;
}
main > * {
    margin-block: 0;
}

/*--------------------------------------------------------------------------- */
/* MARK: Funding Funded By
*/


.funded-by > svg {
    fill: currentColor;
    margin-inline: auto;
    max-width: 28rem;
    width: 100%;
}

/*--------------------------------------------------------------------------- */
/* MARK: Site FOOTER
*/

.site-footer {
    --footerBg: var(--secondary-dark);
    background-color: var(--footerBg);
    color: white;
    font-size: var(--text-sm);
    padding: var(--space-xxl) var(--gutter) var(--space-base) var(--gutter);
}
.site-footer > .inner {
    align-items: start;
    display: grid;
    grid-template-areas:
        "logo"
        "contact"
        "nav1"
        "nav2"
        "nav3"
        "footer"
    ;
    gap: var(--space-xl) var(--space-base);
    margin-inline: auto;
    max-width: var(--max-wide);
    position: relative;
}

.site-footer::before {
    /* Wave top; nice idea, not yet */
    display: none;
    content: '';
    background-color: var(--footerBg);
    position: absolute;
    left: -15vw; right: -15vw;
    bottom: calc(100% - 2vw);
    height: var(--space-xxl);
    pointer-events: none;
    border-radius: 50%;
}

/* all div/nav children */
.site-footer > .inner > div,
.site-footer > .inner > nav {
    display: grid;
    gap: var(--space-sm);
    height: 100%;
    position: relative;
}

/* footer buttons */
.site-footer .btn:hover {
    color: var(--white);

}

/* contact column */
.site-footer .contact-col {
    align-content: center;
    background-color: var(--secondary);
    border-radius: var(--radius-lg);
    border: 0;
    display: grid;
    font-size: var(--text-base);
    font-weight: var(--font-weight-semibold);
    grid-area: contact;
    padding: var(--space-base);
    text-align: center;

}   
.site-footer .contact-col .heading {
    color: var(--secondary-dark);
    font-size: var(--text-md);
}
.site-footer .contact-col .btn {
    --borderAndBackground: var(--secondary-dark);
    font-size: var(--text-sm);
    margin-inline: auto;
    margin-top: var(--space-xs);
}
.site-footer .contact-col .btn:hover {
    border-color: var(--secondary-dark);
}
.site-footer .lang-toggle {
    border-radius: var(--radius-sm);
    justify-content: center;
    max-width: max-content;
    margin-inline: auto;
}

/* logo column */
.site-footer .logo-col {
    background-color: rgba(0, 0, 0, 0.15);
    border-radius: var(--radius-lg);
    align-content: center;
    grid-area: logo;
    padding: var(--space-xl) 0;
}
.site-footer .logo {
    display: block;
    max-width: 20rem;
    margin-inline: auto;
    width: 67%;
}

/* footer/copyright column */
.site-footer > .inner > .footer-col {
    align-items: center;
    border-top: var(--space-tiny) solid var(--primary);
    display: flex;
    flex-direction: column;
    font-size: var(--text-xs);
    gap: var(--space-base);
    grid-area: footer;
    justify-content: space-between;
    padding-top: var(--space-base);
    text-align: center;
    width: 100%;
}
.site-footer > .inner > .footer-col > :nth-child(1) {
    border-bottom: var(--space-tiny) solid var(--accent);
    padding-bottom: var(--space-base);
    width: 100%;
}

/* the 3 navigation columns */
.site-footer > .inner > .nav-col {
    align-items: start;
    align-content: start;
    border-left: var(--space-tiny) solid var(--secondary);
    padding-left: var(--space-sm);
}
.site-footer .nav-col:nth-of-type(1) {
    grid-area: nav1;
}
.site-footer .nav-col:nth-of-type(2) {
    grid-area: nav2;
}
.site-footer .nav-col:nth-of-type(3) {
    grid-area: nav3;
}

.site-footer a {
    color: inherit;
    text-decoration-color: rgba(255, 255, 255, 0.2);
    text-decoration-thickness: 0.05em;
    text-underline-offset: 0.35em;
}
.site-footer a:hover {
    text-decoration-color: var(--white);
}
.site-footer h2,
.site-footer h3 {
    font-size: var(--text-base);
    color: var(--secondary-mid);
}
.site-footer ul {
    display: inherit;
    gap: var(--space-xs);
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer .social-links {
    justify-content: center;
}
.site-footer .social-links svg {
    height: var(--space-lg);
    width: var(--space-lg);
}

/*--------------------------------------------------------------------------- */
/* MARK: ROWS
*/

.row {
    --bg: transparent;
    --row-block-padding-default:    calc(var(--space-xxl) * 1);
    --row-block-padding-less:       calc(var(--row-block-padding-default) * 0.5);
    --row-block-padding-more:       calc(var(--row-block-padding-default) * 1.5);
    --row-block-padding-huge:       calc(var(--row-block-padding-default) * 2);
    background-color: var(--bg);
    padding: var(--row-block-padding-default) var(--gutter);
    position: relative;
}

.row:nth-child(even) {
    background-color: var(--white);
}

.row.top-pad-none       { padding-top:      0; }
.row.bot-pad-none       { padding-bottom:   0; }
.row.top-pad-less       { padding-top:      var(--row-block-padding-less); }
.row.bot-pad-less       { padding-bottom:   var(--row-block-padding-less); }      
.row.top-pad-more       { padding-top:      var(--row-block-padding-more); }    
.row.bot-pad-more       { padding-bottom:   var(--row-block-padding-more); }
.row.top-pad-huge       { padding-top:      var(--row-block-padding-huge); }    
.row.bot-pad-huge       { padding-bottom:   var(--row-block-padding-huge); }

.row.has-bg-image {
    color: white;
}
.row.has-bg-image a {
    color: inherit;
}
.row > * {
    margin-block: 0;
}

.row-bg-image {
    filter: opacity(1) brightness(0.25) contrast(0.9) saturate(1.2);
    height: 100%;
    left: 0; top: 0; bottom: 0; right: 0;
    object-fit: cover;
    position: absolute;
    width: 100%;
}

/*--------------------------------------------------------------------------- */
/* MARK: COLUMNS
*/

.columns {
    display: grid;
    gap: var(--space-lg);
    margin-inline: auto;
}
.columns .column {
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    position: relative;
    z-index: 2;
    container-type: inline-size;
}
.columns .column > * {
    margin-block: 0;
    max-width: 100%;
}

.columns .column > div {
    margin-block: var(--space-sm);
}

.columns .column > :first-child {
    margin-top: 0;
}
.columns .column > :last-child {
    margin-bottom: 0;
}


/*--------------------------------------------------------------------------- */
/* MARK: Auto-Grid
*/

.auto-grid {
    --max-column-width: 100% / var(--auto-grid-max-columns, infinity) - var(--auto-grid-gap);
    --column-width: max(var(--max-column-width), min(var(--auto-grid-min-size, 10rem), 100%));
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(var(--column-width), 1fr));
    gap: var(--auto-grid-gap-vertical, var(--auto-grid-gap, 1rem)) var(--auto-grid-gap, 1rem);

    /* defaults - override these as needed */
    --auto-grid-min-size: 16rem;
    --auto-grid-max-columns: 3;
    --auto-grid-gap: var(--space-md);
}


/*--------------------------------------------------------------------------- */
/* MARK: Headings
*/

h1 { font-size: var(--text-xxl); }
h2 { font-size: var(--text-xl); }
h3 { font-size: var(--text-lg); }
h4 { font-size: var(--text-md); }
h5 { font-size: var(--text-base); }
h6 { font-size: var(--text-sm); }

h1, h2, h3, h4, h5, h6 {
    font-family: 'font-secondary';
    font-weight: 900;
    line-height: 1.2;
}


/*--------------------------------------------------------------------------- */
/* MARK: Links
*/

a {
    color: var(--primary);
}

/*--------------------------------------------------------------------------- */
/* MARK: Paragraphs
*/

.lede {
    font-size: var(--text-md);
    font-weight: var(--font-weight-semibold);
}
.kicker {
    font-family: 'font-script';
    font-size: var(--text-lg);
    font-weight: var(--font-weight-bold);
}
.callout {
    background-color: var(--primary-light);
    border-left: var(--space-tiny) solid var(--primary);
    padding: var(--space-lg) var(--space-base);
}

/*--------------------------------------------------------------------------- */
/* MARK: Lists
*/

ol, ul {
    padding-left: var(--space-lg);
}

/*--------------------------------------------------------------------------- */
/* MARK: Figures/Images
*/

figure figcaption {
    font-size: var(--space-sm);
    font-weight: var(--font-weight-bold);
    padding-top: var(--space-xs);
    text-align: center;
}

img {
    height: auto;
}

/*--------------------------------------------------------------------------- */
/* MARK: HR
*/

hr {
    border: 0;
    padding: 0;
    height: var(--space-tiny);
    background-color: var(--neutral-light);
    width: 100%;
    display: block;
}

/*--------------------------------------------------------------------------- */
/* MARK: Blockquote
*/

blockquote footer {
    font-size: var(--text-sm);
    font-weight: var(--font-weight-bold);
}
blockquote footer::before {
    color: var(--accent);
    content: '— ';
}

/*--------------------------------------------------------------------------- */
/* MARK: Buttons
*/

.btns {
    display: flex;
    gap: var(--space-sm) var(--space-md);
    flex-wrap: wrap;
}

.btn {
    --borderAndBackground: var(--primary);
    --btnRadius: var(--radius-base);
    appearance: none;
    align-items: center;
    justify-content: center;
    background-color: var(--borderAndBackground);
    border: 2px solid var(--borderAndBackground);
    border-radius: var(--btnRadius);
    color: var(--white);
    cursor: pointer;
    display: flex;
    font-weight: var(--font-weight-medium);
    gap: var(--space-tiny);
    line-height: 1;
    padding: var(--space-xs) var(--space-sm);
    text-decoration: none;
    transition: all 0.2s ease-in;
    width: max-content;
}

.btn > svg {
    aspect-ratio: 1;
    height: 1.5em;
    width: auto;
}

.btn > svg path {
    fill: currentColor;
}

.btn:hover {
    background-color: transparent;
    border-color: var(--primary);
    color: var(--primary);
    text-decoration: underline;
    text-decoration-color: currentColor;
}

/*--------------------------------------------------------------------------- */
/* MARK: BLOCKS
*/

/* leave a gap here to make the sidebar nav useful */




/*--------------------------------------------------------------------------- */
/* MARK: CTA Block
*/

.cta-block {
    border: var(--space-tiny) solid var(--neutral-light);
    border-left: 0;
    border-right: 0;
    display: grid;
    grid-template-columns: max-content auto;
    gap: var(--space-xs) var(--space-base);
    padding: var(--space-base);
}

.cta-block .heading {
    font-size: var(--text-lg);
}

.cta-block .copy {
    align-self: center;
    display: inherit;
    gap: inherit;
} 

.cta-block .icon svg {
    height: calc(var(--space-huge));
}
.cta-block .icon svg .icon-fill-dark {
    fill: var(--neutral);
}

/*--------------------------------------------------------------------------- */
/* MARK: Portal Block
*/

.portal {
    display: grid;
    gap: var(--space-xs);
    list-style: none;
    padding: 0;
}
.portal > li > * {
    margin-block: 0;
}
.portal .link {
    align-items: center;
    border: 1px solid var(--theme);
    border-radius: var(--radius-sm);
    color: var(--neutral);
    display: grid;
    grid-template-columns: auto max-content;
    grid-template-areas: 
    "parent icon"
    "heading icon"
    ;
    align-items: center;
    height: 100%;    
    padding: var(--space-base) var(--space-md);
    text-decoration: none;
    transition: all 0.18s ease-out;
    width: 100%;
}

.portal .link > svg {
    height: var(--text-lg);
    grid-area: icon;
    width: auto;
}
.portal .link > .kicker {
    color: var(--theme, --primary);
    display: block;
    grid-area: parent;
    margin-bottom: var(--space-tiny);
}
.portal .link > .heading {
    grid-area: heading;
    font-size: var(--text-lg);
    line-height: 1.2;
}

.portal .link:hover {
    background-color: var(--theme, --primary);
    border-color: var(--theme, --primary);
}
.portal .link:hover > * {
    color: var(--white);
}



/*--------------------------------------------------------------------------- */
/* MARK: Guides Block
*/

.guides {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: var(--space-sm);
    list-style: none;
    padding: 0;
    width: 100%;
}

.guides > li {
    container-type: inline-size;
}

.guides > li > * {
    margin-block: 0;
}
.guides .link {
    aspect-ratio: auto;
    background-color: white;
    box-shadow: var(--shadow-sm);
    border-radius: var(--radius-base);
    color: var(--neutral);
    display: flex;
    flex-direction: column;
    gap: 0;
    height: 100%;
    overflow: hidden;
    padding: 0;
    position: relative;
    text-decoration: none;
    transition: border 0.2s ease-in;
    width: 100%;
    z-index: 1;
}

.guides .kicker {
    color: var(--theme, blue);
    line-height: 1;
    margin: 0;
    padding: var(--space-base);
    padding-bottom: 0;
    font-size: var(--text-lg);

}
.guides .heading {
    margin: 0;
    font-weight: var(--font-weight-bold);
    padding: var(--space-base);
}

.guides .link:hover {
    border-color: var(--primary);
    z-index: 2;
}

.guides .link:hover > svg {
    color: var(--theme);
    opacity: 1;
    transform: scale(1.1) rotate(0deg);
}

.guides .link::after {
    content: '';
    position: absolute;
    bottom: -125%; right: -50%;
    background-color: var(--theme);
    pointer-events: none;
    opacity: 0;
    width: 15vw;
    height: 15vw;
    border-radius: 50%;
    transition: all 0.2s ease-in-out;
}

.guides .link:hover:after {
    bottom: -8vw; right: -8vw;
    opacity: 0.1;
}

.guides .link > svg {
    width: 10%;
    height: auto;
    color: var(--neutral);
    margin-top: auto;
    margin-left: auto;
    margin-right: var(--space-sm);
    margin-bottom: var(--space-sm);
    opacity: 0.2;
    transition: all 0.2s ease;
    transform: rotate(45deg);
}

/*--------------------------------------------------------------------------- */
/* MARK: Blurbs Block
*/

.blurb .icon svg {
    height: var(--space-xxl);
    width: var(--space-xxl);
}

/*--------------------------------------------------------------------------- */
/* MARK: Image Block
*/

.image-block img {
    aspect-ratio: var(--ratio);
    background-color: transparent; /* background colours interfere with pngs and svgs */
    height: auto;
    object-fit: contain;
    width: 100%;
}
.image-block img[data-crop=""] {
    object-fit: cover;
}

.op-right-top          { object-position: right top;       }
.op-right-center       { object-position: right center;    }    
.op-right-bottom       { object-position: right bottom;    }
.op-center-top         { object-position: center top;      }
.op-center-center      { object-position: center center;   }
.op-center-bottom      { object-position: center bottom;   }
.op-left-top           { object-position: left top;        }
.op-left-center        { object-position: left center;     }
.op-left-bottom        { object-position: left bottom;     }

/*--------------------------------------------------------------------------- */
/* MARK: Gallery Block
*/

.gallery-block .gallery {
    --auto-grid-min-size: 8rem;
    --auto-grid-max-columns: 4;
    --auto-grid-gap: var(--space-sm);
    align-items: center;
    list-style: none;
    padding: 0;
}
.gallery-block .gallery img {
    aspect-ratio: var(--ratio);
    background-color: var(--neutral-bg);
    height: auto;
    object-fit: contain;
    width: 100%;
}
.gallery-block .gallery img[data-crop=""] {
    object-fit: cover;
}

/*--------------------------------------------------------------------------- */
/* MARK: Accordions Block / FAQs
*/

details {
    border: 1px solid var(--neutral-mid);
    display: block;
    border-radius: var(--radius-sm);

}

summary {
    cursor: pointer;
    padding: var(--space-base);
    text-decoration: underline;
}

details > .answer {
    padding: var(--space-base);
}

.accordions {
    display: grid;
    gap: var(--space-xs);
}
.accordion {
    border: 1px solid var(--neutral-light);
}
.accordion > .question {
    padding: var(--space-base);
}
.accordion > .answer {
    background-color: var(--accent-bg);
    padding: var(--space-base);
}

/*--------------------------------------------------------------------------- */
/* MARK: Map Block
*/

.map-block {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    height: 100%;
}
.map-block iframe {
    height: 100%;
    min-height: 16rem;
    min-width: 100%;
    width: 100%;
}

/*--------------------------------------------------------------------------- */
/* MARK: Eyebrow Block
*/

.eyebrow-block {

}

/*--------------------------------------------------------------------------- */
/* MARK: Lede Block
*/

.lede-block {
    
}

/*--------------------------------------------------------------------------- */
/* MARK: Lang Toggle
*/

.lang-toggle {
    background-color: var(--site-bg);
    display: flex;
    width: 100%;
}

.lang-toggle ul {
    border-radius: var(--radius-sm);
    display: flex;
    list-style: none;
    line-height: 1;
    margin: var(--space-tiny);
    padding: 0;
}

.lang-toggle a {
    color: var(--neutral);
    font-size: var(--text-sm);
    display: block;
    padding: var(--space-xs);
    position: relative;
    text-decoration: none;
    border-radius: var(--radius-sm);
    z-index: 1;
}

.lang-toggle a:focus {
    z-index: 2;
}

.lang-toggle a:hover {
    text-decoration: underline;
}

.lang-toggle .active a {
    background-color: var(--primary);
    color: white;
}

/*--------------------------------------------------------------------------- */
/* MARK: Social links
*/

.social-links {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-sm);
}
.social-links a {
    text-decoration: none;
    transition: opacity 0.2s ease-out;
}
.social-links a:hover {
    opacity: 0.7;
}
.social-links svg {
    height: var(--space-xl);
    width: var(--space-xl);
}

/*--------------------------------------------------------------------------- */
/* MARK: Forms
*/


.uniform__potty {
    position: absolute;
    left: -9999px;
}

.rtbform .form-row:last-of-type {
    align-items: end;
}

.rtbform .form-row:last-of-type :nth-child(2) {
    justify-self: end;
}

.rtbform {
    display: grid;
    gap: var(--text-base);
}

.rtbform .btn {
    padding: var(--space-sm);
}

.rtbform .two-fields {
    display: inherit;
    gap: inherit;
}

.rtbform label, .rtbform .label {
    display: block;
    font-size: var(--text-base);
    margin-bottom: var(--space-tiny);
}

.rtbform .req {
    color: #ce0000;
}

.rtbform input:is([type="text"], [type="email"], [type="number"], [type="search"],  [type="url"]),
.rtbform textarea {
    appearance: none;
    background-color: var(--white);
    border: 1px solid var(--neutral-mid);
    border-radius: var(--radius-sm);
    box-shadow: none;
    display: block;
    padding: var(--space-xs);
    width: 100%;   
}

.rtbform input:is([type="text"], [type="email"], [type="number"], [type="search"], [type="url"]):focus-visible,
.rtbform textarea:focus-visible {
    border-color: var(--primary);
    outline: 0.125rem solid var(--primary-mid);
    outline-offset: 0;
}

.rtbform input::placeholder,
.rtbform textarea::placeholder {
    color: var(--neutral-mid);
    font-weight: var(--font-weight-regular);
}

.rtbform textarea {
    min-height: calc( 2 * var(--space-huge) );
}

.search-form {
    display: grid;
    gap: var(--space-base);
    grid-template-columns: auto max-content;
}

/*--------------------------------------------------------------------------- */
/* MARK: Utility Classes
*/

.skiplink {
	position: absolute;
	transform: translateX(-100%);
	background-color: white;
	z-index: 3;
	left: 0;
	top: 0;
	padding: var(--space-base);
}
.skiplink:focus {
    transform: translateX(0);
}

.trim > :first-child    { margin-top: 0; }
.trim > :last-child     { margin-bottom: 0; }

.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; }

.text-left                      { text-align: left; }
.text-right                     { text-align: right; }
.text-center                    { text-align: center; }

.text-xxl                       { font-size: var(--text-xxl); }
.text-xl                        { font-size: var(--text-xl); }
.text-lg                        { font-size: var(--text-lg); }
.text-md                        { font-size: var(--text-md); }
.text-base                      { font-size: var(--text-base); }
.text-sm                        { font-size: var(--text-sm); }

.list-none                      { list-style: none; padding-left: 0; }

.justify-content-start          { justify-content: start; }
.justify-content-center         { justify-content: center; }
.justify-content-end            { justify-content: end; }

.justify-items-start            { justify-items: start; }
.justify-items-center           { justify-items: center; }
.justify-items-end              { justify-items: end; }

.align-items-center             { align-items: center; }
.align-items-end                { align-items: end; }
.align-items-start              { align-items: start; }

.max-narrow                     { max-width: var(--max-narrow); }
.max-content                    { max-width: var(--max-content); }
.max-wide                       { max-width: var(--max-wide); }

.none                           { display: none; }
.nobr                           { text-wrap: nowrap; }