:root {

    --primary-bg:       #E8F2F9;
    --primary-light:    #CFE0F4;
    --primary-mid:      #74B2DA;
    --primary:          #0072BC;
    --primary-dark:     #005F9D;

    --secondary-bg:     #FDEAEB;
    --secondary-light:  #FCD6D7;
    --secondary-mid:    #F8ACAF;
    --secondary:        #EC1C24;
    --secondary-dark:   #961217;

    --accent-bg:        #FFFCEF;
    --accent-light:     #FFF5CF;
    --accent-mid:       #FFEA9F;
    --accent:           #FFD94F;
    --accent-dark:      #F1C01E;

    --neutral-bg:       #F5F8FC;
    --neutral-light:    #D8DEE7;
    --neutral-mid:      #BAC2CB;
    --neutral:          #313B46;
    --neutral-dark:     #232A32;
    --white:            #fff;

    /* @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-xxs: 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=576,1440,10—14|14—18|17—21|20—26|24—32|30—44|36—72&p=text */
    /* 576px --> 1440px */

    --text-xs: clamp(0.625rem, 0.4583rem + 0.463vw, 0.875rem);            /* 10-14px */
    --text-sm: clamp(0.875rem, 0.75rem + 0.3472vw, 1.0625rem);            /* 14-17px */
    --text-base: clamp(1.0625rem, 0.9375rem + 0.3472vw, 1.25rem);         /* 17-20px */
    --text-md: clamp(1.25rem, 1rem + 0.6944vw, 1.625rem);                 /* 20-26px */
    --text-lg: clamp(1.5rem, 1rem + 1.3889vw, 2.25rem);                   /* 24-36px */
    --text-xl: clamp(1.875rem, 1.2917rem + 1.6204vw, 2.75rem);            /* 30-44px */
    --text-xxl: clamp(2.25rem, 1.5rem + 2.0833vw, 3.375rem);              /* 36-54px */
    --text-nav: clamp(1rem, 0.9167rem + 0.2315vw, 1.125rem);              /* 16-18px */

    --font-weight-thin: 300;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-black: 800;
    
    --max-xs:   36rem; /* 576px */
    --max-sm:   48rem; /* 768px */
    --max-md:   64rem; /* 1024px */
    --max-lg:   80rem; /* 1280px */
    --max-xl:   90rem; /* 1440px */
    --max-xxl: 105rem; /* 1680px */

    --shadow-sm: 0 var(--space-xs) 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: var(--space-xxs);
    --radius-base: var(--space-xs);
    --radius-md: var(--space-sm);
    --radius-lg: var(--space-md);
    --radius-xl: var(--space-lg);

    --gutter: clamp(1rem, -1.5rem + 8.9286vw, 6rem); /* 16px->96px */


}


/*--------------------------------------------------------------------------- */
/* MARK: FONTS
*/

/* Figtree Var */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/figtree-var/figtree-var.woff2') format('woff2-variations'),
            url('/assets/fonts/figtree-var/figtree-var.ttf') format('truetype-variations');
    font-weight: 300 900;
    font-display: swap;
        
}
.font-primary { font-family: 'font-primary', sans-serif; font-style: normal; }
.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; }

/* Figtree Var Italic */
@font-face {
    font-family: 'font-primary';
    src:    url('/assets/fonts/figtree-var/figtree-var-italic.woff2') format('woff2-variations'),
            url('/assets/fonts/figtree-var/figtree-var-italic.ttf') format('truetype-variations');
    font-weight: 300 900;
    font-display: swap;
    font-style: italic; 
}
.font-primary-i { font-family: 'font-primary', sans-serif; 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; }

/* Hughs 400 */
@font-face { font-family: 'font-script'; src: url('/assets/fonts/hughs/hughs-400.woff2') format('woff2'), url('/assets/fonts/hughs/hughs-400.woff') format('woff'), url('/assets/fonts/hughs/hughs-400.ttf') format('truetype'); font-weight: 400; font-style: normal; font-display: swap; }
.font-script-400 { font-family: 'font-script', sans-serif; font-style: normal; font-weight: 400; }


/*--------------------------------------------------------------------------- */
/* 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(--primary-mid);
    outline-offset: 2px;
}
@media (prefers-reduced-motion: no-preference) {
    html {
        interpolate-size: allow-keywords;
        scroll-behavior: smooth;
    }
}
@media (prefers-reduced-motion: reduce) {
    * {
        animation-duration: 0.001ms !important;
        animation-delay: 0ms !important;
        transition-duration: 0.001ms !important;
        transition-delay: 0ms !important;
    }
}

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-semibold);
}

/*--------------------------------------------------------------------------- */
/* MARK: HTML/BODY
*/

