:root {

    --primary-bg:       #F9F0F0;
    --primary-light:    #D08A8A;
    --primary-mid:      #9A3D3D;
    --primary:          #632C31;
    --primary-dark:     #4C282C;

    --secondary-bg:     #E7EEEC;
    --secondary-light:  #D0DDD9;
    --secondary-mid:    #89A9A0;
    --secondary:        #4F6D64;
    --secondary-dark:   #2B3B36;

    --tertiary-bg:     #F2F6F8;
    --tertiary-light:  #D7E5EA;
    --tertiary-mid:    #6CA0B2;
    --tertiary:        #2F4F5A;
    --tertiary-dark:   #1C2F35;

    --accent-bg:        #F9F6F1;
    --accent-light:     #E7DBC5;
    --accent-mid:       #C2A16A;
    --accent:           #AF865C;
    --accent-dark:      #9C6A4E;

    --neutral-bg:       #E6E3DF;
    --neutral-lighter:  #CFCBC5;
    --neutral-light:    #B8B2AA;
    --neutral-mid:      #857D6F;
    --neutral:          #4E4941;
    --neutral-dark:     #2C2A25;

    --brand:        #632C31;
    --fog:          #E6E3DF;
    --stone:        #B8B2AA;
    --grey:         #8C8F8A;
    --charcoal:     #2E2F2C;
    --kelp:         #4F6D64;
    --tidal:        #2F4F5A;
    --slate:        #5E6F73;
    --clay:         #9C6A4E;
    --sand:         #C2A16A;

    --transparent:  transparent;


    --beige: #F4F2EE;
    --beiger: #f5f4f0;
    --mellow: #eeede0;
    --mellower: #F7F6EC;
    --gold: #d0bc80;
    --red: #ff482a;

    --sage-bg:      #F0EAD2;
    --sage-light:   #BCBEA6;
    --sage:         #656d4a;
    --sage-dark:    #333D29;

    --white:            #fff;

    /* semantic colour names */
    --site-bg:      var(--beige);

    /* @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,13—16|16—18|18—21|20—24|24—32|30—44|36—64&p=text */
    /* 448px --> 1344px */

    --text-xs: clamp(0.8125rem, 0.7188rem + 0.3348vw, 1rem);                    /* 13-16px */
    --text-sm: clamp(1rem, 0.9375rem + 0.2232vw, 1.125rem);                     /* 16-18px */
    --text-base: clamp(1.125rem, 1.0313rem + 0.3348vw, 1.3125rem);              /* 18-21px */
    --text-md: clamp(1.25rem, 1.125rem + 0.4464vw, 1.5rem);                     /* 20-24px */
    --text-lg: clamp(1.5rem, 1.25rem + 0.8929vw, 2rem);                         /* 24-32px */
    --text-xl: clamp(1.875rem, 1.4375rem + 1.5625vw, 2.75rem);                  /* 30-44px */
    --text-xxl: clamp(2.25rem, 1.375rem + 3.125vw, 4rem);                       /* 36-64px */

    --font-weight-thin: 300;
    --font-weight-regular: 400;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    
    --max-narrow:   36rem; /* 576px */
    --max-content:  60rem; /* 960px */
    --max-wide:     84rem; /* 1344px */

    --shadow-sm: 0 var(--space-tiny) var(--space-sm) rgba(0,0,0,0.07);
    --shadow-md: 0 var(--space-sm) var(--space-md) rgba(0,0,0,0.07);

    --radius-sm: 0.1875rem;
    --radius-md: var(--space-sm);
    --radius-lg: var(--space-md);
    --radius-xl: var(--space-lg);
    --btnRadius: var(--radius-sm);

    --gutter: clamp(1rem, -1.5rem + 8.9286vw, 6rem); /* 16px->96px */


}