html {
    background-color: var(--white);
    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 {
    --logoMaxWidth: 10rem;
    align-items: center;
    background-color: white;
    border-bottom: 1px solid var(--neutral-light);
    display: flex;
    flex-direction: column;
    position: sticky;
    left: 0; right: 0; top: 0;
    text-align: center;
    z-index: 99;
}



.header-spacer {
    background-color: var(--themeBg, var(--neutral));
}

.courtesy-header {
    background-color: var(--primary-dark);
    color: white;
    display: flex;
    flex-wrap: wrap;
    font-size: var(--text-sm);
    gap:  0 var(--space-md);
    justify-content: center;
    padding: var(--space-xs) var(--space-sm);
    width: 100%;
}
@media screen and (min-width: 36rem) {
    .courtesy-header {
        justify-content: space-between;
    }
}
.courtesy-header ul {
    display: flex;
    gap: var(--space-sm);
    list-style: none;
    padding: 0;
}
.courtesy-header a {
    color: white;
}

.site-header .masthead {
    align-items: center;
    color: var(--neutral);
    display: grid;
    grid-template-columns: var(--logoMaxWidth) auto;
    grid-template-areas: "logo toggles";
    width: 100%;
    z-index: 5;
}
.site-header .masthead .logo {
    align-items: center;
    display: block;
    border-radius: 0.25rem;
    grid-area: logo;
    margin: var(--space-sm);
    overflow: hidden;
    padding: 0;
    transition: all 0.2s ease-in-out;
    width: calc(var(--logoMaxWidth) - calc(2 * var(--space-sm)));
}

.site-header .masthead .toggles {
    grid-area: toggles;
    height: 100%;
    display: flex;
    flex-wrap: nowrap;
    margin-left: auto;
    max-width: calc(var(--logoMaxWidth) + var(--space-lg) );
    transition: all 0.2s ease-in-out;
    width: 100%;
}

.site-header .masthead .search-toggle {
    align-items: center;
    border-left: 1px solid var(--neutral-light);
    color: var(--neutral);
    display: flex;
    flex-direction: column;
    font-weight: var(--font-weight-medium);
    font-size: var(--text-sm);
    gap: var(--space-xs);
    grid-area: search;
    height: 100%;
    justify-content: center;
    transition: all 0.2s ease-in-out;
    text-decoration: none;
    width: 50%;
}

.mobile-nav {
    display: none; /* drawer nav */
}

.mobile-nav-toggle {
    align-items: center;
    justify-content: center;
    background-color: transparent;
    border: 0;
    border-left: 1px solid var(--neutral-light);
    border-radius: 0;
    color: var(--neutral);
    cursor: pointer;
    display: flex;
    flex-direction: column;
    font-weight: var(--font-weight-medium);
    font-size: var(--text-sm);
    gap: var(--space-xs);
    grid-area: mobile;
    height: 100%;
    line-height: 1;
    margin: 0;
    padding: 0;
    text-align: right;
    transition: all 0.2s ease-in-out;
    width: 50%;
}

.site-nav {
    display: none; /* for mobile */
}

/* swap to the full navigation bar */
@media screen and (min-width: 64rem) {

    .mobile-nav-toggle {
        display: none;
    }
    .site-header .masthead {
        gap: 0;
        grid-template-columns: var(--logoMaxWidth) auto var(--logoMaxWidth);
        grid-template-areas: "logo nav toggles";
    }
    .site-header .masthead .logo {
        margin-right: 0;
        width: calc(var(--logoMaxWidth) - calc(1 * var(--space-sm)));
    }

    .site-nav {
        display: flex;
        align-items: center;
        justify-content: center;
        grid-area: nav;
        padding: 0;
        height: 100%;
        width: 100%;
        z-index: 5;
    }
    .site-header .masthead .search-toggle {
        width: 100%;
    }
    .site-header.is-stuck {
        --logoMaxWidth: 10rem;
    }

    /* the parent menu and primary nav items */
    .site-nav > .menu {
        align-items: center;
        display: flex;
        gap: 0;
        flex-wrap: nowrap;
        font-size: var(--text-nav);
        font-weight: 600;
        height: 100%;
        justify-content: space-evenly;
        line-height: 1.2;
        list-style: none;
        padding: 0 var(--space-sm);
        max-width: 64rem;
        width: 100%;
    }
    .site-nav > .menu.omega-btn > li:last-of-type {
        background-color: var(--accent);
    }
    .site-nav > .menu > li {
        display: block;
        height: 100%;
    }
    .site-nav > .menu > li.tab-active {
        background-color: var(--accent);
    }
    .site-nav > .menu > li > a {
        align-items: center;
        display: flex;
        color: var(--neutral);
        padding-inline: var(--space-xs);
        height: 100%;
        text-decoration: none;
    }

    /* the drop-down menu and kids */
    .site-nav .submenu {
        --columnCount: 1;
        --offset: var(--space-sm);
        background-color: white;
        border-bottom: 2px solid var(--accent);
        border-radius: var(--radius-sm);
        box-shadow: 0 var(--space-xs) var(--space-md) rgba(0, 0, 0, 0.2);
        display: none;
        gap: var(--space-md);
        grid-template-columns: repeat(var(--columnCount), 1fr);
        left: var(--offset);
        list-style: none;
        padding: var(--space-md);
        position: absolute;
        right: var(--offset);
        text-align: left;
        top: calc(100% - var(--space-xs));
        max-width: 75rem;
        margin-inline: auto;
        z-index: 99;
    }
    .site-nav .submenu > li > a,
    .site-nav .submenu > li > span {
        border-bottom: 1px solid var(--neutral-light);
        color: var(--neutral);
        display: block;
        margin-bottom: var(--space-xs);
        padding: var(--space-xs);
    }
    .site-nav .subsubmenu {
        display: grid;
        font-family: 'font-primary';
        list-style: none;
        padding: 0;
    }
    .site-nav .subsubmenu > li > a,
    .site-nav .subsubmenu > li > span {
        color: var(--neutral);
        display: block;
        font-size: var(--text-sm);
        font-weight: 400;
        padding: 0.3125rem var(--space-xs);
        text-decoration: none;
    }

    .site-nav .subsubmenu > li > a:hover {
        background-color: var(--accent-light);
    }
}
@media screen and (min-width: 90rem) {
    .site-header {
        --logoMaxWidth: 12rem;
    }

}


/*--------------------------------------------------------------------------- */
/* MARK: Site Page Title
*/

.page-title {
    background-color: var(--themeBg, var(--neutral));
    background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="32" height="32"><filter id="n"><feTurbulence baseFrequency="0.9" numOctaves="2" stitchTiles="stitch"/><feColorMatrix type="saturate" values="0"/><feComponentTransfer><feFuncA type="table" tableValues="0 0.04"/></feComponentTransfer></filter><rect width="100%" height="100%" filter="url(#n)" fill="#ce0000"/></svg>');
    background-blend-mode: overlay;
    background-size: auto;
    color: var(--themeTextOnBg, white);
    display: grid;
    gap: var(--space-base);
    padding: var(--space-huge) var(--gutter) var(--space-huge) var(--gutter);
    position: relative;
    text-align: center;
    border-radius: 0 0 var(--gutter) var(--gutter);
}

.page-title > * {
    position: relative;
    z-index: 2;
}
.page-title h1 {
    max-width: var(--max-sm);
    margin-inline: auto;
    position: relative;
}
.page-title h1::before,
.page-title h1::after {
    content: '';
    background-color: var(--accent);
    display: block;
    height: 0.3125rem;
    width: 75%;
    margin-inline: auto;
}
.page-title h1::before {
    margin-bottom: var(--space-md);
}
.page-title h1::after {
    margin-top: var(--space-md);
}

.page-title a {
    color: var(--white);
    text-decoration-thickness: 2px;
}
.page-title a:hover {
    color: var(--accent-dark);
}
.page-lede {
    font-weight: 500;
    margin-inline: auto;
    max-width: var(--max-sm);
}

.page-title .rtbform {
    align-items: center;
    display: grid;
    grid-template-columns: auto max-content;
    max-width: var(--max-xs);
    margin-inline: auto;
    width: 100%;
}
.page-title .rtbform > * {
    height: 100%;
}
.page-title .rtbform .btn {
    align-items: center;
    gap: var(--space-xs);
    display: flex;
}

/*--------------------------------------------------------------------------- */
/* MARK: Themes
*/

body {
    /* themes */
    --rentals:          var(--primary-dark);
    --landscape:        #4B763C;
    --hardscape:        #576174;
    --bulk:             #6A685F;
    --construction:     #F2AC2E;
    --commercial:       var(--accent-dark);
    --delivery:         var(--secondary-dark);
    --services:         #5E4352;

    --themeTextOnBg:        var(--white);
    --themeTextOnLightBg:   var(--themeBg, white);

}

/* site controller sets a class on the body */
.theme-default {
    --themeBg: var(--primary);
}
.theme-rentals {
    --themeBg: var(--rentals);
}
.theme-landscaping {
    --themeBg: var(--landscape);
}
.theme-hardscaping {
    --themeBg: var(--hardscape);
}
.theme-construction {
    --themeBg: var(--construction);
    --themeTextOnBg: var(--neutral);
    --themeTextOnLightBg: var(--neutral);
}
.theme-bulk {
    --themeBg: var(--bulk);
}
.theme-delivery {
    --themeBg: var(--delivery);
}
.theme-commercial {
    --themeBg: var(--commercial);
    --themeTextOnBg: var(--neutral);
    --themeTextOnLightBg: var(--neutral);
}
.theme-services {
    --themeBg: var(--services);
}

/*--------------------------------------------------------------------------- */
/* MARK: Site MAIN
*/

main {
    display: flex;
    flex-direction: column;
}
main > * {
    margin-block: 0;
}

.padded {
    padding: var(--space-xxl) var(--gutter);
}
.padded > .inner {
    margin-inline: auto;
    max-width: var(--max-xl);
}

.p0-t {
    padding-top: 0;
}
.p0-b {
    padding-top: 0;
}

/*--------------------------------------------------------------------------- */
/* MARK: Site FOOTER
*/

.site-footer {
    font-size: var(--text-sm);
    padding: var(--space-xxl) var(--space-sm) var(--space-sm);
    position: relative;
    text-align: center;
}

.site-footer::before {
    /* background-color: var(--themeBg, var(--neutral)); */
    background-color: var(--neutral-bg);
    content: '';
    /* filter: saturate(2); */
    inset: 0;
    /* opacity: 0.05; */
    position: absolute;
    transition: filter 500ms ease, opacity 280ms cubic-bezier(.4,0,.2,1);
    z-index: 1;
}

.site-footer > * {
    position: relative;
    z-index: 2;
}

.site-footer .search-form {
    display: flex;
    gap: var(--space-xs);
    justify-content: center;
    margin-inline: auto;
    max-width: 24rem;
    width: 100%;
}

.site-footer .search-form-input {
    border: 1px solid var(--neutral-mid);
    background-color: white;
    border-radius: var(--radius-sm);
    padding: var(--space-xs);
    width: 100%;
}

.site-footer .site-footer-wrap {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    display: grid;
    overflow: hidden;
}

.site-footer .footer-nav-wrap {
    background-color: white;
    border-bottom: 1px solid var(--neutral-light);
    display: grid;
    gap: var(--space-base);
    padding: var(--space-base);
}

.site-footer .footer-nav-title {
    font-size: var(--text-sm);
    font-weight: 600;
    margin-bottom: var(--space-xs);
    text-transform: uppercase;
}
.site-footer .footer-nav-ul {
    line-height: 1.1;
    list-style: none;
    padding: 0;
}
.site-footer .footer-nav-link {
    display: inline-block;
    padding-block: var(--space-xs);
    text-decoration: none;
}

.site-footer .footer-contact-wrap {
    align-content: center;
    background-color: white;
    display: grid;
    gap: var(--space-sm);
    padding: var(--space-sm);
}
.site-footer .footer-logo {
    border-radius: 0.25rem;
    display: block;
    margin-inline: auto;
    overflow: hidden;
    width: 8rem;
}
.site-footer .footer-contact {
    list-style: none;
    padding: 0;
}

.site-footer .footer-social {
    align-items: center;
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-md);
    justify-content: center;
}
.site-footer .footer-social a {
    color: var(--neutral-mid);
    text-decoration: none;
}
.site-footer .footer-social svg {
    height: var(--space-lg);
    width: var(--space-lg);
}
.site-footer .footer-social a:hover {
    color: var(--accent-dark);
}

.site-footer .footer-meta {
    font-size: var(--text-sm);
    padding-top: var(--space-sm)
}

@media screen and (min-width: 36rem) {
    .site-footer .footer-nav-wrap {
        grid-template-columns: repeat(3, 1fr);
        text-align: left;
    }
    .site-footer .footer-meta {
        display: flex;
        justify-content: space-between;
    }
}
@media screen and (min-width: 64rem) {
    .site-footer {
        padding-inline: var(--gutter)
    }
    .site-footer .site-footer-wrap {
        grid-template-columns: 3fr 1fr;
    }
    .site-footer .footer-nav-wrap {
        border: 0;
    }
    .site-footer .footer-contact-wrap {
        border-left: 1px solid var(--neutral-light);
    }
}

.back-to-top-link {
    text-transform: uppercase;
    font-weight: 500;
}

/*--------------------------------------------------------------------------- */
/* MARK: ROWS
*/

.row {
    --bg: transparent;
    background-color: var(--bg);
    border-bottom: 1px solid var(--neutral-light);
    /* border: 1px dashed salmon; */
    padding: var(--space-xxl) var(--gutter); /* top/bottom padding (xxl) relates to the more/less classes below */
    position: relative;
}
.row.top-pad-none       { padding-top:      0; }
.row.bot-pad-none       { padding-bottom:   0; }
.row.top-pad-less       { padding-top:      var(--space-lg); }
.row.bot-pad-less       { padding-bottom:   var(--space-lg); }      /* lg is half the xxl size */
.row.top-pad-more       { padding-top:      var(--space-mega); }    /* mega is twice the xxl size */
.row.bot-pad-more       { padding-bottom:   var(--space-mega); }