/*--------------------------------------------------------------------------- */
/* MARK: FONTS
*/



    /* DM Sans Var */
    @font-face {
        font-family: 'font-primary';
        src:    url('/assets/fonts/dm-sans-var/dm-sans-var.woff2') format('woff2-variations'),
                url('/assets/fonts/dm-sans-var/dm-sans-var.ttf') format('truetype-variations');
        font-weight: 100 1000;
        font-display: swap;
        
    }
    .font-primary { font-family: 'font-primary', sans-serif; font-style: normal; }
    .font-primary-100 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 100; }
    .font-primary-200 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 200; }
    .font-primary-300 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 300; }
    .font-primary-400 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 400; }
    .font-primary-500 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 500; }
    .font-primary-600 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 600; }
    .font-primary-700 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 700; }
    .font-primary-800 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 800; }
    .font-primary-900 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 900; }
    .font-primary-1000 { font-family: 'font-primary', sans-serif; font-style: normal; font-weight: 1000; }

    /* DM Sans Var Italic */
    @font-face {
        font-family: 'font-primary';
        src:    url('/assets/fonts/dm-sans-var/dm-sans-var-italic.woff2') format('woff2-variations'),
                url('/assets/fonts/dm-sans-var/dm-sans-var-italic.ttf') format('truetype-variations');
        font-weight: 100 1000;
        font-display: swap;
        font-style: italic; 
    }
    .font-primary-i { font-family: 'font-primary', sans-serif; font-style: italic; }
    .font-primary-100i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 100; font-style: italic; }
    .font-primary-200i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 200; font-style: italic; }
    .font-primary-300i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 300; font-style: italic; }
    .font-primary-400i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 400; font-style: italic; }
    .font-primary-500i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 500; font-style: italic; }
    .font-primary-600i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 600; font-style: italic; }
    .font-primary-700i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 700; font-style: italic; }
    .font-primary-800i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 800; font-style: italic; }
    .font-primary-900i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 900; font-style: italic; }
    .font-primary-1000i { font-family: 'font-primary', sans-serif; font-style: italic; font-weight: 1000; font-style: italic; }



    /* Neco Var */
    @font-face {
        font-family: 'font-secondary';
        src:    url('/assets/fonts/neco-var/neco-var.woff2') format('woff2-variations'),
                url('/assets/fonts/neco-var/neco-var.ttf') format('truetype-variations');
        font-weight: 400 900;
        font-display: swap;
         
    }
    .font-secondary { font-family: 'font-secondary', sans-serif; font-style: normal; }
    .font-secondary-400 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 400; }
    .font-secondary-500 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 500; }
    .font-secondary-600 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 600; }
    .font-secondary-700 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 700; }
    .font-secondary-800 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 800; }
    .font-secondary-900 { font-family: 'font-secondary', sans-serif; font-style: normal; font-weight: 900; }

    /* Neco Var Italic */
    @font-face {
        font-family: 'font-secondary';
        src:    url('/assets/fonts/neco-var/neco-var-italic.woff2') format('woff2-variations'),
                url('/assets/fonts/neco-var/neco-var-italic.ttf') format('truetype-variations');
        font-weight: 400 900;
        font-display: swap;
        font-style: italic; 
    }
    .font-secondary-i { font-family: 'font-secondary', sans-serif; font-style: italic; }
    .font-secondary-400i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 400; font-style: italic; }
    .font-secondary-500i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 500; font-style: italic; }
    .font-secondary-600i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 600; font-style: italic; }
    .font-secondary-700i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 700; font-style: italic; }
    .font-secondary-800i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 800; font-style: italic; }
    .font-secondary-900i { font-family: 'font-secondary', sans-serif; font-style: italic; font-weight: 900; font-style: italic; }



/*--------------------------------------------------------------------------- */
/* 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 var(--gold);
    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(--primary-dark); */
    display: flex;
    align-items: center;
    gap: var(--space-base);
    justify-content: space-between;
    padding: var(--space-base) var(--gutter);
    text-align: center;
}
.site-header .logo {
    align-items: center;
    gap: var(--space-sm);
    display: flex;
    font-weight: var(--font-weight-bold);
    max-width: 12rem;
    position: relative;
    z-index: 5;
    text-decoration: none;
}
.site-header .logo svg {
    width: 100%;
}

.site-header .logo path {
    fill: var(--primary) !important;
}

/* navigation starts here */

.site-nav {
    display: none; /* for mobile */
    z-index: 5;
}