.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:nth-of-type(even) {
    /* background-color: var(--neutral-bg); */
}


/*--------------------------------------------------------------------------- */
/* MARK: COLUMNS
*/

.columns {
    display: grid;
    gap: var(--space-md) var(--space-xl);
    margin-inline: auto;
}
@media screen and (min-width: 48rem) {
    .columns {
        grid-template-columns: repeat(12, 1fr);
    }
    .columns .column {
        grid-column: span var(--span);
    }
}
.columns .column {
    /* border: 1px solid powderblue; */
    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%;
}

/*--------------------------------------------------------------------------- */
/* MARK: AutoGrid
*/

.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: 5;
    --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-base); }
h5 { font-size: var(--text-base); }
h6 { font-size: var(--text-sm); }

h1, h2, h3, h4, h5, h6 {
    /* font-family: 'font-primary', system-ui, sans-serif; */
    font-family: 'font-primary', 'font-primary', system-ui, sans-serif;
    font-weight: var(--font-weight-medium);
    letter-spacing: -0.01em;
    line-height: 1.2;
}

/*--------------------------------------------------------------------------- */
/* MARK: Paragraphs
*/

.lede {
    font-size: var(--text-md);
}

.kicker {
    font-family: 'font-script';
    font-size: var(--text-lg);
    font-weight: 400;
    letter-spacing: 0.05em;
    line-height: 1.1;
}

.callout {
    background-color: var(--accent-light);
    border: 1px solid var(--accent-dark);
    border-radius: var(--radius-base);
    padding: var(--space-base);
}
.callout.text-sm {
    padding: var(--space-sm);
}

/*--------------------------------------------------------------------------- */
/* MARK: Lists
*/

ol, ul {
    padding-left: var(--space-lg);
}

/*--------------------------------------------------------------------------- */
/* MARK: Figures/Images
*/

figure figcaption {
    font-size: var(--space-sm);
    padding: var(--text-sm);
    padding-bottom: 0;
    text-align: center;
}

img {
    height: auto;
}

/*--------------------------------------------------------------------------- */
/* MARK: HR
*/

hr {
    border: 0;
    padding: 0;
    height: 1px;
    background-color: var(--neutral-mid);
    width: 100%;
    display: block;
}

/*--------------------------------------------------------------------------- */
/* MARK: Blockquote
*/

blockquote footer {
    font-style: italic;
}
blockquote footer::before {
    content: ' — ';
}

/*--------------------------------------------------------------------------- */
/* MARK: Links
*/

a {
    color: var(--primary);
    text-decoration-color: var(--accent-dark);
}
a:hover {
    color: var(--secondary);
}

/*--------------------------------------------------------------------------- */
/* MARK: Buttons
*/

.btns {
    display: flex;
    gap: var(--space-xs) var(--space-sm);
    flex-wrap: wrap;
}



.btn {
    --btnBackground: var(--accent);
    --btnBorder: var(--accent-dark);
    --btnRadius: var(--radius-base);
    appearance: none;
    background-color: var(--btnBackground);
    border: 1px solid var(--btnBorder);
    border-radius: var(--btnRadius);
    color: var(--neutral);
    cursor: pointer;
    display: inline-block;
    line-height: 1;
    padding: var(--space-sm);
    text-align: center;
    text-decoration: none;
}

.btn.btn-outline {
    background-color: transparent;
}
.btn.btn-outline:hover {
    background-color: var(--primary-bg);
    color: var(--primary);
}
.btn.simple {
    --btnBackground: transparent;
}
.btn.subtle {
    --btnBackground: var(--accent-bg);
}
.btn:hover {
    --btnBackground: var(--primary);
    --btnBorder: var(--primary);
    color: var(--white);
}

/*--------------------------------------------------------------------------- */
/* MARK: BLOCKS
*/

/* leave a gap here to make the sidebar nav useful */





/*--------------------------------------------------------------------------- */
/* MARK: Portal Block
*/

.portal {
    --auto-grid-min-size: 14rem;
    --auto-grid-max-columns: 5;
    --auto-grid-gap: var(--space-md);
    --auto-grid-gap-vertical: var(--space-xl);

    display: grid;
    gap: var(--space-xl) var(--space-md);
    list-style: none;
    padding: 0;
}
.portal-card {
    border-radius: var(--radius-base);
    border: 1px solid var(--themeBg);
    container-type: inline-size;
    display: block;
    overflow: hidden;
    padding: 0;
    position: relative;
}
.portal-card::before {
    background-color: var(--themeBg, var(--neutral));
    content: '';
    filter: saturate(3);
    inset: 0;
    opacity: 0.05;
    position: absolute;
    transition: filter 500ms ease, opacity 280ms cubic-bezier(.4,0,.2,1);
    z-index: 1;
}
.portal-card > * {
    margin-block: 0;
    position: relative;
    z-index: 2;
}
/* wraps the full card! this is the direct child of the li */
.portal-card .link {
    color: var(--themeTextOnLightBg);
    display: flex;
    flex-direction: column;
    height: 100%;
    text-decoration: none;
    transition: color 140ms ease;
    text-align: center;
}

.portal-card img {
    aspect-ratio: 4/3;
    background-color: white;
    border-bottom: 1px solid var(--themeBg, var(--neutral));
    border-radius: var(--radius-base) var(--radius-base) 0 0;
    grid-area: img;
    filter: saturate(1.1) contrast(1.1) brightness(0.95);
    object-fit: contain;
    transition: opacity 280ms cubic-bezier(.4,0,.2,1);
    width: 100%;
}
.portal-card .text {
    margin-block: auto;
    grid-area: text;
    padding: var(--space-base);
}
.portal-card .heading {
    font-size: var(--text-md);
    font-weight: var(--font-weight-semibold);
    text-wrap: initial;
}

.portal-card .link:hover {
    color: var(--white);
}

.portal-card:hover::before {
    filter: saturate(1);
    opacity: 1;
}


@container (width < 18rem ) {
    .portal-card img {
        aspect-ratio: 1;
        object-fit: cover;
    }

}
@container (width > 20rem ) {
    .portal-card img {
        aspect-ratio: 5/3;
    }
}


@container (width > 24rem ) {
    .portal, .search-results {
        grid-template-columns: repeat(2, 1fr);
    }
}
@container (width > 48rem ) {
    .portal, .search-results {
        grid-template-columns: repeat(3, 1fr);
    }
}
@container (width > 60rem ) {
    .portal, .search-results {
        grid-template-columns: repeat(4, 1fr);
    }
}
@container (width > 72rem ) {
    .search-results {
        grid-template-columns: repeat(5, 1fr);
    }
}
@container (width > 84rem ) {
    .portal {
        grid-template-columns: repeat(5, 1fr);
    }
    .search-results {
        grid-template-columns: repeat(6, 1fr);
    }
}

/*--------------------------------------------------------------------------- */
/* MARK: Portal Themes
*/




/*--------------------------------------------------------------------------- */
/* MARK: Image Block
*/

.image-block img {
    aspect-ratio: var(--ratio);
    object-fit: contain;
}

/*--------------------------------------------------------------------------- */
/* MARK: Accordions Block / FAQs
*/

summary {
    cursor: pointer;
    font-weight: var(--font-weight-semibold);
}

.accordions {
    display: grid;
    gap: var(--space-xs);
}
.accordion {
    border: 1px solid var(--neutral-mid);
    border-radius: var(--radius-base);
}
.accordion:hover {
    background-color: var(--accent-bg);
    border-color: var(--accent);
}
.accordion > .question {
    padding: var(--space-base);
}
.accordion > .answer {
    display: grid;
    gap: var(--space-sm);
    padding: var(--space-base);
}

.accordion > .answer :is(h2, h3) {
    font-size: var(--text-md);
}
.accordion > .answer :is(h4, h5, h6) {
    font-size: var(--text-base);
    font-weight: var(--font-weight-semibold);
}

/*--------------------------------------------------------------------------- */
/* MARK: Video Block
*/

.video-block > * {
    width: 100%;
}
.video-block iframe {
    aspect-ratio: 16/9;
    background-color: var(--neutral-light);
    border: 0;
    border-radius: var(--radius-sm);
    outline: 2px solid var(--neutral-mid);
    outline-offset: 2px;
}

/*--------------------------------------------------------------------------- */
/* MARK: Item Details (bulk-item, collection-item, collection, rental-item
*/

/* the outer wrap for each item */
.item-detail {
    align-items: start;
    display: grid;
    gap: var(--space-xl);
}

.item-detail .buttons {
    --auto-grid-min-size: 6rem;
    --auto-grid-gap: var(--space-sm);
    --auto-grid-gap-vertical: var(--space-sm);
    grid-column: 1 / -1;
}
.item-detail .buttons .btn {
    align-content: center;
    text-align: center;
}