.mobile-nav-toggle {
    background: var(--primary);
    border: 0;
    border-radius: var(--radius-lg);
    color: white;
    cursor: pointer;
    display: block; /* for mobile */
    height: var(--space-huge);
    width: var(--space-huge);
}
.mobile-nav-toggle svg {
    width: 100%;
}

/* the parent menu and primary nav items */
.site-nav > .menu {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    font-size: var(--text-xs);
    gap: var(--space-xs) var(--space-md);
    justify-content: end;
    list-style: none;
    padding: 0;
}
.site-nav > .menu.omega-btn > li:last-of-type a {
    background-color: var(--primary);
    border-radius: var(--btnRadius);
    color: var(--white);
    font-weight: var(--font-weight-bold);
    padding: calc(0.8 * var(--space-sm)) var(--space-lg);
}
.site-nav > .menu.omega-btn > li:last-of-type a:hover {
    background-color: var(--gold);
}
.site-nav > .menu.omega-btn > li:last-of-type a::after {
    display: none;
}

.site-nav > .menu > li {
    display: flex;
}
.site-nav > .menu > li.has-submenu {
    position: relative;
}
.site-nav > .menu > li > a {
    color: var(--neutral);
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.05em;
    padding: var(--space-xs) 0;
    position: relative;
    text-decoration: none;
    text-transform: uppercase;
}

.site-nav > .menu > li > a.active {
    color: var(--primary);
}

.site-nav > .menu > li > a.active::after {
    background-color: var(--primary);
    content: '';
    height: 2px;
    left: 0; right: 0; bottom: 0;
    position: absolute;
}

.site-nav > .menu > li > a:hover {
}

/* the drop-down menu and kids */
.site-nav .submenu {
    background-color: var(--white);
    border-radius: var(--btnRadius);
    display: none;
    left: 50%;
    list-style: none;
    margin-left: calc(-0.5 * 24rem);
    padding: var(--space-base) var(--space-xs);
    position: absolute;
    text-align: center;
    top: calc(100% + var(--space-base));
    width: 24rem;
}
.site-nav .submenu:before {
    border-bottom: 1rem solid var(--white);
    border-left: 1rem solid transparent;
    border-right: 1rem solid transparent;
    content: '';
    pointer-events: none;
    position: absolute;
    top: -0.75rem;
    left: 50%;
    margin-left: -1rem;
}

.site-nav .submenu a {
    color: var(--primary);
    display: block;
    font-size: var(--text-sm);
    padding: var(--space-xs);
    position: relative;
    text-decoration: none;
    z-index: 2;
}
.site-nav .submenu a:hover {
}

@media screen and (min-width: 60rem) {
    .site-nav {
        display: block;
    }
    .mobile-nav-toggle {
        display: none; /* for mobile */
    }
}

/*--------------------------------------------------------------------------- */
/* MARK: Page Title
*/

.page-title {
    position: relative;
}

.page-title .illustration {
    height: auto;
    width: calc( 2.5 * var(--space-huge) );
    position: relative;
}

.page-title .illustration::before {
    background-color: var(--neutral-bg);
    border-radius: 50%;
    content: '';
    display: block;
    inset: var(--space-md);
    position: absolute;
}
.page-title .illustration > * {
    position: relative;
}

.page-title .copy {
    display: grid;
    flex-direction: grid;
    gap: var(--space-md);
    padding: var(--space-huge) var(--gutter);
    position: relative;
    z-index: 2;
    width: 100%;
}

.page-title.no-image .copy {
    padding-bottom: 0;
}

.page-title h1 {
    font-weight: 400;
    line-height: 1;
}

.page-title .lede {
    text-wrap: pretty;
}

.page-title .image {
    aspect-ratio: 1;
    height: auto;
    object-fit: cover;
    width: 100%;
}

.page-title .btns {
    margin-top: var(--space-lg);
}

.XXXpage-title::after {
    background-image: url('/assets/img/spiral.svg');
    background-repeat: no-repeat;
    background-position: bottom center;
    content: '';
    filter: grayscale(1) brightness(0) opacity(0.1);
    right: 0;
    bottom: 5%;
    left: 0;
    pointer-events: none;
    position: absolute;
    top: -150%;
}