.item-detail > * {
    /* border: 1px dashed red; */
}

.item-detail .image-col {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    grid-column: 1 / -1;
    overflow: hidden;
}
.item-detail .image-col img {
    aspect-ratio: 3/2;
    filter: brightness(0.9) contrast(1.1) saturate(1.1);
    object-fit: contain;
    object-position: center;
    width: 100%;
}
.item-detail .overview {
    display: grid;
    gap: var(--space-base);
}
.item-detail .overview > * {
    /* border: 1px solid pink; */
}
.item-detail .overview .code strong,
.item-detail .rate-set .code strong {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-sm);
    display: inline-block;
    line-height: 1;
    padding: var(--space-xs) var(--space-sm);
}

.item-detail .overview .description {
    display: grid;
    gap: var(--space-base);
}
.item-detail .overview .description > * {
    /* border: 1px solid greenyellow; */
}

.item-detail .overview .description * + :is(h2, h3, h4, h5) {
    /* background-color: red; */
}

.item-detail .rates {
    display: grid;
    gap: var(--space-base);
}

.item-detail .specs {
    display: grid;
    gap: var(--space-base);
}

.item-detail .rates-list {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    container-type: inline-size;
    line-height: 1.309;
    list-style: none;
    padding: var(--space-xs);
}

.item-detail .rates-list > li {
    display: grid;
    padding: var(--space-xs);
}

@container (width > 32rem ) {
    .item-detail .rates-list > li {
        gap: var(--space-sm);
        grid-template-columns: max-content auto;
    }
    .item-detail .rates-list > li .value,
    .item-detail .rates-list > li .price {
        text-align: right;
    }
}

.item-detail .rates-list > li:hover {
    background-color: var(--neutral-bg);
}

.item-detail .rates-list > li:not(:last-of-type) {
    border-bottom: 1px solid var(--neutral-light);
}

.item-detail .rate-set {
    display: grid;
    gap: var(--space-xs);
}
.item-detail .rate-set h3 {
    font-size: var(--text-md);
    font-weight: var(--font-weight-semibold);
}

.collection-meta {
    display: flex;
    column-gap: var(--space-base);
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
}
.collection-brand {
    font-size: var(--text-md);
}
.collection-items {
    container-type: inline-size;

}
.collection-gallery {
    list-style: none;
    padding: 0;
}

.collection-gallery img {
    aspect-ratio: 2/1;
    border-radius: var(--radius-sm);
    filter: brightness(0.95) contrast(1.1) saturate(1.1);
    object-fit: cover;
    height: 100%;
    width: 100%;
}



.bulk-detail .bulk-callout {
    display: grid;
    gap: var(--space-sm);
    grid-column: 1 / -1;
    text-align: center;
}

.rental-overview .features {
    font-weight: var(--font-weight-bold);
}

.related-items {
    display: grid;
    gap: var(--space-base);
    
}

.swatches {
    align-items: start;
    --auto-grid-min-size: 8rem;
    --auto-grid-max-columns: 6;
    font-size: var(--text-sm);
    list-style: none;
    padding: 0;
}
.swatches .swatch {
    align-content: start;
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    display: grid;
    gap: var(--space-xs);
    height: 100%;
    padding: var(--space-base);
    text-align: center;
}
.swatches img {
    aspect-ratio: 1;
    border-radius: var(--radius-sm);
    display: block;
    object-fit: cover;
    height: 100%;
    margin-inline: auto;
    max-width: 10rem;
    width: 100%;
}
.swatches img.fallback {
    background-color: var(--neutral-bg);
}

/* 1024px */
@media screen and (min-width: 64rem) {
    .item-detail {
        grid-template-columns: repeat(2, 1fr);
        column-gap: var(--space-xxl);
    }
    .collection-detail > * {
        grid-column: 1 / -1 !important;
    }
}
/* 1280px */
@media screen and (min-width: 80rem) {
    .item-detail {
        grid-template-columns: repeat(4, 1fr);
    }
    .item-detail .image-col {
        grid-column: span 3;
    }
    .item-detail .image-col img {
        aspect-ratio: 2/1;
    }
    .item-detail .buttons {
        --auto-grid-max-columns: 1;
        grid-column: span 1;
    }
    .item-detail .overview {
        grid-column: span 2;
    }
    .item-detail .rates {
        grid-column: span 2;
    }
    .item-detail .specs {
        grid-column: span 2;
    }

}
/* 1440px */
@media screen and (min-width: 90rem) {
}

/*--------------------------------------------------------------------------- */
/* MARK: Tables
*/

table {
    border-collapse: collapse;
    text-align: left;
    width: 100%;
}
thead {
    background-color: var(--neutral);
    color: white;
}
thead a {
    color: white;
}
thead th {
    font-weight: var(--font-weight-bold);
}
tr:nth-child(even) {
    background-color: var(--neutral-bg);
}
th {
    font-weight: var(--font-weight-regular);
}
th, td {
    padding: var(--space-base);
}

/*--------------------------------------------------------------------------- */
/* MARK: Shopping List
*/



.shopping-list-link {
    display: inline-block;
    text-decoration: none;
    min-width: 2rem;
}

.shopping-list {
    display: grid;
    gap: var(--space-base);
}

.shopping-list .my-list {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    display: grid;
    gap: var(--space-base);
    padding: var(--space-base);
    padding-top: var(--space-md);

}

.sl-actions {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    align-items: start;
    display: flex;
    gap: var(--space-xs);
    padding: var(--space-base);
    justify-content: end;
}

.sl-customer-notes {
}

#sl-items {
    display: grid;
    gap: var(--space-xxs);
}

.sl-item {
    align-items: center;
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-sm);
    display: grid;
    gap: var(--space-sm);
    padding: var(--space-base);
}

.sl-item > * {
    /* border: 2px dashed red !important; */
}

.sl-notes {
    display: none;
}
.sl-notes > label {
    display: flex;
    align-items: start;
}
.sl-notes textarea {
    display: block;
    width: 100%;
}
.sl-customer-notes > label {
    display: block;
}
.sl-customer-notes > textarea {
    display: block;
    width: 100%;
}

.sl-summary {
    font-weight: var(--font-weight-bold);
    padding: 0;
    text-align: right;
}
.sl-title {
    font-weight: var(--font-weight-bold);
}
.sl-qty {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    gap: var(--space-base);
    justify-items: end;
}
.sl-qty-controls {
    display: flex;
    gap: 0;
}
.sl-qty-controls input {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    border-radius: 0;
    box-shadow: 0;
    font-family: inherit;
    font-size: inherit;
    padding: var(--space-xs);
    width: 100%;
}
.sl-decrement, .sl-increment {
    border-color: var(--neutral-light);
    border-radius: var(--radius-base);
    padding-inline: var(--space-xs);
}
.sl-decrement {
    border-right-width: 0;
    border-top-right-radius: 0;
    border-bottom-right-radius: 0;
}
.sl-increment {
    border-left-width: 0;
    border-top-left-radius: 0;
    border-bottom-left-radius: 0;
}

.sl-thumb {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    overflow: hidden;
}
.sl-thumb a {
    display: block;
}
.sl-thumb img {
    aspect-ratio: 1;
    height: 100%;
    margin-inline: auto;
    object-fit: cover;
    max-width: 9rem;
    width: 100%;
}

.sl-qty-input {
    width: auto;
    max-width: 6rem;
}
.sl-qty-controls {
    display: flex;
    flex-wrap: nowrap;
}


/*--------------------------------------------------------------------------- */
/* MARK: Delivery Rates
*/

* + .delivery-rates {
    margin-top: var(--space-base);
}

.delivery-rates {
    border-radius: var(--radius-base);
    display: grid;
    gap: var(--space-xs);
    overflow: hidden;
}
.delivery-rates tr {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    display: grid;
}
.delivery-rates thead {
    border-radius: var(--radius-base);
}

.delivery-rates thead tr {
    border: 0;
}

.delivery-rates thead th:not(:first-child) {
    display: none;
}
.delivery-rates tbody {
    display: grid;
    gap: var(--space-xs);
}

.delivery-rates tbody td {
    padding-top: 0;
}
.delivery-rates .mobile-only-label {
    color: var(--neutral);
    display: inline-block;
    font-weight: var(--font-weight-bold);
    min-width: 5rem;
}

.delivery-rates h3 {
    font-size: var(--text-base);
    font-weight: var(--font-weight-bold);
}
.delivery-rates h3 + * {
    margin-top: var(--space-xs);
}

.delivery-rates .details {
    font-size: var(--text-sm);
}

.delivery-detail .delivery-notes,
.delivery-detail .buttons {
    margin-top: var(--space-xs);
}

.zone-calculator {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    display: grid;
    gap: var(--space-base);
    padding: var(--space-sm);
}
.zone-calculator > .form-row {
    align-items: center;
    display: flex;
    gap: var(--space-sm);
}
.zone-calculator label {
    text-wrap: nowrap;
}
.zone-calculator-results {
    align-items: center;
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-light);
    border-radius: 0 0 var(--radius-base) var(--radius-base);
    border-top: 0;
    display: grid;
    gap: var(--space-xs);
    grid-template-columns: auto 1fr;
    padding: var(--space-sm);
}
.zone-calculator-results > :nth-child(2) {
    font-size: var(--text-md);
    font-weight: 500;
}
.zone-calculator-results .badge {
    background-color: var(--accent);
    display: inline-block;
    padding-inline: var(--space-xs);
}

/*--------------------------------------------------------------------------- */
/* MARK: LRC Landscape Recycling Centre
*/

lrc-bin {
    background-color: var(--neutral-bg);
    display: grid;
}
lrc-bin :is(h2, h3, h4) + * {
    margin-top: var(--space-xs);
}
lrc-bin > * {
    padding: var(--space-base);
}
lrc-bin > header {
    background-color: var(--neutral-light);
}

@media screen and (min-width: 48rem) {
    lrc-bin {
        grid-template-areas: 
        "header header header"
        "binA binB binC"
        ;
        grid-template-columns: repeat(3, 1fr);
    }
    lrc-bin > header {
        grid-area: header;
    }
}

/*--------------------------------------------------------------------------- */
/* MARK: Forms
*/

.rtbform {
    container-type: inline-size;
    display: grid;
    gap: var(--space-sm);
}
.rtbform .uniform-potty {
    position: absolute;
    left: -9999px;
}
.rtbform select {
    display: block;
}
.rtbform input:is([type="number"], [type="text"], [type="email"], [type="search"]),
.rtbform textarea {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-mid);
    border-radius: var(--radius-sm);
    box-shadow: 0;
    font-family: inherit;
    font-size: inherit;
    padding: var(--space-xs);
    width: 100%;
}

.rtbform select {
    background-color: var(--neutral-bg);
    border: 1px solid var(--neutral-mid);
    border-radius: var(--radius-sm);
    display: block;
    max-width: 32rem;
    width: 100%;
}


.rtbform .form-row.side-x-side {
    display: grid;
    gap: var(--space-sm);
}