.hero-divider {
    /* the extra 2 pixels prevent a hairline gap from appearing */
    margin-top: calc((-1 * var(--space-xl)) + 2px);
}

/*--------------------------------------------------------------------------- */
/* MARK: Site MAIN
*/

main {
    display: flex;
    flex-direction: column;
}
main > * {
    margin-block: 0;
}
/*--------------------------------------------------------------------------- */
/* MARK: Site CTA
*/

.site-cta {
    background-color: var(--neutral-bg);
    padding: var(--space-xxl) var(--gutter) var(--space-huge) var(--gutter);
    position: relative;
    z-index: 2;
}
.site-cta > .inner {
    display: grid;
    gap: var(--space-base) var(--space-lg);
}
.site-cta .heading {
    font-weight: var(--font-weight-regular);
}
.site-cta .copy {
    display: grid;
    gap: var(--space-xl);
}
.site-cta-divider-bottom.rough-divider {
    background-color: var(--neutral-lighter);
    height: var(--space-md);
    position: relative;
    margin-top: -2px !important;
    margin-bottom: -2px !important;
    z-index: 1;
}
.site-cta-divider-top.rough-divider {
    height: var(--space-huge);
    margin-bottom: -2px !important;
}


/*--------------------------------------------------------------------------- */
/* MARK: Site FOOTER
*/

.site-footer {
    background-color: var(--neutral-lighter);
    display: flex;
    flex-direction: column;
    font-size: var(--text-sm);
    gap: var(--space-lg);
    padding: var(--space-xxl) var(--gutter);
}

.site-footer > .inner {
    align-items: start;
    display: grid;
    gap: var(--space-xl);
    grid-template-areas: 
        "blurb"
        "navLeft"
        "navRight"
        "contact"
    ;
}

.site-footer .blurb {
    display: grid;
    gap: var(--space-base);
    grid-area: blurb;
    line-height: 1.618;
}
.site-footer .contact-info {
    grid-area: contact;
}

.site-footer .logo {
    display: block;
    max-width: 100%;
    width: 16rem;
}
.site-footer .logo path {
    fill: var(--neutral) !important;
}

.site-footer a {
    text-decoration: none;
}

.site-footer h2 {
    color: var(--neutral);
    font-size: var(--text-sm);
    font-family: 'font-primary';
    font-weight: var(--font-weight-bold);
    letter-spacing: 0.05em;
    margin-bottom: var(--space-base);
    text-transform: uppercase;
}
.site-footer ul {
    display: grid;
    gap: var(--space-xs);
    list-style: none;
    margin: 0;
    padding: 0;
}

.site-footer .social-links {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-sm);
    margin-top: var(--space-sm);
    margin-left: -0.25rem;
    margin-right: -0.25rem;
}
.site-footer .social-links a {
    text-decoration: none;
}
.site-footer .social-links svg {
    height: var(--space-xl);
    width: var(--space-xl);
}
.site-footer a {
    color: var(--neutral);
}

.site-meta {
    align-items: center;
    background-color: var(--neutral-mid);
    color: var(--white);
    display: grid;
    font-size: var(--text-xs);
    grid-area: meta;
    grid-template-columns: repeat(2, 1fr);
    line-height: 1.309;
    padding: var(--space-base) var(--gutter);
    position: relative;
    z-index: 2;
}
.site-meta a {
    color: var(--gold);
}
.site-meta-divider.rough-divider {
    background-color: var(--neutral-lighter);
    height: var(--space-sm);
    margin-bottom: -2px !important;
    position: relative;
    z-index: 1;
}

.site-meta .btn.subtle {
    --borderAndBackground: rgba(0,0,0,0.1);
    color: var(--white);
    padding: var(--space-xs) var(--space-sm);
}
.site-meta .btn.subtle:hover {
    --borderAndBackground: var(--neutral);
}

.site-meta > :nth-child(even) {
    text-align: right;
}

/*--------------------------------------------------------------------------- */
/* MARK: ROWS
*/

.row {
    --rowPad:           var(--space-xxl);
    --rowPadDefault:    calc(2 * var(--rowPad));
    --rowPadMore:       calc(4 * var(--rowPad));
    --rowPadLess:       calc(1 * var(--rowPad));
    --bg: transparent;
    background-color: var(--bg);
    padding: var(--rowPadDefault) var(--gutter);
    position: relative;
}


.row.with-bdr::after {
    background-color: var(--neutral-bg);
    content: '';
    height: 2px;
    position: absolute;
    left: var(--gutter); right: var(--gutter); bottom: 0;
}

.row.top-pad-none       { padding-top:      0; }
.row.bot-pad-none       { padding-bottom:   0; }
.row.top-pad-less       { padding-top:      var(--rowPadLess); }
.row.bot-pad-less       { padding-bottom:   var(--rowPadLess); }      /* md is half the xl size */
.row.top-pad-more       { padding-top:      var(--rowPadMore); }    /* huge is twice the xl size */
.row.bot-pad-more       { padding-bottom:   var(--rowPadMore); }

.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%;
}

.row.flipped .columns > :first-child {
    order: 2;
}

/*--------------------------------------------------------------------------- */
/* MARK: COLUMNS
*/

.columns {
    container-type: inline-size;
    display: grid;
    gap: var(--space-xl);
    margin-inline: auto;
}
.columns .column {
    container-type: inline-size;
    display: flex;
    gap: var(--space-md);
    flex-direction: column;
    position: relative;
    z-index: 2;
}
.columns .column > * {
    margin-block: 0;
    max-width: 100%;
}

.columns .column.post {
    gap: var(--space-lg);
}

/*--------------------------------------------------------------------------- */
/* 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: 500;
    letter-spacing: -0.01em;
    line-height: 1.154;
}

/*--------------------------------------------------------------------------- */
/* MARK: Paragraphs
*/

.lede {
    font-size: var(--text-md);
    line-height: 1.618;
}
.kicker {
    color: var(--neutral-mid);
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    letter-spacing: 0.07em;
    line-height: 1.154;
    text-transform: uppercase;
}
.kicker-link {
    font-size: var(--text-xs);
    font-weight: var(--font-weight-bold);
    letter-spacing: 0.07em;
    line-height: 1.154;
    text-transform: uppercase;
    text-decoration: none;
}

.callout {
    background-color: var(--secondary-bg);
    border-radius: var(--radius-sm);
    font-size: var(--text-sm);
    padding: var(--space-base);
}

/*--------------------------------------------------------------------------- */
/* MARK: LINKS
*/

a {
    color: var(--primary-mid);
    text-decoration-thickness: 1px;
}


/*--------------------------------------------------------------------------- */
/* 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-wrap: balance;
}

img {
    height: auto;
}

/*--------------------------------------------------------------------------- */
/* MARK: HRs & DIVIDERS
*/

hr {
    border: 0;
    padding: 0;
    height: 1px;
    background-color: var(--neutral-mid);
    width: 100%;
    display: block;
}

.rough-divider {
    --bg: --neutral;
    height: var(--space-xl);
    position: relative;

}
.rough-divider svg {
    position: absolute;
    inset: 0;
    fill: var(--bg);
}

.rough-divider.flip {
    margin-top: -1px;
    transform: rotate(180deg);
}

.rough-divider:not(.flip) {
    margin-bottom: -1px;
}


/*--------------------------------------------------------------------------- */
/* 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 {
    align-items: center;
    display: flex;
    gap: var(--space-sm) var(--space-md);
    flex-wrap: wrap;
    font-size: var(--text-sm);
}

.btn {
    --borderAndBackground: var(--primary);
    appearance: none;
    background-color: var(--borderAndBackground);
    border: 1px solid var(--borderAndBackground);
    border-radius: var(--btnRadius);
    color: var(--white);
    cursor: pointer;
    display: inline-block;
    font-weight: 600;
    line-height: 1;
    letter-spacing: 0.05em;
    padding: var(--space-sm) var(--space-lg);
    text-decoration: none;
    text-transform: uppercase;
}
.btn.has-arrow {
    display: flex;
    gap: var(--space-base);
    padding-right: var(--space-md);
}
.btn.outline {
    background-color: transparent;
    color: var(--borderAndBackground);
}
.btn.subtle {
    --borderAndBackground: var(--neutral-bg);
    color: var(--primary);
}
.btn.simple {
    background: transparent;
    border: 0;
    border-radius: 0;
    border-bottom: 2px solid var(--primary);
    color: var(--primary);
    padding: 0 0 var(--space-xs) 0;
}
.btn:hover {
    --borderAndBackground: var(--gold);
}
.btn.subtle:hover {
    color: var(--white);
}
.btn.simple:hover {
    border-color: var(--gold);
    color: var(--gold);
}


/*--------------------------------------------------------------------------- */
/* MARK: BLOCKS
*/