@container (width > 36rem ) {
    .rtbform .form-row.side-x-side {
        grid-template-columns: repeat(2, 1fr);
    }
}


.rtbform textarea {
    min-height: 6rem;
}

.rtbform .form-row .submit-btn {
    align-self: flex-end;
    justify-self: end;
}

.rtbform fieldset {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    display: grid;
    gap: var(--space-sm);
    padding: var(--space-base);
}

/*--------------------------------------------------------------------------- */
/* MARK: Search & Search Results
*/

/* -------------------------------------------------------------------------- */
/* MARK: Search
*/

.search-modal {
    cursor: zoom-out;
    display: none;
    position: fixed;
    z-index: 1000;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: auto;
    background-color: rgba(0, 0, 0, 0.6);
    backdrop-filter: blur(0.5rem);
}

.search-modal-content {
    cursor: default;
    background-color: white;
    border-radius: var(--radius-sm);
    margin: auto;
    max-width: 100%;
    min-width: 30rem;
    padding: var(--space-base);
    position: relative;
    width: 50%;
}

.search-modal .search-form {
    display: flex;
    flex-wrap: nowrap;
    gap: var(--space-base);
    width: calc(100% - 3.75rem);
}
.search-modal .search-form-input {
    max-width: none;
    padding: var(--space-xs);
    width: 100%;
}

.search-modal .search-form-btn {
    --btnBackground: var(--primary);
    color: white;
}
.search-modal .search-form-btn:hover {
    --btnBackground: var(--primary-mid);
}

.search-close {
    position: absolute;
    top: 50%;
    margin-top: -20px;
    right: 20px;
    color: var(--neutral);
    font-size: 2.5rem;
    height: 2.5rem;
    width: 2.5rem;
    font-weight: bold;
    line-height: 2.1875rem;
    cursor: pointer;
    text-align: center;
}

.modal-hidden {
    display: none !important;
}

.search-results {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: var(--space-base);
    list-style: none;
    margin-top: var(--space-md);
    padding: 0;
    max-width: 100%;
}

.sr-link {
    border: 1px solid var(--neutral-light);
    border-radius: var(--radius-base);
    justify-items: start;
    display: flex;
    flex-direction: column;
    gap: var(--space-xs);
    height: 100%;
    padding: var(--space-xs);
    text-decoration: none;
}

.sr-link:hover {
    background-color: var(--accent-bg);
    border-color: var(--accent);
}

.sr-link h3 {
    font-size: var(--text-base);
    margin-bottom: var(--space-md);
}

.sr-parent {
    color: var(--neutral);
    display: block;
    font-size: 60%;
    line-height: 1;
    margin-top: auto;
}

.sr-img {
    background-color: var(--neutral-bg);
    border-radius: var(--radius-sm);
    aspect-ratio: 1;
    object-fit: cover;
    filter: brightness(0.95);
    width: 100%;
}


/*--------------------------------------------------------------------------- */
/* MARK: Yard Calculator
*/

.yard-calculator {
    align-items: start;
    display: grid;
    gap: var(--space-xl);
}
@media screen and (min-width: 48rem) {
    .yard-calculator {
        grid-template-columns: repeat(2, 1fr);
    }
}
.yard-calculator .rtbform {
    border: 1px solid var(--neutral-light);
    padding: var(--space-base);

}
.yard-calculator .results {
    align-content: start;
    background-color: var(--accent-light);
    display: grid;
    gap: var(--space-sm);
    height: 100%;
    padding: var(--space-base);
}
.yard-calculator .result-ft3 {
    opacity: 0.5;
}

/*--------------------------------------------------------------------------- */
/* MARK: Utility Classes
*/

.skiplink {
	position: absolute;
	transform: translateX(-100%);
	background-color: white;
	z-index: 999;
	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-xs                          { max-width: var(--max-xs); }
.max-sm                          { max-width: var(--max-sm); }
.max-md                          { max-width: var(--max-md); }
.max-lg                          { max-width: var(--max-lg); }
.max-xl                          { max-width: var(--max-xl); }
.max-xxl                         { max-width: var(--max-xxl); }

.none { display: none; }

.noise {
	background-image: url('/assets/img/noise.svg');
	background-repeat: repeat;
	background-position: left top;
	background-size: 700px;
}


@media print {
    * {
	background: transparent !important;
	color: #000 !important; /* Black prints faster: h5bp.com/s */
	box-shadow: none !important;
	text-shadow: none !important;
    }

    /* shopping list */

    .sl-item { display: flex; width: 100%; }
    .sl-actions,
    .sl-item .btn { display: none; }
    .sl-thumb { width: 4rem; }
    .sl-qty { margin-left: auto; }


    .site-nav,
    .site-header .masthead .toggles,
    .site-footer { display: none; }
    .site-header .masthead {
        display: block;
    }
    .site-header .masthead .logo {
        margin-inline: auto;
    }
    .page-title {
        padding: 4rem 2rem;
    }

	a, a:visited	{ text-decoration: underline; }
    pre, blockquote	{ border: 1px solid #999; page-break-inside: avoid; }
    thead			{ display: table-header-group; /* h5bp.com/t */ }
    tr, img			{ page-break-inside: avoid; }
    img				{ max-width: 100% !important; }
    @page			{ margin: 0.5cm; }
    p, h2, h3		{ orphans: 3; widows: 3; }
    h2, h3			{ page-break-after: avoid; }

		.svg-mask, .svg-mask-square, #meta-footer, #footer, #header { display: none !important; }
		.answer.none { display: block !important; }

}