/* leave a gap here to make the sidebar nav useful */


/*--------------------------------------------------------------------------- */
/* MARK: Text Block
*/

.text-stack {
    display: grid;
    gap: var(--space-md);
}

/*--------------------------------------------------------------------------- */
/* MARK: Partners Logo Block
*/

.partners {
    container-type: inline-size;
    display: grid;
    gap: var(--space-sm);
    grid-template-columns: repeat(2, 1fr);
    list-style: none;
    padding: 0;
}

.partners .partner {
    align-content: start;
    background-color: var(--white);
    border-radius: var(--btnRadius);
    display: flex;
    flex-direction: column;
    font-size: var(--text-xs);
    height: 100%;
    text-align: center;
}

.partners .partner:hover {
    box-shadow: var(--shadow-sm);
}

.partners .name {
    background-color: var(--neutral-bg);
    border-radius: 0 0 var(--btnRadius) var(--btnRadius);
    align-items: center;
    justify-content: center;
    display: flex;
    padding: var(--space-xs);
    line-height: 1.309;
    height: 100%;
    margin-block: auto;
    text-wrap: balance;
}

.partners .logo-link {
    display: block;
}

.partners .logo {
    aspect-ratio: 1;
    background-color: white;
    margin-inline: auto;
    object-fit: contain;
    padding: var(--space-sm);
    width: 100%;
    max-height: 9rem;
    max-width: 14rem;
}

/* services listing responsive */
@container (min-width: 28rem) {
    .partners {
        grid-template-columns: repeat(3, 1fr);
    }
}
@container (min-width: 42rem) {
    .partners {
        grid-template-columns: repeat(4, 1fr);
    }
}
@container (min-width: 68rem) {
    .partners {
        grid-template-columns: repeat(6, 1fr);
    }
}

/*--------------------------------------------------------------------------- */
/* MARK: Portal Block
*/

.portal {
    container-type: inline-size;
    display: grid;
    gap: var(--space-base);
    list-style: none;
    padding: 0;
}

.portal.random {
    grid-template-columns: 1fr;
}

.portal .portal-item .image {
    aspect-ratio: 3/2;
}

.portal.random .portal-item .image {
    aspect-ratio: 3/2;
}

.portal-item .link {
    background-color: var(--primary);
    border-radius: var(--btnRadius);
    color: var(--white);
    display: grid;
    grid-template-areas: "stack";
    height: 100%;
    overflow: hidden;
    text-decoration: none;
    transition: clip-path 0.2s ease;
    width: 100%;
}
.portal-item .link:hover {
    box-shadow: var(--shadow-sm);
}

.portal-item .link > * {
    grid-area: stack;
    position: relative;
}

.portal-item .copy {
    display: flex;
    flex-direction: column;
    gap: var(--space-base);
    padding: var(--space-base);
}

.portal-item .image {
    filter: brightness(0.6) saturate(1.4);
    height: 100%;
    object-fit: cover;
    width: 100%;
}

.portal-item strong {
    margin-top: auto;
}


.portal-item > * {
    margin-block: 0;
}

/* standard portal responsive container stuff */
@container (min-width: 28rem) {
    .portal {
        grid-template-columns: repeat(2, 1fr);
    }
    .portal .portal-item .image {
        aspect-ratio: 1;
    }
}
@container (min-width: 42rem) {
    .portal .portal-item .image {
        aspect-ratio: 4/3;
    }
}
@container (min-width: 68rem) {
    .portal {
        grid-template-columns: repeat(3, 1fr);
    }
    .portal .portal-item .image {
        aspect-ratio: 1;
    }
}
@container (min-width: 98rem) {
    .portal .portal-item .image {
        aspect-ratio: 4/3;
    }
}
/* random portal responsive container stuff */

@container (min-width: 28rem) {
    .portal.random {
        grid-template-columns: repeat(2, 1fr);
    }
    .portal.random .portal-item .image {
        aspect-ratio: 3/4;
    }
}
@container (min-width: 42rem) {
    .portal.random .portal-item .image {
        aspect-ratio: 1;
    }
}
@container (min-width: 48rem) {
    .portal.random .portal-item .image {
        aspect-ratio: 3/2;
    }
}
@container (min-width: 68rem) {
    .portal.random {
        grid-template-columns: repeat(4, 1fr);
    }
    .portal.random .portal-item .image {
        aspect-ratio: 2/3;
    }
}

/*--------------------------------------------------------------------------- */
/* 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: var(--neutral-bg);
    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: 3D Viewer Block
*/

model-viewer {
    background: var(--neutral-mid);
    border-radius: 0.5rem;
    height: 50svh;
    margin-bottom: 1rem;
    width: 100%;
}

/*--------------------------------------------------------------------------- */
/* 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: Careers
*/

.careers-row .column:last-of-type {
    border: 2px solid var(--neutral-bg);
    border-radius: var(--btnRadius);
    padding: var(--space-md);
}


/*--------------------------------------------------------------------------- */
/* MARK: Paging pagination
*/

.prev-next {
    container-type: inline-size;
    display: flex;
    flex-wrap: wrap;
    font-size: var(--text-sm);
    justify-content: center;
    gap: var(--space-xs) var(--space-xl);
    text-align: center;
}
.prev-next a {
    border-top: 2px solid var(--neutral-bg);
    color: var(--neutral);
    display: flex;
    flex-direction: column;
    padding: var(--space-sm);
    text-decoration: none;
    width: 100%;
}
.prev-next a .label {
    font-weight: var(--font-weight-semibold);
    letter-spacing: 0.05em;
    text-transform: uppercase;
}

@container (min-width: 36rem) {
    .prev-next {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }
}

/*--------------------------------------------------------------------------- */
/* MARK: Services Listing and Cards
*/

.services {
    display: grid;
    gap: var(--space-tiny);
    list-style: none;
    padding: 0;
}

.services + .callout {
    margin-top: var(--space-lg);
}

.services > li {
    width: 100%;
}

/* listing variant */

.services-listing {
    container-type: inline-size;
    font-size: var(--text-sm);
    font-weight: 500;
    gap: var(--space-base);
    grid-template-columns: repeat(1, 1fr);
    text-align: center;
}

.services-listing .link {
    background-color: var(--white);
    border-radius: var(--btnRadius);
    display: grid;
    height: 100%;
    gap: var(--space-sm);
    align-content: start;
    justify-content: center;
    padding: var(--space-md);
    text-decoration: none;
}

.services-listing .title {
    font-size: var(--text-base);
    font-family: 'font-primary';
}

.services-listing .illustration {
    margin-inline: auto;
    width: var(--space-huge);
}

.services-listing .link:hover {
    box-shadow: var(--shadow-sm);
}

/* services listing responsive */
@container (min-width: 28rem) {
    .services-listing {
        grid-template-columns: repeat(2, 1fr);
    }
}
@container (min-width: 48rem) {
    .services-listing {
        grid-template-columns: repeat(3, 1fr);
    }
}
@container (min-width: 58rem) {
    .services-listing {
        grid-template-columns: repeat(4, 1fr);
    }
}
@container (min-width: 68rem) {
    .services-listing {
        grid-template-columns: repeat(5, 1fr);
    }
}


/* cards */

.services-cards {
    gap: var(--space-base);
}

.services-cards .item {
    background-color: var(--white);
    border-radius: var(--btnRadius);
    display: grid;
    gap: var(--space-sm);
    grid-row: span 4;
    grid-template-rows: subgrid;
    padding: var(--space-md);
}
.services-cards .item:hover {
    box-shadow: var(--shadow-sm);
}

.services-cards .title {
    font-family: 'font-primary';
    font-size: var(--text-base);
    font-weight: var(--font-weight-semibold);
}
.services-cards .desc {
    border-top: 2px solid var(--neutral-bg);
    font-size: var(--text-sm);
    padding-top: var(--space-sm);
}
.services-cards .link {
    font-size: var(--text-sm);
    display: block;
    margin-top: auto;
}

.services-cards .illustration > a {
    display: block;
}
.services-cards .illustration {
    display: block;
    max-width: calc( 1.5 * var(--space-huge) );
    width: 100%;
}

/* services listing responsive */
@container (min-width: 38rem) {
    .services-cards {
        grid-template-columns: repeat(2, 1fr);
    }
}
@container (min-width: 58rem) {
    .services-cards {
        grid-template-columns: repeat(3, 1fr);
    }
}
@container (min-width: 78rem) {
    .services-cards {
        grid-template-columns: repeat(4, 1fr);
    }
}
@container (min-width: 98rem) {
    .services-cards {
        grid-template-columns: repeat(5, 1fr);
    }
}



/* detailed variant */

.services-detailed {
    gap: 0;
}

.services-detailed .title {
    font-size: var(--text-xl);
}

.services-detailed .item {
    align-items: center;
    display: grid;
    gap: var(--space-xl);
    grid-template-columns: calc(var(--space-huge) * 3) auto;
    padding: 0 0 var(--space-xl) 0;
}

.services-detailed .item:nth-child(odd) .hr {
    transform: scaleX(-1);
}
.services-detailed .item:nth-child(even) .hr {
    transform: scaleY(-1);
}

.services-detailed .hr {
    color: var(--gold);
    grid-column: 1 / -1;
    height: 2rem;
    width: 100%;
}
.services-detailed .hr svg {
    height: 100%;
    width: 100%;
}

.services-detailed .copy {
    display: grid;
    gap: var(--space-base);
}

.services-detailed + .callout {
    margin-top: var(--space-xxl);
}

#services .services-listing {
    position: sticky;
    left: 0; top: var(--space-base); right: 0;
}


/*--------------------------------------------------------------------------- */
/* MARK: Accordions Block / FAQs
*/

summary {
    cursor: pointer;
}
.accordions {
    display: grid;
    gap: var(--space-xs);
}
.accordion {
    border: 1px dashed var(--neutral-light);
    border-radius: var(--radius-sm);
}
.accordion[open=""] {
    background-color: var(--accent-bg);
    border-style: solid;
}
.accordion > .question {
    padding: var(--space-sm);
}
.accordion:hover {
    border-style: solid;
}
.accordion > .answer {
    display: grid;
    gap: var(--space-sm);
    padding: var(--space-sm);
}

/*--------------------------------------------------------------------------- */
/* 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 p {
    max-width: 48ch;
}

/*--------------------------------------------------------------------------- */
/* MARK: Forms
*/

.contact-form {
    display: grid;
    gap: var(--space-md);
    width: 100%;
}

.uniform__potty {
    position: absolute;
    left: -9999px;
}

* + .rtbform {
    padding-top: var(--space-lg);
}

.rtbform .form-row:last-of-type {
    align-items: end;
}

.rtbform .form-row:last-of-type :nth-child(2) {
    justify-self: end;
}

.rtbform .two-fields {
    display: grid;
    gap: var(--space-md);
}

.rtbform label, .rtbform .label {
    display: block;
    font-size: var(--text-sm);
    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(--accent-bg);
    border: 1px solid var(--neutral-light);
    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(--color-ocean-400);
    outline: 0.125rem solid var(--color-ocean-300);
    outline-offset: 0;
}

.rtbform input::placeholder,
.rtbform textarea::placeholder {
    color: var(--neutral-light);
    font-weight: var(--font-weight-regular);
}

.rtbform textarea {
    min-height: calc( 2 * var(--space-huge) );
}

/*--------------------------------------------------------------------------- */
/* MARK: Utility Classes
*/

.skiplink {
	position: absolute;
	transform: translateX(-100%);
	background-color: white;
	z-index: 99;
	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; }
